X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/ccc70fb914a4f565d2f637e2202df76dffe77a50..e41814d1395803bdb46bfa4db88424be9d47071f:/app/abilities/api_capability.rb?ds=sidebyside diff --git a/app/abilities/api_capability.rb b/app/abilities/api_capability.rb index 2035afff9..1c2eab41f 100644 --- a/app/abilities/api_capability.rb +++ b/app/abilities/api_capability.rb @@ -5,17 +5,18 @@ class ApiCapability def initialize(token) if Settings.status != "database_offline" - user = (User.find(token.resource_owner_id) if token.respond_to?(:resource_owner_id)) + user = User.find(token.resource_owner_id) if user&.active? can [:create, :comment, :close, :reopen], Note if scope?(token, :write_notes) - can [:show, :data], Trace if scope?(token, :read_gpx) + can [:create, :destroy], NoteSubscription if scope?(token, :write_notes) + can [:read, :data], Trace if scope?(token, :read_gpx) can [:create, :update, :destroy], Trace if scope?(token, :write_gpx) can [:details], User if scope?(token, :read_prefs) can [:gpx_files], User if scope?(token, :read_gpx) - can [:index, :show], UserPreference if scope?(token, :read_prefs) + can :read, UserPreference if scope?(token, :read_prefs) can [:update, :update_all, :destroy], UserPreference if scope?(token, :write_prefs) - can [:inbox, :outbox, :show, :update, :destroy], Message if scope?(token, :consume_messages) + can [:inbox, :outbox, :read, :update, :destroy], Message if scope?(token, :consume_messages) can [:create], Message if scope?(token, :send_messages) if user.terms_agreed? @@ -27,7 +28,7 @@ class ApiCapability if user.moderator? can [:destroy, :restore], ChangesetComment if scope?(token, :write_api) can :destroy, Note if scope?(token, :write_notes) - can :redact, [OldNode, OldWay, OldRelation] if user&.terms_agreed? && (scope?(token, :write_api) || scope?(token, :write_redactions)) + can :redact, [OldNode, OldWay, OldRelation] if user&.terms_agreed? && scope?(token, :write_redactions) end end end