aboutsummaryrefslogtreecommitdiffstats
path: root/routers/api/v1/user/email.go
diff options
context:
space:
mode:
authorUnknwon <u@gogs.io>2015-12-15 22:57:18 -0500
committerUnknwon <u@gogs.io>2015-12-15 22:57:18 -0500
commitb117befc2b4f5ec1e864e2eeaf99355861be01d7 (patch)
treea6f3b95e28e606f89d672e5079070b1cd9119c69 /routers/api/v1/user/email.go
parent7786cb76f3bfc87f92aaae5cc70cbfa974b76868 (diff)
downloadgitea-b117befc2b4f5ec1e864e2eeaf99355861be01d7.tar.gz
gitea-b117befc2b4f5ec1e864e2eeaf99355861be01d7.zip
#1692 add user email APIs
Diffstat (limited to 'routers/api/v1/user/email.go')
-rw-r--r--routers/api/v1/user/email.go78
1 files changed, 78 insertions, 0 deletions
diff --git a/routers/api/v1/user/email.go b/routers/api/v1/user/email.go
new file mode 100644
index 0000000000..449560e782
--- /dev/null
+++ b/routers/api/v1/user/email.go
@@ -0,0 +1,78 @@
+// Copyright 2015 The Gogs Authors. All rights reserved.
+// Use of this source code is governed by a MIT-style
+// license that can be found in the LICENSE file.
+
+package user
+
+import (
+ api "github.com/gogits/go-gogs-client"
+
+ "github.com/gogits/gogs/models"
+ "github.com/gogits/gogs/modules/middleware"
+ "github.com/gogits/gogs/modules/setting"
+ to "github.com/gogits/gogs/routers/api/v1/utils"
+)
+
+func ListEmails(ctx *middleware.Context) {
+ emails, err := models.GetEmailAddresses(ctx.User.Id)
+ if err != nil {
+ ctx.Handle(500, "GetEmailAddresses", err)
+ return
+ }
+ apiEmails := make([]*api.Email, len(emails))
+ for i := range emails {
+ apiEmails[i] = to.ApiEmail(emails[i])
+ }
+ ctx.JSON(200, &apiEmails)
+}
+
+func AddEmail(ctx *middleware.Context, form api.CreateEmailOption) {
+ if len(form.Emails) == 0 {
+ ctx.Status(422)
+ return
+ }
+
+ emails := make([]*models.EmailAddress, len(form.Emails))
+ for i := range form.Emails {
+ emails[i] = &models.EmailAddress{
+ UID: ctx.User.Id,
+ Email: form.Emails[i],
+ IsActivated: !setting.Service.RegisterEmailConfirm,
+ }
+ }
+
+ if err := models.AddEmailAddresses(emails); err != nil {
+ if models.IsErrEmailAlreadyUsed(err) {
+ ctx.APIError(422, "", "Email address has been used: "+err.(models.ErrEmailAlreadyUsed).Email)
+ } else {
+ ctx.APIError(500, "AddEmailAddresses", err)
+ }
+ return
+ }
+
+ apiEmails := make([]*api.Email, len(emails))
+ for i := range emails {
+ apiEmails[i] = to.ApiEmail(emails[i])
+ }
+ ctx.JSON(201, &apiEmails)
+}
+
+func DeleteEmail(ctx *middleware.Context, form api.CreateEmailOption) {
+ if len(form.Emails) == 0 {
+ ctx.Status(204)
+ return
+ }
+
+ emails := make([]*models.EmailAddress, len(form.Emails))
+ for i := range form.Emails {
+ emails[i] = &models.EmailAddress{
+ Email: form.Emails[i],
+ }
+ }
+
+ if err := models.DeleteEmailAddresses(emails); err != nil {
+ ctx.APIError(500, "DeleteEmailAddresses", err)
+ return
+ }
+ ctx.Status(204)
+}