summaryrefslogtreecommitdiff
path: root/app/controllers/api/smtp_certs_controller.rb
diff options
context:
space:
mode:
authorNavaL <ayoyo@thoughtworks.com>2016-07-14 15:44:07 +0200
committerNavaL <ayoyo@thoughtworks.com>2016-07-14 15:44:07 +0200
commite3c2cb91dfef5c39c608b967e702e9de977d1bd2 (patch)
tree154dc28dd986bd6e0a48e933c5da46994ffaa0cb /app/controllers/api/smtp_certs_controller.rb
parente2f19bcfb6dbce77746c2d61715340525b29a592 (diff)
parentf09e6ec1337962ab279f021a6a6d0ff30479ebe0 (diff)
Merge branch 'develop' of https://github.com/leapcode/leap_web into feature/expose_admin_in_api
Diffstat (limited to 'app/controllers/api/smtp_certs_controller.rb')
-rw-r--r--app/controllers/api/smtp_certs_controller.rb42
1 files changed, 42 insertions, 0 deletions
diff --git a/app/controllers/api/smtp_certs_controller.rb b/app/controllers/api/smtp_certs_controller.rb
new file mode 100644
index 0000000..d9eab7d
--- /dev/null
+++ b/app/controllers/api/smtp_certs_controller.rb
@@ -0,0 +1,42 @@
+class Api::SmtpCertsController < ApiController
+
+ before_filter :require_login
+ before_filter :require_email_account
+ before_filter :fetch_identity
+ before_filter :require_enabled
+
+ # POST /1/smtp_cert
+ def create
+ @cert = ClientCertificate.new common_name: current_user.email_address
+ @identity.register_cert(@cert)
+ @identity.save
+ render text: @cert.to_s, content_type: 'text/plain'
+ end
+
+ protected
+
+ #
+ # Filters
+ #
+
+ def require_email_account
+ access_denied unless service_level.provides? 'email'
+ end
+
+ def require_enabled
+ access_denied unless current_user.enabled?
+ end
+
+ def fetch_identity
+ @identity = current_user.identity
+ end
+
+ #
+ # Helper methods
+ #
+
+ def service_level
+ current_user.effective_service_level
+ end
+
+end