422 Error occurs when editing a staff alias topic's title

The Staf-alias plugin will cause a 422 error when editing with the box at the top of the topic (pictured)

Under /logs I see an error message that is obviously wrong

Apparently, I’m in the Staff Alias group myself, so I think it’s a failed authentication bug

info:

ActiveRecord::RecordInvalid (验证失败:You can only edit a staff alias post as the staff alias user.)
lib/post_revisor.rb:524:in `create_revision'
lib/post_revisor.rb:511:in `create_or_update_revision'
lib/post_revisor.rb:391:in `revise'
lib/post_revisor.rb:383:in `revise_and_create_new_version'
lib/post_revisor.rb:289:in `revise_post'
lib/post_revisor.rb:209:in `block in revise!'
lib/post_revisor.rb:208:in `revise!'
app/controllers/topics_controller.rb:423:in `update'
app/controllers/application_controller.rb:414:in `block in with_resolved_locale'
app/controllers/application_controller.rb:414:in `with_resolved_locale'
lib/middleware/omniauth_bypass_middleware.rb:74:in `call'
lib/content_security_policy/middleware.rb:12:in `call'
lib/middleware/anonymous_cache.rb:369:in `call'
config/initializers/100-quiet_logger.rb:20:in `call'
config/initializers/100-silence_logger.rb:29:in `call'
lib/middleware/enforce_hostname.rb:24:in `call'
lib/middleware/request_tracker.rb:228:in `call'

backtrace

activerecord (7.0.4.3) lib/active_record/validations.rb:80:in `raise_validation_error'
activerecord (7.0.4.3) lib/active_record/validations.rb:53:in `save!'
activerecord (7.0.4.3) lib/active_record/transactions.rb:302:in `block in save!'
activerecord (7.0.4.3) lib/active_record/transactions.rb:354:in `block in with_transaction_returning_status'
activerecord (7.0.4.3) lib/active_record/connection_adapters/abstract/database_statements.rb:314:in `transaction'
activerecord (7.0.4.3) lib/active_record/transactions.rb:350:in `with_transaction_returning_status'
activerecord (7.0.4.3) lib/active_record/transactions.rb:302:in `save!'
activerecord (7.0.4.3) lib/active_record/suppressor.rb:54:in `save!'
activerecord (7.0.4.3) lib/active_record/persistence.rb:55:in `create!'
lib/post_revisor.rb:524:in `create_revision'
lib/post_revisor.rb:511:in `create_or_update_revision'
lib/post_revisor.rb:391:in `revise'
lib/post_revisor.rb:383:in `revise_and_create_new_version'
lib/post_revisor.rb:289:in `revise_post'
lib/post_revisor.rb:209:in `block in revise!'
activerecord (7.0.4.3) lib/active_record/connection_adapters/abstract/transaction.rb:319:in `block in within_new_transaction'
activesupport (7.0.4.3) lib/active_support/concurrency/load_interlock_aware_monitor.rb:25:in `handle_interrupt'
activesupport (7.0.4.3) lib/active_support/concurrency/load_interlock_aware_monitor.rb:25:in `block in synchronize'
activesupport (7.0.4.3) lib/active_support/concurrency/load_interlock_aware_monitor.rb:21:in `handle_interrupt'
activesupport (7.0.4.3) lib/active_support/concurrency/load_interlock_aware_monitor.rb:21:in `synchronize'
activerecord (7.0.4.3) lib/active_record/connection_adapters/abstract/transaction.rb:317:in `within_new_transaction'
activerecord (7.0.4.3) lib/active_record/connection_adapters/abstract/database_statements.rb:316:in `transaction'
activerecord (7.0.4.3) lib/active_record/transactions.rb:209:in `transaction'
lib/post_revisor.rb:208:in `revise!'
app/controllers/topics_controller.rb:423:in `update'
plugins/discourse-encrypt/lib/topics_controller_extensions.rb:20:in `update'
actionpack (7.0.4.3) lib/action_controller/metal/basic_implicit_render.rb:6:in `send_action'
actionpack (7.0.4.3) lib/abstract_controller/base.rb:215:in `process_action'
actionpack (7.0.4.3) lib/action_controller/metal/rendering.rb:53:in `process_action'
actionpack (7.0.4.3) lib/abstract_controller/callbacks.rb:234:in `block in process_action'
activesupport (7.0.4.3) lib/active_support/callbacks.rb:118:in `block in run_callbacks'
plugins/discourse-staff-alias/plugin.rb:105:in `block (4 levels) in activate!'
activesupport (7.0.4.3) lib/active_support/callbacks.rb:127:in `instance_exec'
activesupport (7.0.4.3) lib/active_support/callbacks.rb:127:in `block in run_callbacks'
app/controllers/application_controller.rb:414:in `block in with_resolved_locale'
i18n (1.12.0) lib/i18n.rb:322:in `with_locale'
app/controllers/application_controller.rb:414:in `with_resolved_locale'
activesupport (7.0.4.3) lib/active_support/callbacks.rb:127:in `block in run_callbacks'
activesupport (7.0.4.3) lib/active_support/callbacks.rb:138:in `run_callbacks'
actionpack (7.0.4.3) lib/abstract_controller/callbacks.rb:233:in `process_action'
actionpack (7.0.4.3) lib/action_controller/metal/rescue.rb:22:in `process_action'
actionpack (7.0.4.3) lib/action_controller/metal/instrumentation.rb:67:in `block in process_action'
activesupport (7.0.4.3) lib/active_support/notifications.rb:206:in `block in instrument'
activesupport (7.0.4.3) lib/active_support/notifications/instrumenter.rb:24:in `instrument'
activesupport (7.0.4.3) lib/active_support/notifications.rb:206:in `instrument'
actionpack (7.0.4.3) lib/action_controller/metal/instrumentation.rb:66:in `process_action'
actionpack (7.0.4.3) lib/action_controller/metal/params_wrapper.rb:259:in `process_action'
activerecord (7.0.4.3) lib/active_record/railties/controller_runtime.rb:27:in `process_action'
actionpack (7.0.4.3) lib/abstract_controller/base.rb:151:in `process'
actionview (7.0.4.3) lib/action_view/rendering.rb:39:in `process'
rack-mini-profiler (3.0.0) lib/mini_profiler/profiling_methods.rb:85:in `block in profile_method' 
actionpack (7.0.4.3) lib/action_controller/metal.rb:188:in `dispatch'
actionpack (7.0.4.3) lib/action_controller/metal.rb:251:in `dispatch'
actionpack (7.0.4.3) lib/action_dispatch/routing/route_set.rb:49:in `dispatch'
actionpack (7.0.4.3) lib/action_dispatch/routing/route_set.rb:32:in `serve'
actionpack (7.0.4.3) lib/action_dispatch/journey/router.rb:50:in `block in serve'
actionpack (7.0.4.3) lib/action_dispatch/journey/router.rb:32:in `each'
actionpack (7.0.4.3) lib/action_dispatch/journey/router.rb:32:in `serve'
actionpack (7.0.4.3) lib/action_dispatch/routing/route_set.rb:852:in `call'
lib/middleware/omniauth_bypass_middleware.rb:74:in `call'
rack (2.2.6.4) lib/rack/tempfile_reaper.rb:15:in `call'
rack (2.2.6.4) lib/rack/conditional_get.rb:40:in `call'
rack (2.2.6.4) lib/rack/head.rb:12:in `call'
actionpack (7.0.4.3) lib/action_dispatch/http/permissions_policy.rb:38:in `call'
lib/content_security_policy/middleware.rb:12:in `call'
lib/middleware/anonymous_cache.rb:369:in `call'
rack (2.2.6.4) lib/rack/session/abstract/id.rb:266:in `context'
rack (2.2.6.4) lib/rack/session/abstract/id.rb:260:in `call'
actionpack (7.0.4.3) lib/action_dispatch/middleware/cookies.rb:704:in `call'
actionpack (7.0.4.3) lib/action_dispatch/middleware/callbacks.rb:27:in `block in call'
activesupport (7.0.4.3) lib/active_support/callbacks.rb:99:in `run_callbacks'
actionpack (7.0.4.3) lib/action_dispatch/middleware/callbacks.rb:26:in `call'
actionpack (7.0.4.3) lib/action_dispatch/middleware/debug_exceptions.rb:28:in `call'
actionpack (7.0.4.3) lib/action_dispatch/middleware/show_exceptions.rb:26:in `call'
logster (2.12.2) lib/logster/middleware/reporter.rb:43:in `call'
railties (7.0.4.3) lib/rails/rack/logger.rb:40:in `call_app'
railties (7.0.4.3) lib/rails/rack/logger.rb:27:in `call'
config/initializers/100-quiet_logger.rb:20:in `call'
config/initializers/100-silence_logger.rb:29:in `call'
actionpack (7.0.4.3) lib/action_dispatch/middleware/remote_ip.rb:93:in `call'
actionpack (7.0.4.3) lib/action_dispatch/middleware/request_id.rb:26:in `call'
lib/middleware/enforce_hostname.rb:24:in `call'
rack (2.2.6.4) lib/rack/method_override.rb:24:in `call'
actionpack (7.0.4.3) lib/action_dispatch/middleware/executor.rb:14:in `call'
rack (2.2.6.4) lib/rack/sendfile.rb:110:in `call'
actionpack (7.0.4.3) lib/action_dispatch/middleware/host_authorization.rb:131:in `call'
rack-mini-profiler (3.0.0) lib/mini_profiler/profiler.rb:249:in `call' 
message_bus (4.3.2) lib/message_bus/rack/middleware.rb:60:in `call'
lib/middleware/request_tracker.rb:228:in `call'
railties (7.0.4.3) lib/rails/engine.rb:530:in `call'
railties (7.0.4.3) lib/rails/railtie.rb:226:in `public_send'
railties (7.0.4.3) lib/rails/railtie.rb:226:in `method_missing'
rack (2.2.6.4) lib/rack/urlmap.rb:74:in `block in call'
rack (2.2.6.4) lib/rack/urlmap.rb:58:in `each'
rack (2.2.6.4) lib/rack/urlmap.rb:58:in `call'
unicorn (6.1.0) lib/unicorn/http_server.rb:634:in `process_client'
unicorn (6.1.0) lib/unicorn/http_server.rb:739:in `worker_loop'
unicorn (6.1.0) lib/unicorn/http_server.rb:547:in `spawn_missing_workers'
unicorn (6.1.0) lib/unicorn/http_server.rb:143:in `start'
unicorn (6.1.0) bin/unicorn:128:in `<top (required)>'
vendor/bundle/ruby/3.2.0/bin/unicorn:25:in `load'
vendor/bundle/ruby/3.2.0/bin/unicorn:25:in `<main>'

info of warning

Failed to handle exception in exception app middleware : ActiveRecord::RecordInvalid : 验证失败:You can only edit a staff alias post as the staff alias user.

backtrace

activerecord-7.0.4.3/lib/active_record/validations.rb:80:in `raise_validation_error' 
activerecord-7.0.4.3/lib/active_record/validations.rb:53:in `save!' 
activerecord-7.0.4.3/lib/active_record/transactions.rb:302:in `block in save!' 
activerecord-7.0.4.3/lib/active_record/transactions.rb:354:in `block in with_transaction_returning_status' 
activerecord-7.0.4.3/lib/active_record/connection_adapters/abstract/database_statements.rb:314:in `transaction' 
activerecord-7.0.4.3/lib/active_record/transactions.rb:350:in `with_transaction_returning_status' 
activerecord-7.0.4.3/lib/active_record/transactions.rb:302:in `save!' 
activerecord-7.0.4.3/lib/active_record/suppressor.rb:54:in `save!' 
activerecord-7.0.4.3/lib/active_record/persistence.rb:55:in `create!' 
/var/www/discourse/lib/post_revisor.rb:524:in `create_revision' 
/var/www/discourse/lib/post_revisor.rb:511:in `create_or_update_revision' 
/var/www/discourse/lib/post_revisor.rb:391:in `revise' 
/var/www/discourse/lib/post_revisor.rb:383:in `revise_and_create_new_version' 
/var/www/discourse/lib/post_revisor.rb:289:in `revise_post' 
/var/www/discourse/lib/post_revisor.rb:209:in `block in revise!' 
activerecord-7.0.4.3/lib/active_record/connection_adapters/abstract/transaction.rb:319:in `block in within_new_transaction' 
activesupport-7.0.4.3/lib/active_support/concurrency/load_interlock_aware_monitor.rb:25:in `handle_interrupt' 
activesupport-7.0.4.3/lib/active_support/concurrency/load_interlock_aware_monitor.rb:25:in `block in synchronize' 
activesupport-7.0.4.3/lib/active_support/concurrency/load_interlock_aware_monitor.rb:21:in `handle_interrupt' 
activesupport-7.0.4.3/lib/active_support/concurrency/load_interlock_aware_monitor.rb:21:in `synchronize' 
activerecord-7.0.4.3/lib/active_record/connection_adapters/abstract/transaction.rb:317:in `within_new_transaction' 
activerecord-7.0.4.3/lib/active_record/connection_adapters/abstract/database_statements.rb:316:in `transaction' 
activerecord-7.0.4.3/lib/active_record/transactions.rb:209:in `transaction' 
/var/www/discourse/lib/post_revisor.rb:208:in `revise!' 
/var/www/discourse/app/controllers/topics_controller.rb:423:in `update' 
/var/www/discourse/plugins/discourse-encrypt/lib/topics_controller_extensions.rb:20:in `update' 
actionpack-7.0.4.3/lib/action_controller/metal/basic_implicit_render.rb:6:in `send_action' 
actionpack-7.0.4.3/lib/abstract_controller/base.rb:215:in `process_action' 
actionpack-7.0.4.3/lib/action_controller/metal/rendering.rb:53:in `process_action' 
actionpack-7.0.4.3/lib/abstract_controller/callbacks.rb:234:in `block in process_action' 
activesupport-7.0.4.3/lib/active_support/callbacks.rb:118:in `block in run_callbacks' 
/var/www/discourse/plugins/discourse-staff-alias/plugin.rb:105:in `block (4 levels) in activate!' 
activesupport-7.0.4.3/lib/active_support/callbacks.rb:127:in `instance_exec' 
activesupport-7.0.4.3/lib/active_support/callbacks.rb:127:in `block in run_callbacks' 
/var/www/discourse/app/controllers/application_controller.rb:414:in `block in with_resolved_locale' 
i18n-1.12.0/lib/i18n.rb:322:in `with_locale' 
/var/www/discourse/app/controllers/application_controller.rb:414:in `with_resolved_locale' 
activesupport-7.0.4.3/lib/active_support/callbacks.rb:127:in `block in run_callbacks' 
activesupport-7.0.4.3/lib/active_support/callbacks.rb:138:in `run_callbacks' 
actionpack-7.0.4.3/lib/abstract_controller/callbacks.rb:233:in `process_action' 
actionpack-7.0.4.3/lib/action_controller/metal/rescue.rb:22:in `process_action' 
actionpack-7.0.4.3/lib/action_controller/metal/instrumentation.rb:67:in `block in process_action' 
activesupport-7.0.4.3/lib/active_support/notifications.rb:206:in `block in instrument' 
activesupport-7.0.4.3/lib/active_support/notifications/instrumenter.rb:24:in `instrument' 
activesupport-7.0.4.3/lib/active_support/notifications.rb:206:in `instrument' 
actionpack-7.0.4.3/lib/action_controller/metal/instrumentation.rb:66:in `process_action' 
actionpack-7.0.4.3/lib/action_controller/metal/params_wrapper.rb:259:in `process_action' 
activerecord-7.0.4.3/lib/active_record/railties/controller_runtime.rb:27:in `process_action' 
actionpack-7.0.4.3/lib/abstract_controller/base.rb:151:in `process' 
actionview-7.0.4.3/lib/action_view/rendering.rb:39:in `process' 
rack-mini-profiler-3.0.0/lib/mini_profiler/profiling_methods.rb:85:in `block in profile_method' 
actionpack-7.0.4.3/lib/action_controller/metal.rb:188:in `dispatch' 
actionpack-7.0.4.3/lib/action_controller/metal.rb:251:in `dispatch' 
actionpack-7.0.4.3/lib/action_dispatch/routing/route_set.rb:49:in `dispatch' 
actionpack-7.0.4.3/lib/action_dispatch/routing/route_set.rb:32:in `serve' 
actionpack-7.0.4.3/lib/action_dispatch/journey/router.rb:50:in `block in serve' 
actionpack-7.0.4.3/lib/action_dispatch/journey/router.rb:32:in `each' 
actionpack-7.0.4.3/lib/action_dispatch/journey/router.rb:32:in `serve' 
actionpack-7.0.4.3/lib/action_dispatch/routing/route_set.rb:852:in `call' 
/var/www/discourse/lib/middleware/omniauth_bypass_middleware.rb:74:in `call' 
rack-2.2.6.4/lib/rack/tempfile_reaper.rb:15:in `call' 
rack-2.2.6.4/lib/rack/conditional_get.rb:40:in `call' 
rack-2.2.6.4/lib/rack/head.rb:12:in `call' 
actionpack-7.0.4.3/lib/action_dispatch/http/permissions_policy.rb:38:in `call' 
/var/www/discourse/lib/content_security_policy/middleware.rb:12:in `call' 
/var/www/discourse/lib/middleware/anonymous_cache.rb:369:in `call' 
rack-2.2.6.4/lib/rack/session/abstract/id.rb:266:in `context' 
rack-2.2.6.4/lib/rack/session/abstract/id.rb:260:in `call' 
actionpack-7.0.4.3/lib/action_dispatch/middleware/cookies.rb:704:in `call' 
actionpack-7.0.4.3/lib/action_dispatch/middleware/callbacks.rb:27:in `block in call' 
activesupport-7.0.4.3/lib/active_support/callbacks.rb:99:in `run_callbacks' 
actionpack-7.0.4.3/lib/action_dispatch/middleware/callbacks.rb:26:in `call' 
actionpack-7.0.4.3/lib/action_dispatch/middleware/debug_exceptions.rb:28:in `call' 
actionpack-7.0.4.3/lib/action_dispatch/middleware/show_exceptions.rb:26:in `call' 
logster-2.12.2/lib/logster/middleware/reporter.rb:43:in `call' 
railties-7.0.4.3/lib/rails/rack/logger.rb:40:in `call_app' 
railties-7.0.4.3/lib/rails/rack/logger.rb:27:in `call' 
/var/www/discourse/config/initializers/100-quiet_logger.rb:20:in `call' 
/var/www/discourse/config/initializers/100-silence_logger.rb:29:in `call' 
actionpack-7.0.4.3/lib/action_dispatch/middleware/remote_ip.rb:93:in `call' 
actionpack-7.0.4.3/lib/action_dispatch/middleware/request_id.rb:26:in `call' 
/var/www/discourse/lib/middleware/enforce_hostname.rb:24:in `call' 
rack-2.2.6.4/lib/rack/method_override.rb:24:in `call' 
actionpack-7.0.4.3/lib/action_dispatch/middleware/executor.rb:14:in `call' 
rack-2.2.6.4/lib/rack/sendfile.rb:110:in `call' 
actionpack-7.0.4.3/lib/action_dispatch/middleware/host_authorization.rb:131:in `call' 
rack-mini-profiler-3.0.0/lib/mini_profiler/profiler.rb:249:in `call' 
message_bus-4.3.2/lib/message_bus/rack/middleware.rb:60:in `call' 
/var/www/discourse/lib/middleware/request_tracker.rb:228:in `call' 
railties-7.0.4.3/lib/rails/engine.rb:530:in `call' 
railties-7.0.4.3/lib/rails/railtie.rb:226:in `public_send' 
railties-7.0.4.3/lib/rails/railtie.rb:226:in `method_missing' 
rack-2.2.6.4/lib/rack/urlmap.rb:74:in `block in call' 
rack-2.2.6.4/lib/rack/urlmap.rb:58:in `each' 
rack-2.2.6.4/lib/rack/urlmap.rb:58:in `call' 
unicorn-6.1.0/lib/unicorn/http_server.rb:634:in `process_client'
unicorn-6.1.0/lib/unicorn/http_server.rb:739:in `worker_loop'
unicorn-6.1.0/lib/unicorn/http_server.rb:547:in `spawn_missing_workers'
unicorn-6.1.0/lib/unicorn/http_server.rb:143:in `start'
unicorn-6.1.0/bin/unicorn:128:in `<top (required)>'
/var/www/discourse/vendor/bundle/ruby/3.2.0/bin/unicorn:25:in `load' 
/var/www/discourse/vendor/bundle/ruby/3.2.0/bin/unicorn:25:in `<main>' 

2 Likes

It seems that the plugin had not yet accounted for title edits when a topic is created by a staff alias user.

4 Likes

Sincerely appreciate you for your quick reply! :blush:

1 Like