mirror of
				https://github.com/optim-enterprises-bv/databunker.git
				synced 2025-10-31 01:47:57 +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
	 root
					root