Andreas Nedbal
a05248fb13
Fix Ruby codestyle in `ServicesController`
2022-01-29 20:08:41 +01:00
Andreas Nedbal
592de78a4f
Add translations for `ServicesController`
2022-01-29 20:08:41 +01:00
Andreas Nedbal
c08545fe7c
Fix typo
2022-01-25 22:31:25 +01:00
Andreas Nedbal
ac83995dfc
Add controller-scoped locales for `AnnouncementController`
2022-01-25 22:31:25 +01:00
Andreas Nedbal
8d73008ebf
Address review suggestions
2022-01-24 20:13:09 +01:00
Andreas Nedbal
fb812d4f36
Appease the mighty dog overlords (fix Ruby code nits)
2022-01-24 20:13:09 +01:00
Andreas Nedbal
ad60e3c753
Disable locale switching logic
2022-01-24 20:13:09 +01:00
Karina Kwiatek
3b1287c424
Apply suggestions from @nilsding
...
Co-authored-by: Georg Gadinger <nilsding@nilsding.org>
2022-01-23 16:48:53 +01:00
Karina Kwiatek
731ee4bf69
Address review comments from @nilsding
2022-01-23 16:48:53 +01:00
Karina Kwiatek
677ce26e6c
Use generic handling of our own exceptions
...
Noticed that we shouldn't be trying to catch specific exceptions as `Dry::Types` will throw its own exceptions for validation errors.
2022-01-23 16:48:53 +01:00
Karina Kwiatek
29d46b43db
Fix lint error; use fail message for relationship create failures
2022-01-23 16:48:53 +01:00
Karina Kwiatek
8d59ef9398
Use `screen_name` instead of `target_user` param in `Ajax::RelationshipController`
2022-01-23 16:48:53 +01:00
Karina Kwiatek
b4e0699e82
Fix lint errors
2022-01-23 16:48:53 +01:00
Karina Kwiatek
0ab822c33a
Use full translation key for messages
2022-01-23 16:48:53 +01:00
Karina Kwiatek
d609435f7c
Update `Ajax::RelationshipController` to use usernames; Test Use Case
2022-01-23 16:48:53 +01:00
Karina Kwiatek
3962671135
Implement relationship logic as use case
2022-01-23 16:48:53 +01:00
Karina Kwiatek
ce951453a2
Make relationships polymorphic
2022-01-23 16:48:53 +01:00
Andreas Nedbal
d56dfc02f9
Move consent POST-logic to separate action
2022-01-22 22:50:32 +01:00
Andreas Nedbal
3711c676da
Fix Ruby codestyle
2022-01-22 22:50:32 +01:00
Andreas Nedbal
4d4296de19
Redirect away from consent action if consent is already given
2022-01-22 22:50:32 +01:00
Andreas Nedbal
0b76ceb73d
WIP: Canny integration
2022-01-22 22:50:32 +01:00
Karina Kwiatek
45854894dc
Upgrade to Rails 6.0
2022-01-13 21:42:06 +01:00
Karina Kwiatek
136e2fa016
Merge pull request #272 from Retrospring/feature/social-post-tagging
...
Add the ability to post to services with a tag
2022-01-07 19:40:52 +01:00
Karina Kwiatek
96e48a833b
Merge pull request #194 from Retrospring/refactor/user-bans
...
Implement ban history
2022-01-06 14:05:33 +01:00
Karina Kwiatek
75d24db1b9
Merge pull request #269 from Retrospring/feature/mod-pagination
...
Pagination in moderation panel
2022-01-06 14:05:12 +01:00
Karina Kwiatek
ac92a8b6bd
Use `String#tr` instead of `String#gsub`
2022-01-05 20:09:34 +01:00
Karina Kwiatek
023b642bc1
Disallow @ symbols from post tags
...
Co-authored-by: Andreas Nedbal <git@pixelde.su>
2022-01-05 19:50:01 +01:00
Karina Kwiatek
683fffd734
Add the ability to post to services with a tag
2022-01-05 19:49:59 +01:00
Andreas Nedbal
7fcb8312b9
Put `/settings/muted` behind authentication
2022-01-04 01:35:14 +01:00
Karina Kwiatek
2cab96b9af
Implement cursored pagination in Moderation Panel
2022-01-03 22:43:37 +01:00
Karina Kwiatek
7677ed21a4
Update tests for unbanning users
2022-01-02 19:50:44 +01:00
Karina Kwiatek
6500d7ac71
Update usages of bans
2022-01-02 19:50:44 +01:00
Karina Kwiatek
9a35584284
Refactor ban-related functionality into use cases
2022-01-02 19:50:01 +01:00
Karina Kwiatek
be0cf69368
Refactor existing ban-related methods
2022-01-02 19:50:01 +01:00
Karina Kwiatek
b7ce9cdbba
Merge pull request #222 from Retrospring/feature/muting
2022-01-02 15:31:49 +01:00
Karina Kwiatek
6b626765a8
Create views for managing muted words
2022-01-02 01:55:52 +01:00
Karina Kwiatek
9ce1fc0ce4
Address review comments from @nilsding
...
Co-authored-by: Georg Gadinger <nilsding@nilsding.org>
2022-01-01 22:10:13 +01:00
Karina Kwiatek
fe6dff8ed6
Improve error messaging when trying to attach a service connected to another account
2022-01-01 21:58:22 +01:00
Karina Kwiatek
6c0e6b1d30
Create mute rules AJAX controller
2022-01-01 00:38:38 +01:00
Karina Kwiatek
c31ab3578d
Apply mute filters to questions asked directly
2022-01-01 00:38:38 +01:00
Andreas Nedbal
09172a56ef
Add linkfilter action
2021-12-31 22:40:38 +01:00
Karina Kwiatek
0da070c5ff
Move includes into `cursored_friends`/`cursored_followers`
2021-12-31 15:35:02 +01:00
Karina Kwiatek
7e57735b88
Add basic test for answer & user show views
2021-12-31 13:59:15 +01:00
Karina Kwiatek
32e6975c28
Include smiles when eager loading answers
2021-12-30 23:21:46 +01:00
Karina Kwiatek
7357e92865
Eager load relationships for questions, answers and users
2021-12-30 22:15:59 +01:00
Andreas Nedbal
dcc781df3d
Put all security related actions behind authentication
2021-12-29 22:35:17 +01:00
Karina Kwiatek
1b4aa8600d
Set Sentry user context
2021-12-28 19:19:27 +01:00
Karina Kwiatek
065e56ccf1
Replace New Relic with Sentry
2021-12-28 18:32:03 +01:00
Karina Kwiatek
053ebafbc5
Merge pull request #213 from Retrospring/refactor/profile
...
Move profile fields to seperate table
2021-12-25 22:44:10 +01:00
Karina Kwiatek
f28f714457
Allow retries for ShareWorker
2021-12-25 13:40:21 +01:00
Karina Kwiatek
8fa4feb469
Add endpoint for updating profile
2021-12-22 00:03:19 +01:00
Andreas Nedbal
58588d22b1
use .where.not instead of in-query condition for user confirm date
2021-10-03 20:49:33 +02:00
Andreas Nedbal
6639f6646a
only count active users on about page
2021-10-03 20:40:25 +02:00
Karina Kwiatek
56786ebb38
Add direct field to questions
...
Co-authored-by: Georg Gadinger <nilsding@nilsding.org>
2021-08-11 16:56:58 +02:00
Dominik Kwiatek
2e6f49819a
Address @nilsding's review comments
2020-11-15 22:08:18 +01:00
Dominik Kwiatek
aeb1396422
Add tests for recovery codes
2020-11-15 10:21:06 +01:00
Dominik Kwiatek
e16896fac1
Provide the user a way to generate new codes.
2020-11-01 18:52:42 +01:00
Dominik Kwiatek
61d82bdbec
Display count of remaining recovery codes
2020-11-01 18:41:37 +01:00
Dominik Kwiatek
5eb4f32660
Clean up after TOTP is disabled.
2020-11-01 18:31:20 +01:00
Dominik Kwiatek
5dd920eba2
Allow recovery codes to be used to sign in in place of a OTP
2020-11-01 18:29:11 +01:00
Dominik Kwiatek
b4f479a00f
Generate recovery keys on TOTP setup
2020-11-01 17:55:31 +01:00
Dominik Kwiatek
d20f527d8c
Add drift period
2020-10-24 00:24:04 +02:00
Dominik Kwiatek
0f80bcef14
Remove I18n. prefix
2020-10-23 21:01:00 +02:00
Dominik Kwiatek
702156258c
Remove user/sessions#two_factor_entry
2020-10-23 21:00:06 +02:00
Dominik Kwiatek
66cccbb5d6
Use the same string for 2FA failures
2020-10-23 20:58:42 +02:00
Dominik Kwiatek
d7a1750694
Implement @nilsding's review changes
2020-10-23 20:45:06 +02:00
Dominik Kwiatek
556050aa66
Add tests for security settings page
2020-10-21 13:44:00 +02:00
Dominik Kwiatek
3211f8f59b
Make OTP secret longer
2020-10-19 20:25:18 +02:00
Dominik Kwiatek
433f1d45e5
Use controller for setting up QR Code
2020-10-19 14:56:13 +02:00
Dominik Kwiatek
00da21a13d
Redirect away from two factor entry page if no target user is set in session
2020-10-19 12:20:44 +02:00
Dominik Kwiatek
4ce5dfc92a
Fix detaching, improve UI for attaching 2FA
2020-10-18 19:48:12 +02:00
Dominik Kwiatek
25410e111d
Fix OTP auth triggering for users who haven't set it up
...
I thought I could be clever by using a null secret key as an indicator of it being disabled
2020-10-18 11:39:28 +02:00
Dominik Kwiatek
141ff59f63
Implement Two Factor Authentication
2020-10-18 10:39:46 +02:00
Dominik M. Kwiatek
a92dd54be3
Address @nilsding's review comments
2020-05-27 20:07:39 +01:00
Dominik M. Kwiatek
984976a2f7
Omit hCaptcha if it is disabled
2020-05-27 20:07:39 +01:00
Dominik M. Kwiatek
7cac93ad4e
Add hCaptcha
2020-05-27 20:07:39 +01:00
Georg Gadinger
b58883e004
Remove "ask a group" feature
2020-05-25 18:34:43 +02:00
Georg Gadinger
ea0685136e
Rename Groups to Lists
...
haha regexp go brrr
special thanks to @seatsea for helping me out with the French locales
2020-05-25 18:04:54 +02:00
Karina Kwiatek
ff9741589d
Implement cropping; make uploaders DRY
2020-05-17 20:38:40 +01:00
Georg Gadinger
9b4c8027b8
Fix pagination for ajax views
2020-05-09 04:39:09 +02:00
Andreas Nedbal
928eeb28f3
Redirect user to edit_user_theme_path after deletion
2020-05-06 22:19:30 +02:00
Andreas Nedbal
880429f5f9
Add new fields for themes
...
- In the settings view
- In the model validation
- In the controller parameter permissions
- In the CoffeeScript/Ruby helpers
2020-05-05 02:02:16 +02:00
Andreas Nedbal
53979580d8
Merge branch 'master' into feature/bootstrap
2020-05-04 23:19:54 +02:00
Andreas Nedbal
e7c5b1a4a3
Remove theme preview route and logic
2020-05-04 17:26:38 +02:00
Georg Gadinger
0109322610
add spec for Ajax::ModerationController
2020-05-01 22:41:26 +02:00
Georg Gadinger
3e95d5ebeb
add spec for Ajax::ReportController
2020-05-01 10:17:05 +02:00
Georg Gadinger
6f3f3afa2f
add spec for Ajax::GroupController
2020-05-01 10:17:05 +02:00
Georg Gadinger
54532c71e1
add spec for Ajax::QuestionController
...
also fix some minor annoyances
2020-05-01 10:17:05 +02:00
Georg Gadinger
1824fb1c25
add spec for Ajax::InboxController
2020-05-01 10:17:05 +02:00
Georg Gadinger
d492cd34f6
AjaxController: also rescue from StandardError
2020-05-01 10:17:05 +02:00
Andreas Nedbal
91a7f7ed33
Fix wrong partial in Ajax::CommentController#create
2020-04-29 14:01:48 +02:00
Andreas Nedbal
b22c7d358c
Fix wrong partial path in Ajax::AnswerController#create
2020-04-29 13:33:53 +02:00
Andreas Nedbal
45b11bddfd
Merge branch 'master' into feature/bootstrap
2020-04-29 02:49:07 +02:00
Georg Gadinger
29a5d0408c
ajax_controller: fix variable name
2020-04-28 21:42:41 +02:00
Georg Gadinger
2f2b9ab1f4
New Relic be like: *notices your errors* OwO what's this?
2020-04-28 20:32:36 +02:00
Georg Gadinger
e07d069c73
Refactor Ajax::*Controllers
...
Also removed the unused `Ajax::QuestionController#preview` method and
route
2020-04-28 20:28:00 +02:00
Andreas Nedbal
e9e0a222b0
Merge branch 'master' into feature/bootstrap
2020-04-27 02:11:54 +02:00
Georg Gadinger
aeef50ad78
Merge pull request #86 from Retrospring/cleanup
...
Minor Cleanup
2020-04-26 20:03:46 +02:00
Karina Kwiatek
926631eca3
Remove more left-over references to role fields
2020-04-25 22:23:37 +01:00
Karina Kwiatek
f42cc6aed9
Remove all other references to removed roles
2020-04-25 21:20:02 +01:00
Andreas Nedbal
96309eb8ba
Move all modals into shared views/modal directory
2020-04-25 15:16:45 +02:00
Georg Gadinger
445d9ebe2a
Fix user questions page
2020-04-23 03:31:07 +02:00
Georg Gadinger
101b3b68d3
Use cursored pagination, remove WillPaginate
2020-04-20 23:13:24 +02:00
Karina Kwiatek
391f4a28ed
Merge branch 'master' into feature/announcements
...
# Conflicts:
# db/schema.rb
2020-04-19 21:52:58 +01:00
Karina Kwiatek
a505e7ee71
Ensure we're logged in as an admin when using the AnnouncementController
2020-04-19 21:45:07 +01:00
Karina Kwiatek
b6d6c1fded
Add announcements to the top of the application template
2020-04-19 21:38:21 +01:00
Georg Gadinger
946bb3ae9d
Use Rolify for admin and moderator roles
2020-04-19 22:35:58 +02:00
Karina Kwiatek
473f2cdcc5
Show announcement validation errors on the frontend
2020-04-19 21:26:55 +01:00
Karina Kwiatek
6187cb0b6c
Add the ability to edit announcements
2020-04-19 20:58:57 +01:00
Karina Kwiatek
f14a168bce
Implement deletion of announcements
2020-04-19 20:50:33 +01:00
Karina Kwiatek
e3b89f7346
Implement creation of announcements
2020-04-19 20:34:48 +01:00
Karina Kwiatek
8a632a09cd
Create Announcement model & controller
2020-04-19 20:12:22 +01:00
Georg Gadinger
8b129bbbf4
Fix moderation panel.
2020-04-19 18:33:20 +02:00
Georg Gadinger
6f6ac3cc7d
Merge remote-tracking branch 'origin/master' into rails5
2020-04-19 14:32:47 +02:00
Georg Gadinger
9fa8ef1501
enable 'Discover' page for mods
2020-04-19 13:55:13 +02:00
Karina Kwiatek
a19402af41
Upgrade to Rails 5.2
2020-04-19 00:45:50 +01:00
Georg Gadinger
d47991f379
Fixes for devise 4.x
2019-03-29 22:37:10 +01:00
Georg G
0deb4c4ccc
added export view/controller/routes
2016-01-05 20:54:38 +01:00
Yuki
e510a6e8b4
Do you feel it, Mr. Krabs?
2015-09-18 18:09:26 +09:00
Yuki
c107cb19cb
LEEDLE LEEDLE LEEE
2015-09-18 18:08:08 +09:00
Yuki
64ba41d9a6
Fix reports
2015-09-18 18:02:16 +09:00
pixeldesu
ede3ad1b92
Update notification design and behaviour
...
- Add display of content that was replied to/with
- Instead of marking notifications new, only show new items and hide seen entries
- Add a 'New Notifications' page and set it as default
- Add proper display if there are no new notifications
- Adjust theme to fit new changes
2015-09-16 22:18:40 +02:00
Yuki
8cbd85a89c
the copy paste is strong
2015-09-01 18:48:56 +05:30
Yuki
4b891b3f70
Fix dangerous send exploit
2015-09-01 18:44:50 +05:30
Yuki
5d3d3a68e7
Fix remote code execution exploit
2015-09-01 18:44:31 +05:30
pixeldesu
a9ad31b285
move check if user is logged in out of template
2015-08-28 16:36:49 +02:00
Yuki
71caf3cce5
Several changes to theming, solving a bunch of bugs
2015-08-27 05:30:26 +05:30
Yuki
a7c3acea76
ISHYGDDT
2015-08-26 02:14:14 +05:30
Yuki
c2da575955
invalid is invalid
2015-08-26 01:20:17 +05:30
Yuki
2e0a00e461
Braces
2015-08-26 00:50:18 +05:30
Yuki
7c68b2a167
PRODUCTION V DEVELOPMENT, ROUND 3 FIGHT
2015-08-26 00:45:08 +05:30
Yuki
906692e78f
Theming is finished
...
Previews, settings pane and presets!
2015-08-25 23:57:06 +05:30
Yuki
1912fc3766
Model goop
...
also made the theme selection logic for user profiles and current user, and the saving logic
2015-08-25 13:56:36 +05:30
Yuki
47344a5774
ThemeHelper.render_theme_with_context
2015-07-29 22:24:33 +05:30
Yuki
aec452cbd1
CSS -> SCSS
2015-07-29 22:01:34 +05:30
Yuki
9ef71a84e9
Merge branch 'master' of github.com:Retrospring/retrospring into feature-themes
2015-07-29 19:52:14 +05:30
Yuki
26a517a650
Fixes, workers now output to sidekiq, not rails
2015-07-27 12:42:12 +05:30
Yuki
92bbfef2df
Moved ask all + ask group to worker, validates user_id for ask person now
2015-07-27 12:29:56 +05:30
Yuki
54b051a7e7
Temp. layout for testing
2015-07-24 22:42:14 +05:30
Yuki
3b0646644a
Replace @users with Hash
2015-07-24 01:14:20 +05:30
Yuki
2aef9bd71f
Support for Ruby 2.0.0
2015-07-24 01:13:39 +05:30
Yuki
deb6d12108
Moderation Priority + IP
2015-07-23 23:21:13 +05:30
pixeldesu
36d6cd5816
remove strict case requirement
2015-07-17 22:46:05 +02:00
pixeldesu
19d6ccd855
change logic for deletion when no user or no question is found
2015-07-17 22:31:10 +02:00
pixeldesu
0044430fa6
fix indentation
2015-07-17 21:59:16 +02:00
pixeldesu
68526bfc4e
removing unnecessary return values
2015-07-17 21:48:33 +02:00
pixeldesu
e1d38ebb89
removing more logic from templates + simpler coffeescript
2015-07-17 21:45:45 +02:00
pixeldesu
8232aa2a21
fix flashes staying on the page
2015-07-17 21:34:53 +02:00
pixeldesu
84f80c824e
fix broken pagination and wrong question count for deletion
2015-07-17 20:54:11 +02:00
pixeldesu
e9ae442431
add ability to show/search questions from specific users
2015-07-17 20:29:19 +02:00
pixeldesu
3a5dcbcd3b
Move account deletion to Sidekiq worker, fixes #11
2015-07-15 01:44:35 +02:00
Yuki
af71f1ef34
Some adjustmenets to locale logic, add 'jp.language: 日本語', regenerate schema
2015-07-04 13:01:46 +05:30
Yuki
409c82b5ed
Flag switcher
2015-06-21 12:33:29 +05:30
pixeldesu
58e80919df
add data page
2015-06-20 20:38:07 +02:00
pixeldesu
c1faf41305
added translator badge to profiles
2015-06-19 14:46:23 +02:00
Yuki
43825a0951
Rename locale cookie
2015-06-11 07:36:33 +05:30
Yuki
c358c34043
HAHA EVERYONE GOT FRENCH BECAUSE I USED A DEPENDENCY, SERVES ME RIGHT
2015-06-10 01:06:47 +05:30
pixeldesu
0aeab3b7f7
fix merge conflict
2015-06-08 22:17:14 +02:00
pixeldesu
984abbe738
git localize flashes
2015-06-07 19:03:57 +02:00
pixeldesu
e6e1d03187
localized ajax controllers
2015-06-07 18:24:01 +02:00
Yuki
ce2323d675
fix tests
2015-06-07 06:27:21 +05:30
Yuki
d11b16dad6
Possibly fix /ajax/preview
2015-06-06 05:57:15 +05:30
Yuki
50e1186e79
Accept-Language header support
2015-05-27 07:06:18 +05:30
Yuki
c6028f8dee
[skip ci] fix comments
2015-05-26 09:01:06 +05:30
Yuki
69a1bb32f4
Basic locale check
2015-05-26 08:56:40 +05:30
pixeldesu
4400779d00
add Most Comments and Most Answered to Discover
2015-05-18 00:57:47 +02:00
Yuki
6c48e47f2c
Only show people that have asked at least 1 question (Discover)
2015-05-15 10:25:26 +05:30
Georg G
140e5bf51e
added some querying magic :neckbeard:
2015-05-13 21:58:00 +02:00
pixeldesu
961ebfd266
add routes and empty index for discover
2015-05-13 20:56:51 +02:00
Georg G
c9a268ebdf
added empty DiscoverController
2015-05-13 20:39:04 +02:00
Georg G
91be970cb9
fixed profile headers
2015-05-10 02:57:18 +02:00
Andreas N.
0145b36510
Merge pull request #22 from Retrospring/profile-headers
...
Profile headers
2015-05-10 02:22:30 +02:00
Yuki
05ca42c819
Fix Retrospring/bugs#49
2015-05-09 05:01:31 +05:30
Yuki
2e6ffdaab7
basic implementation
2015-05-08 21:14:16 +05:30
pixeldesu
42b41a268b
fix not shown ban reason
2015-05-05 18:09:26 +02:00
Georg G.
9b39491d88
Merge pull request #18 from skiprope/temp-bans
...
Support for ban reasons and ban times.
2015-05-05 16:54:23 +02:00
Yuki
8b88827a00
Fix retrospring/bugs#43
2015-05-05 02:36:57 +05:30
Yuki
2204227273
Feature-comment-smiles complete ( fix Retrospring/bugs#42 )
2015-05-04 07:09:47 +05:30
Yuki
9688b7ee48
Merge stable
2015-04-28 10:22:54 +05:30
Yuki
ac14fefb3c
Check privilege
2015-04-26 07:09:51 +05:30
Yuki
ee29e1f28f
Reporting and Deleting logic
2015-04-26 07:06:25 +05:30
Yuki
0bb3895ce8
Small fixes
2015-04-24 00:51:58 +05:30
Yuki
407595c12b
Missing return statement
2015-04-23 06:31:48 +05:30
Yuki
be04d3528c
Support for ban reasons and ban times. Fixes Retrospring/bugs#26 and Retrospring/bugs#25
2015-04-23 06:26:29 +05:30
Yuki
b9bf0b04b6
Add support for report reasons
2015-04-22 08:29:10 +05:30
Yuki
ecffd07344
Support for post subscriptions
2015-04-21 06:42:11 +05:30
Georg G
ced880fe34
made contributor badge changable via web interface
2015-04-19 22:25:04 +02:00
Georg G
141db2e521
Merge branch 'master' of github.com:Retrospring/retrospring
2015-04-19 00:43:04 +02:00
Georg G
399bdf21ee
include MarkdownHelper
2015-04-19 00:42:58 +02:00
Yuki
e2bfc26c75
Markdown preview through AJAX (/ajax/preview)
2015-04-19 03:47:13 +05:30
Andreas N
c50531c988
Merge remote-tracking branch 'remotes/origin/texts' into develop
2015-02-16 18:59:59 +01:00
Georg G
cb606f942a
fixed pagination for real
2015-02-12 22:09:11 +01:00
nilsding
5c2d75ece9
now marking multiple "smiled" and "commented" notifications as read at once
2015-02-12 17:49:05 +01:00
nilsding
31d8e68725
automatically mark notifications as read
2015-02-10 06:53:50 +01:00
Georg G
06cc52ffc5
made these checkboxes work
2015-02-03 17:48:30 +01:00
nilsding
44b4e8721a
alright
2015-01-17 19:53:34 +01:00
nilsding
4a8005b195
closes issue #64
2015-01-17 19:49:11 +01:00
nilsding
2ffd514bf1
forgot the @
2015-01-17 19:14:18 +01:00
nilsding
1c26af4c8c
@group now holds the current group
2015-01-17 19:07:31 +01:00
nilsding
927ec9678f
deleting groups works now! finally!!!
2015-01-17 18:57:23 +01:00