mirror of
https://github.com/optim-enterprises-bv/databunker.git
synced 2025-11-02 02:48:05 +00:00
send admin email on user request
This commit is contained in:
@@ -223,7 +223,7 @@ func (e mainEnv) agreementWithdraw(w http.ResponseWriter, r *http.Request, ps ht
|
|||||||
}
|
}
|
||||||
|
|
||||||
if authResult == "login" && selfService == false {
|
if authResult == "login" && selfService == false {
|
||||||
rtoken, rstatus, err := e.db.saveUserRequest("agreement-withdraw", userTOKEN, "", brief, nil)
|
rtoken, rstatus, err := e.db.saveUserRequest("agreement-withdraw", userTOKEN, "", brief, nil, e.conf)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
returnError(w, r, "internal error", 405, err, event)
|
returnError(w, r, "internal error", 405, err, event)
|
||||||
return
|
return
|
||||||
|
|||||||
@@ -58,6 +58,10 @@ func (e mainEnv) globalUserDelete(userTOKEN string) {
|
|||||||
// not implemented
|
// not implemented
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (dbobj dbcon) GetTenantAdmin(cfg Config) string {
|
||||||
|
return cfg.Generic.AdminEmail
|
||||||
|
}
|
||||||
|
|
||||||
func (e mainEnv) pluginUserDelete(pluginid string, userTOKEN string) {
|
func (e mainEnv) pluginUserDelete(pluginid string, userTOKEN string) {
|
||||||
// not implemented
|
// not implemented
|
||||||
}
|
}
|
||||||
|
|||||||
20
src/email.go
20
src/email.go
@@ -24,3 +24,23 @@ func sendCodeByEmail(code int32, address string, cfg Config) {
|
|||||||
fmt.Println("Mail sent successfully!")
|
fmt.Println("Mail sent successfully!")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func adminEmailAlert(action string, adminEmail string, cfg Config) {
|
||||||
|
if len(adminEmail) == 0 {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
Dest := []string{adminEmail}
|
||||||
|
Subject := "Data Subject request received"
|
||||||
|
bodyMessage := "Request: " + action
|
||||||
|
msg := "From: " + cfg.SMTP.Sender + "\n" +
|
||||||
|
"To: " + strings.Join(Dest, ",") + "\n" +
|
||||||
|
"Subject: " + Subject + "\n" + bodyMessage
|
||||||
|
auth := smtp.PlainAuth("", cfg.SMTP.User, cfg.SMTP.Pass, cfg.SMTP.Server)
|
||||||
|
err := smtp.SendMail(cfg.SMTP.Server+":"+cfg.SMTP.Port,
|
||||||
|
auth, cfg.SMTP.User, Dest, []byte(msg))
|
||||||
|
if err != nil {
|
||||||
|
fmt.Printf("smtp error: %s", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
fmt.Println("Mail sent successfully!")
|
||||||
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -24,7 +24,7 @@ type requestEvent struct {
|
|||||||
Reason string `json:"reason"`
|
Reason string `json:"reason"`
|
||||||
}
|
}
|
||||||
|
|
||||||
func (dbobj dbcon) saveUserRequest(action string, token string, app string, brief string, change []byte) (string, string, error) {
|
func (dbobj dbcon) saveUserRequest(action string, token string, app string, brief string, change []byte, cfg Config) (string, string, error) {
|
||||||
now := int32(time.Now().Unix())
|
now := int32(time.Now().Unix())
|
||||||
bdoc := bson.M{}
|
bdoc := bson.M{}
|
||||||
bdoc["token"] = token
|
bdoc["token"] = token
|
||||||
@@ -53,6 +53,12 @@ func (dbobj dbcon) saveUserRequest(action string, token string, app string, brie
|
|||||||
bdoc["change"] = encodedStr
|
bdoc["change"] = encodedStr
|
||||||
}
|
}
|
||||||
_, err = dbobj.store.CreateRecord(storage.TblName.Requests, &bdoc)
|
_, err = dbobj.store.CreateRecord(storage.TblName.Requests, &bdoc)
|
||||||
|
if err != nil {
|
||||||
|
adminEmail := dbobj.GetTenantAdmin(cfg)
|
||||||
|
if len(adminEmail) > 0 {
|
||||||
|
go adminEmailAlert(action, adminEmail, cfg)
|
||||||
|
}
|
||||||
|
}
|
||||||
return rtoken, "request-created", err
|
return rtoken, "request-created", err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -117,7 +117,7 @@ func (e mainEnv) userappChange(w http.ResponseWriter, r *http.Request, ps httpro
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
rtoken, rstatus, err := e.db.saveUserRequest("change-app-data", userTOKEN, appName, "", jsonData)
|
rtoken, rstatus, err := e.db.saveUserRequest("change-app-data", userTOKEN, appName, "", jsonData, e.conf)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
returnError(w, r, "internal error", 405, err, event)
|
returnError(w, r, "internal error", 405, err, event)
|
||||||
return
|
return
|
||||||
|
|||||||
@@ -202,7 +202,7 @@ func (e mainEnv) userChange(w http.ResponseWriter, r *http.Request, ps httproute
|
|||||||
if authResult == "login" {
|
if authResult == "login" {
|
||||||
event.Title = "user change-profile request"
|
event.Title = "user change-profile request"
|
||||||
if e.conf.SelfService.UserRecordChange == false || adminRecordChanged == true {
|
if e.conf.SelfService.UserRecordChange == false || adminRecordChanged == true {
|
||||||
rtoken, rstatus, err := e.db.saveUserRequest("change-profile", userTOKEN, "", "", parsedData.jsonData)
|
rtoken, rstatus, err := e.db.saveUserRequest("change-profile", userTOKEN, "", "", parsedData.jsonData, e.conf)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
returnError(w, r, "internal error", 405, err, event)
|
returnError(w, r, "internal error", 405, err, event)
|
||||||
return
|
return
|
||||||
@@ -266,7 +266,7 @@ func (e mainEnv) userDelete(w http.ResponseWriter, r *http.Request, ps httproute
|
|||||||
if authResult == "login" {
|
if authResult == "login" {
|
||||||
event.Title = "user forget-me request"
|
event.Title = "user forget-me request"
|
||||||
if e.conf.SelfService.ForgetMe == false {
|
if e.conf.SelfService.ForgetMe == false {
|
||||||
rtoken, rstatus, err := e.db.saveUserRequest("forget-me", userTOKEN, "", "", nil)
|
rtoken, rstatus, err := e.db.saveUserRequest("forget-me", userTOKEN, "", "", nil, e.conf)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
returnError(w, r, "internal error", 405, err, event)
|
returnError(w, r, "internal error", 405, err, event)
|
||||||
return
|
return
|
||||||
|
|||||||
Reference in New Issue
Block a user