diff options
author | Eugen Rochko <eugen@zeonfederated.com> | 2021-03-01 18:39:47 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-03-01 18:39:47 +0100 |
commit | ee1119208c613b9ded7ebfb2a5a7b8bd5a5ef008 (patch) | |
tree | becd592fb3d5015681a31613d74d73a132609740 /app/controllers/api/v1/emails | |
parent | 287aa75f2ecc9bbbb75047e96e64882d8d14fd82 (diff) |
Add `POST /api/v1/emails/confirmations` to REST API (#15816)
Only available to the application the user originally signed-up with
Diffstat (limited to 'app/controllers/api/v1/emails')
-rw-r--r-- | app/controllers/api/v1/emails/confirmations_controller.rb | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/app/controllers/api/v1/emails/confirmations_controller.rb b/app/controllers/api/v1/emails/confirmations_controller.rb new file mode 100644 index 000000000..03ab5de8c --- /dev/null +++ b/app/controllers/api/v1/emails/confirmations_controller.rb @@ -0,0 +1,17 @@ +# frozen_string_literal: true + +class Api::V1::Emails::ConfirmationsController < Api::BaseController + before_action :doorkeeper_authorize! + before_action :require_user_owned_by_application! + + def create + current_user.resend_confirmation_instructions if current_user.unconfirmed_email.present? + render_empty + end + + private + + def require_user_owned_by_application! + render json: { error: 'This method is only available to the application the user originally signed-up with' }, status: :forbidden unless current_user && current_user.created_by_application_id == doorkeeper_token.application_id + end +end |