Moving Services to seperate namespaces again, auth endpoint working
This commit is contained in:
		@@ -15,3 +15,7 @@ To regenerate docs simply run `bee generate docs`
 | 
				
			|||||||
- company controller, create databases and so on
 | 
					- company controller, create databases and so on
 | 
				
			||||||
- Update not found to json
 | 
					- Update not found to json
 | 
				
			||||||
- load db connections from config
 | 
					- load db connections from config
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## Notes:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- Fixes have been placed into the beego orm for setting the timezone when using NewOrmWithDB()
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,9 +1,13 @@
 | 
				
			|||||||
package controllers
 | 
					package controllers
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import (
 | 
					import (
 | 
				
			||||||
	auth "multitenantStack/services"
 | 
						"multitenantStack/models"
 | 
				
			||||||
 | 
						companydb "multitenantStack/services/companydbservice"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						jwtservice "multitenantStack/services/jwtservice"
 | 
				
			||||||
	"time"
 | 
						"time"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						"github.com/astaxie/beego/orm"
 | 
				
			||||||
	jwt "github.com/dgrijalva/jwt-go"
 | 
						jwt "github.com/dgrijalva/jwt-go"
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -41,23 +45,79 @@ func (c *AuthController) Login() {
 | 
				
			|||||||
		return
 | 
							return
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	//TODO: did the user send us a token? then just validate and tell him he is logged in
 | 
						tokenHeader := c.Ctx.Request.Header.Get("X-JWTtoken")
 | 
				
			||||||
 | 
						if tokenHeader != "" {
 | 
				
			||||||
 | 
							valid, _ := jwtservice.Validate(tokenHeader)
 | 
				
			||||||
 | 
							if valid {
 | 
				
			||||||
 | 
								c.ServeJSONError("You are already logged in")
 | 
				
			||||||
 | 
								return
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	email := c.GetString("email")
 | 
						email := c.GetString("email")
 | 
				
			||||||
	password := c.GetString("password")
 | 
						password := c.GetString("password")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	//TODO: check against main database, get company id and verify password
 | 
						if email == "" || password == "" {
 | 
				
			||||||
	companyName := "company_1"
 | 
							c.ServeJSONError("Email/Password missing")
 | 
				
			||||||
	companyUserID := 5
 | 
							return
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						/*
 | 
				
			||||||
 | 
							systemdb := companydb.GetSystemDatabase()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if systemdb == nil {
 | 
				
			||||||
 | 
								c.ServeJSONError("Error retrieving User")
 | 
				
			||||||
 | 
								return
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							o, err := orm.NewOrmWithDB("postgres", "default", systemdb)
 | 
				
			||||||
 | 
							if err != nil {
 | 
				
			||||||
 | 
								c.ServeJSONError("Error retrieving User")
 | 
				
			||||||
 | 
								return
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						*/
 | 
				
			||||||
 | 
						o := orm.NewOrm()
 | 
				
			||||||
 | 
						o.Using("system") //TODO: Replace this with something cleverer (manager) once implemented
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						userCompanyMapping, err := models.GetUserCompanyMapByEmail(o, email)
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							c.ServeJSONError("Error retrieving User")
 | 
				
			||||||
 | 
							return
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if password != userCompanyMapping.PasswordHash { // TODO: Hash me
 | 
				
			||||||
 | 
							c.ServeJSONError("Email/Password incorrect")
 | 
				
			||||||
 | 
							return
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						companyName := userCompanyMapping.Company
 | 
				
			||||||
 | 
						companyUserID := userCompanyMapping.CompanyUserID
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						db, err := companydb.GetDatabaseWithName(companyName)
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							c.ServeJSONError("Error retrieving Company")
 | 
				
			||||||
 | 
							return
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						o, err = orm.NewOrmWithDB("postgres", "default", db)
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							c.ServeJSONError("Error retrieving CompanyData")
 | 
				
			||||||
 | 
							return
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						companyUser, err := models.GetCompanyUserById(o, int(companyUserID))
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							c.ServeJSONError("Error retrieving Company User")
 | 
				
			||||||
 | 
							return
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	//TODO: if found query the company database to get roleID, and name
 | 
						//TODO: if found query the company database to get roleID, and name
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	name := "Lukas"
 | 
						name := companyUser.Name
 | 
				
			||||||
	roleID := 5
 | 
						roleID := companyUser.Role
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	tokenString := ""
 | 
						tokenString := ""
 | 
				
			||||||
	if email == "admin@admin.at" && password == "my password" {
 | 
						if email == "admin@admin.at" && password == "my password" {
 | 
				
			||||||
		// The jwtClaims are our trusted clientside session
 | 
							// The jwtClaims are our trusted clientside session
 | 
				
			||||||
		tokenString = auth.CreateToken(jwt.MapClaims{
 | 
							tokenString = jwtservice.CreateToken(jwt.MapClaims{
 | 
				
			||||||
			"email":         email,
 | 
								"email":         email,
 | 
				
			||||||
			"companyName":   companyName,
 | 
								"companyName":   companyName,
 | 
				
			||||||
			"companyUserID": companyUserID,
 | 
								"companyUserID": companyUserID,
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -3,7 +3,7 @@ package controllers
 | 
				
			|||||||
import (
 | 
					import (
 | 
				
			||||||
	"database/sql"
 | 
						"database/sql"
 | 
				
			||||||
	"fmt"
 | 
						"fmt"
 | 
				
			||||||
	companydb "multitenantStack/services"
 | 
						companydb "multitenantStack/services/companydbservice"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	"github.com/astaxie/beego/orm"
 | 
						"github.com/astaxie/beego/orm"
 | 
				
			||||||
	jwt "github.com/dgrijalva/jwt-go"
 | 
						jwt "github.com/dgrijalva/jwt-go"
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -34,7 +34,7 @@ func (c *CompanyDataController) URLMapping() {
 | 
				
			|||||||
func (c *CompanyDataController) Post() {
 | 
					func (c *CompanyDataController) Post() {
 | 
				
			||||||
	var v models.CompanyData
 | 
						var v models.CompanyData
 | 
				
			||||||
	if err := json.Unmarshal(c.Ctx.Input.RequestBody, &v); err == nil {
 | 
						if err := json.Unmarshal(c.Ctx.Input.RequestBody, &v); err == nil {
 | 
				
			||||||
		if _, err := models.AddCompanyData(&v); err == nil {
 | 
							if _, err := models.AddCompanyData(o, &v); err == nil {
 | 
				
			||||||
			c.Ctx.Output.SetStatus(201)
 | 
								c.Ctx.Output.SetStatus(201)
 | 
				
			||||||
			c.Data["json"] = v
 | 
								c.Data["json"] = v
 | 
				
			||||||
		} else {
 | 
							} else {
 | 
				
			||||||
@@ -56,7 +56,7 @@ func (c *CompanyDataController) Post() {
 | 
				
			|||||||
func (c *CompanyDataController) GetOne() {
 | 
					func (c *CompanyDataController) GetOne() {
 | 
				
			||||||
	idStr := c.Ctx.Input.Param(":id")
 | 
						idStr := c.Ctx.Input.Param(":id")
 | 
				
			||||||
	id, _ := strconv.Atoi(idStr)
 | 
						id, _ := strconv.Atoi(idStr)
 | 
				
			||||||
	v, err := models.GetCompanyDataById(id)
 | 
						v, err := models.GetCompanyDataById(o, id)
 | 
				
			||||||
	if err != nil {
 | 
						if err != nil {
 | 
				
			||||||
		c.Data["json"] = err.Error()
 | 
							c.Data["json"] = err.Error()
 | 
				
			||||||
	} else {
 | 
						} else {
 | 
				
			||||||
@@ -119,7 +119,7 @@ func (c *CompanyDataController) GetAll() {
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	l, err := models.GetAllCompanyData(query, fields, sortby, order, offset, limit)
 | 
						l, err := models.GetAllCompanyData(o, query, fields, sortby, order, offset, limit)
 | 
				
			||||||
	if err != nil {
 | 
						if err != nil {
 | 
				
			||||||
		c.Data["json"] = err.Error()
 | 
							c.Data["json"] = err.Error()
 | 
				
			||||||
	} else {
 | 
						} else {
 | 
				
			||||||
@@ -141,7 +141,7 @@ func (c *CompanyDataController) Put() {
 | 
				
			|||||||
	id, _ := strconv.Atoi(idStr)
 | 
						id, _ := strconv.Atoi(idStr)
 | 
				
			||||||
	v := models.CompanyData{Id: id}
 | 
						v := models.CompanyData{Id: id}
 | 
				
			||||||
	if err := json.Unmarshal(c.Ctx.Input.RequestBody, &v); err == nil {
 | 
						if err := json.Unmarshal(c.Ctx.Input.RequestBody, &v); err == nil {
 | 
				
			||||||
		if err := models.UpdateCompanyDataById(&v); err == nil {
 | 
							if err := models.UpdateCompanyDataById(o, &v); err == nil {
 | 
				
			||||||
			c.Data["json"] = "OK"
 | 
								c.Data["json"] = "OK"
 | 
				
			||||||
		} else {
 | 
							} else {
 | 
				
			||||||
			c.Data["json"] = err.Error()
 | 
								c.Data["json"] = err.Error()
 | 
				
			||||||
@@ -162,7 +162,7 @@ func (c *CompanyDataController) Put() {
 | 
				
			|||||||
func (c *CompanyDataController) Delete() {
 | 
					func (c *CompanyDataController) Delete() {
 | 
				
			||||||
	idStr := c.Ctx.Input.Param(":id")
 | 
						idStr := c.Ctx.Input.Param(":id")
 | 
				
			||||||
	id, _ := strconv.Atoi(idStr)
 | 
						id, _ := strconv.Atoi(idStr)
 | 
				
			||||||
	if err := models.DeleteCompanyData(id); err == nil {
 | 
						if err := models.DeleteCompanyData(o, id); err == nil {
 | 
				
			||||||
		c.Data["json"] = "OK"
 | 
							c.Data["json"] = "OK"
 | 
				
			||||||
	} else {
 | 
						} else {
 | 
				
			||||||
		c.Data["json"] = err.Error()
 | 
							c.Data["json"] = err.Error()
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -34,7 +34,7 @@ func (c *CompanyUserController) URLMapping() {
 | 
				
			|||||||
func (c *CompanyUserController) Post() {
 | 
					func (c *CompanyUserController) Post() {
 | 
				
			||||||
	var v models.CompanyUser
 | 
						var v models.CompanyUser
 | 
				
			||||||
	if err := json.Unmarshal(c.Ctx.Input.RequestBody, &v); err == nil {
 | 
						if err := json.Unmarshal(c.Ctx.Input.RequestBody, &v); err == nil {
 | 
				
			||||||
		if _, err := models.AddCompanyUser(&v); err == nil {
 | 
							if _, err := models.AddCompanyUser(o, &v); err == nil {
 | 
				
			||||||
			c.Ctx.Output.SetStatus(201)
 | 
								c.Ctx.Output.SetStatus(201)
 | 
				
			||||||
			c.Data["json"] = v
 | 
								c.Data["json"] = v
 | 
				
			||||||
		} else {
 | 
							} else {
 | 
				
			||||||
@@ -56,7 +56,7 @@ func (c *CompanyUserController) Post() {
 | 
				
			|||||||
func (c *CompanyUserController) GetOne() {
 | 
					func (c *CompanyUserController) GetOne() {
 | 
				
			||||||
	idStr := c.Ctx.Input.Param(":id")
 | 
						idStr := c.Ctx.Input.Param(":id")
 | 
				
			||||||
	id, _ := strconv.Atoi(idStr)
 | 
						id, _ := strconv.Atoi(idStr)
 | 
				
			||||||
	v, err := models.GetCompanyUserById(id)
 | 
						v, err := models.GetCompanyUserById(o, id)
 | 
				
			||||||
	if err != nil {
 | 
						if err != nil {
 | 
				
			||||||
		c.Data["json"] = err.Error()
 | 
							c.Data["json"] = err.Error()
 | 
				
			||||||
	} else {
 | 
						} else {
 | 
				
			||||||
@@ -119,7 +119,7 @@ func (c *CompanyUserController) GetAll() {
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	l, err := models.GetAllCompanyUser(query, fields, sortby, order, offset, limit)
 | 
						l, err := models.GetAllCompanyUser(o, query, fields, sortby, order, offset, limit)
 | 
				
			||||||
	if err != nil {
 | 
						if err != nil {
 | 
				
			||||||
		c.Data["json"] = err.Error()
 | 
							c.Data["json"] = err.Error()
 | 
				
			||||||
	} else {
 | 
						} else {
 | 
				
			||||||
@@ -141,7 +141,7 @@ func (c *CompanyUserController) Put() {
 | 
				
			|||||||
	id, _ := strconv.Atoi(idStr)
 | 
						id, _ := strconv.Atoi(idStr)
 | 
				
			||||||
	v := models.CompanyUser{Id: id}
 | 
						v := models.CompanyUser{Id: id}
 | 
				
			||||||
	if err := json.Unmarshal(c.Ctx.Input.RequestBody, &v); err == nil {
 | 
						if err := json.Unmarshal(c.Ctx.Input.RequestBody, &v); err == nil {
 | 
				
			||||||
		if err := models.UpdateCompanyUserById(&v); err == nil {
 | 
							if err := models.UpdateCompanyUserById(o, &v); err == nil {
 | 
				
			||||||
			c.Data["json"] = "OK"
 | 
								c.Data["json"] = "OK"
 | 
				
			||||||
		} else {
 | 
							} else {
 | 
				
			||||||
			c.Data["json"] = err.Error()
 | 
								c.Data["json"] = err.Error()
 | 
				
			||||||
@@ -162,7 +162,7 @@ func (c *CompanyUserController) Put() {
 | 
				
			|||||||
func (c *CompanyUserController) Delete() {
 | 
					func (c *CompanyUserController) Delete() {
 | 
				
			||||||
	idStr := c.Ctx.Input.Param(":id")
 | 
						idStr := c.Ctx.Input.Param(":id")
 | 
				
			||||||
	id, _ := strconv.Atoi(idStr)
 | 
						id, _ := strconv.Atoi(idStr)
 | 
				
			||||||
	if err := models.DeleteCompanyUser(id); err == nil {
 | 
						if err := models.DeleteCompanyUser(o, id); err == nil {
 | 
				
			||||||
		c.Data["json"] = "OK"
 | 
							c.Data["json"] = "OK"
 | 
				
			||||||
	} else {
 | 
						} else {
 | 
				
			||||||
		c.Data["json"] = err.Error()
 | 
							c.Data["json"] = err.Error()
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -34,7 +34,7 @@ func (c *ContactController) URLMapping() {
 | 
				
			|||||||
func (c *ContactController) Post() {
 | 
					func (c *ContactController) Post() {
 | 
				
			||||||
	var v models.Contact
 | 
						var v models.Contact
 | 
				
			||||||
	if err := json.Unmarshal(c.Ctx.Input.RequestBody, &v); err == nil {
 | 
						if err := json.Unmarshal(c.Ctx.Input.RequestBody, &v); err == nil {
 | 
				
			||||||
		if _, err := models.AddContact(&v); err == nil {
 | 
							if _, err := models.AddContact(o, &v); err == nil {
 | 
				
			||||||
			c.Ctx.Output.SetStatus(201)
 | 
								c.Ctx.Output.SetStatus(201)
 | 
				
			||||||
			c.Data["json"] = v
 | 
								c.Data["json"] = v
 | 
				
			||||||
		} else {
 | 
							} else {
 | 
				
			||||||
@@ -119,8 +119,7 @@ func (c *ContactController) GetAll() {
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	ob, _ := orm.NewOrmWithDB("postgres", "default", companyDB)
 | 
						l, err := models.GetAllContact(o, query, fields, sortby, order, offset, limit)
 | 
				
			||||||
	l, err := models.GetAllContact(ob, query, fields, sortby, order, offset, limit)
 | 
					 | 
				
			||||||
	if err != nil {
 | 
						if err != nil {
 | 
				
			||||||
		c.Data["json"] = err.Error()
 | 
							c.Data["json"] = err.Error()
 | 
				
			||||||
	} else {
 | 
						} else {
 | 
				
			||||||
@@ -143,7 +142,7 @@ func (c *ContactController) Put() {
 | 
				
			|||||||
	id, _ := strconv.Atoi(idStr)
 | 
						id, _ := strconv.Atoi(idStr)
 | 
				
			||||||
	v := models.Contact{Id: id}
 | 
						v := models.Contact{Id: id}
 | 
				
			||||||
	if err := json.Unmarshal(c.Ctx.Input.RequestBody, &v); err == nil {
 | 
						if err := json.Unmarshal(c.Ctx.Input.RequestBody, &v); err == nil {
 | 
				
			||||||
		if err := models.UpdateContactById(&v); err == nil {
 | 
							if err := models.UpdateContactById(o, &v); err == nil {
 | 
				
			||||||
			c.Data["json"] = "OK"
 | 
								c.Data["json"] = "OK"
 | 
				
			||||||
		} else {
 | 
							} else {
 | 
				
			||||||
			c.Data["json"] = err.Error()
 | 
								c.Data["json"] = err.Error()
 | 
				
			||||||
@@ -164,7 +163,7 @@ func (c *ContactController) Put() {
 | 
				
			|||||||
func (c *ContactController) Delete() {
 | 
					func (c *ContactController) Delete() {
 | 
				
			||||||
	idStr := c.Ctx.Input.Param(":id")
 | 
						idStr := c.Ctx.Input.Param(":id")
 | 
				
			||||||
	id, _ := strconv.Atoi(idStr)
 | 
						id, _ := strconv.Atoi(idStr)
 | 
				
			||||||
	if err := models.DeleteContact(id); err == nil {
 | 
						if err := models.DeleteContact(o, id); err == nil {
 | 
				
			||||||
		c.Data["json"] = "OK"
 | 
							c.Data["json"] = "OK"
 | 
				
			||||||
	} else {
 | 
						} else {
 | 
				
			||||||
		c.Data["json"] = err.Error()
 | 
							c.Data["json"] = err.Error()
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -34,7 +34,7 @@ func (c *PostController) URLMapping() {
 | 
				
			|||||||
func (c *PostController) Post() {
 | 
					func (c *PostController) Post() {
 | 
				
			||||||
	var v models.Post
 | 
						var v models.Post
 | 
				
			||||||
	if err := json.Unmarshal(c.Ctx.Input.RequestBody, &v); err == nil {
 | 
						if err := json.Unmarshal(c.Ctx.Input.RequestBody, &v); err == nil {
 | 
				
			||||||
		if _, err := models.AddPost(&v); err == nil {
 | 
							if _, err := models.AddPost(o, &v); err == nil {
 | 
				
			||||||
			c.Ctx.Output.SetStatus(201)
 | 
								c.Ctx.Output.SetStatus(201)
 | 
				
			||||||
			c.Data["json"] = v
 | 
								c.Data["json"] = v
 | 
				
			||||||
		} else {
 | 
							} else {
 | 
				
			||||||
@@ -56,7 +56,7 @@ func (c *PostController) Post() {
 | 
				
			|||||||
func (c *PostController) GetOne() {
 | 
					func (c *PostController) GetOne() {
 | 
				
			||||||
	idStr := c.Ctx.Input.Param(":id")
 | 
						idStr := c.Ctx.Input.Param(":id")
 | 
				
			||||||
	id, _ := strconv.Atoi(idStr)
 | 
						id, _ := strconv.Atoi(idStr)
 | 
				
			||||||
	v, err := models.GetPostById(id)
 | 
						v, err := models.GetPostById(o, id)
 | 
				
			||||||
	if err != nil {
 | 
						if err != nil {
 | 
				
			||||||
		c.Data["json"] = err.Error()
 | 
							c.Data["json"] = err.Error()
 | 
				
			||||||
	} else {
 | 
						} else {
 | 
				
			||||||
@@ -119,7 +119,7 @@ func (c *PostController) GetAll() {
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	l, err := models.GetAllPost(query, fields, sortby, order, offset, limit)
 | 
						l, err := models.GetAllPost(o, query, fields, sortby, order, offset, limit)
 | 
				
			||||||
	if err != nil {
 | 
						if err != nil {
 | 
				
			||||||
		c.Data["json"] = err.Error()
 | 
							c.Data["json"] = err.Error()
 | 
				
			||||||
	} else {
 | 
						} else {
 | 
				
			||||||
@@ -141,7 +141,7 @@ func (c *PostController) Put() {
 | 
				
			|||||||
	id, _ := strconv.Atoi(idStr)
 | 
						id, _ := strconv.Atoi(idStr)
 | 
				
			||||||
	v := models.Post{Id: id}
 | 
						v := models.Post{Id: id}
 | 
				
			||||||
	if err := json.Unmarshal(c.Ctx.Input.RequestBody, &v); err == nil {
 | 
						if err := json.Unmarshal(c.Ctx.Input.RequestBody, &v); err == nil {
 | 
				
			||||||
		if err := models.UpdatePostById(&v); err == nil {
 | 
							if err := models.UpdatePostById(o, &v); err == nil {
 | 
				
			||||||
			c.Data["json"] = "OK"
 | 
								c.Data["json"] = "OK"
 | 
				
			||||||
		} else {
 | 
							} else {
 | 
				
			||||||
			c.Data["json"] = err.Error()
 | 
								c.Data["json"] = err.Error()
 | 
				
			||||||
@@ -162,7 +162,7 @@ func (c *PostController) Put() {
 | 
				
			|||||||
func (c *PostController) Delete() {
 | 
					func (c *PostController) Delete() {
 | 
				
			||||||
	idStr := c.Ctx.Input.Param(":id")
 | 
						idStr := c.Ctx.Input.Param(":id")
 | 
				
			||||||
	id, _ := strconv.Atoi(idStr)
 | 
						id, _ := strconv.Atoi(idStr)
 | 
				
			||||||
	if err := models.DeletePost(id); err == nil {
 | 
						if err := models.DeletePost(o, id); err == nil {
 | 
				
			||||||
		c.Data["json"] = "OK"
 | 
							c.Data["json"] = "OK"
 | 
				
			||||||
	} else {
 | 
						} else {
 | 
				
			||||||
		c.Data["json"] = err.Error()
 | 
							c.Data["json"] = err.Error()
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1 +1 @@
 | 
				
			|||||||
{"/Users/LB/go/src/multitenantStack/controllers":1541617005449208486}
 | 
					{"/Users/LB/go/src/multitenantStack/controllers":1541629384273036460}
 | 
				
			||||||
							
								
								
									
										9
									
								
								main.go
									
									
									
									
									
								
							
							
						
						
									
										9
									
								
								main.go
									
									
									
									
									
								
							@@ -2,7 +2,8 @@ package main
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
import (
 | 
					import (
 | 
				
			||||||
	_ "multitenantStack/routers"
 | 
						_ "multitenantStack/routers"
 | 
				
			||||||
	auth "multitenantStack/services"
 | 
						companydb "multitenantStack/services/companydbservice"
 | 
				
			||||||
 | 
						jwt "multitenantStack/services/jwtservice"
 | 
				
			||||||
	"time"
 | 
						"time"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	"github.com/astaxie/beego"
 | 
						"github.com/astaxie/beego"
 | 
				
			||||||
@@ -12,11 +13,15 @@ import (
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
func init() {
 | 
					func init() {
 | 
				
			||||||
	orm.RegisterDataBase("default", "postgres", "host=127.0.0.1 port=5435 user=postgres password=postgre sslmode=disable")
 | 
						orm.RegisterDataBase("default", "postgres", "host=127.0.0.1 port=5435 user=postgres password=postgre sslmode=disable")
 | 
				
			||||||
	auth.InitJWTService()
 | 
						orm.RegisterDataBase("system", "postgres", "host=127.0.0.1 port=5435 user=postgres password=postgre dbname=system sslmode=disable")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						jwt.InitJWTService()
 | 
				
			||||||
 | 
						companydb.InitCompanyService()
 | 
				
			||||||
	orm.DefaultTimeLoc = time.UTC
 | 
						orm.DefaultTimeLoc = time.UTC
 | 
				
			||||||
	if beego.BConfig.RunMode == "dev" {
 | 
						if beego.BConfig.RunMode == "dev" {
 | 
				
			||||||
		beego.BConfig.WebConfig.DirectoryIndex = true
 | 
							beego.BConfig.WebConfig.DirectoryIndex = true
 | 
				
			||||||
		beego.BConfig.WebConfig.StaticDir["/swagger"] = "swagger"
 | 
							beego.BConfig.WebConfig.StaticDir["/swagger"] = "swagger"
 | 
				
			||||||
 | 
							orm.Debug = true
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										159
									
								
								models/userCompanyMap.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										159
									
								
								models/userCompanyMap.go
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,159 @@
 | 
				
			|||||||
 | 
					package models
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import (
 | 
				
			||||||
 | 
						"errors"
 | 
				
			||||||
 | 
						"fmt"
 | 
				
			||||||
 | 
						"reflect"
 | 
				
			||||||
 | 
						"strings"
 | 
				
			||||||
 | 
						"time"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						"github.com/astaxie/beego/orm"
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type UserCompanyMap struct {
 | 
				
			||||||
 | 
						ID            int       `orm:"column(id);pk"`
 | 
				
			||||||
 | 
						Email         string    `orm:"column(email)"`
 | 
				
			||||||
 | 
						PasswordHash  string    `orm:"column(password_hash)"`
 | 
				
			||||||
 | 
						Company       string    `orm:"column(company)"`
 | 
				
			||||||
 | 
						CompanyUserID int16     `orm:"column(company_user_id)"`
 | 
				
			||||||
 | 
						Created       time.Time `orm:"column(created);type(timestamp with time zone);auto_now_add"`
 | 
				
			||||||
 | 
						Modified      time.Time `orm:"column(modified);type(timestamp with time zone);auto_now_add"`
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// TableName returns tablename
 | 
				
			||||||
 | 
					func (t *UserCompanyMap) TableName() string {
 | 
				
			||||||
 | 
						return "user_company_map"
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func init() {
 | 
				
			||||||
 | 
						orm.RegisterModel(new(UserCompanyMap))
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// AddUserCompanyMap insert a new UserCompanyMap into database and returns
 | 
				
			||||||
 | 
					// last inserted Id on success.
 | 
				
			||||||
 | 
					func AddUserCompanyMap(o orm.Ormer, m *UserCompanyMap) (id int64, err error) {
 | 
				
			||||||
 | 
						id, err = o.Insert(m)
 | 
				
			||||||
 | 
						return
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// GetUserCompanyMapByID retrieves UserCompanyMap by Id. Returns error if Id doesn't exist
 | 
				
			||||||
 | 
					func GetUserCompanyMapByID(o orm.Ormer, id int) (v *UserCompanyMap, err error) {
 | 
				
			||||||
 | 
						v = &UserCompanyMap{ID: id}
 | 
				
			||||||
 | 
						if err = o.Read(v); err == nil {
 | 
				
			||||||
 | 
							return v, nil
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						return nil, err
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// GetUserCompanyMapByEmail retrieves UserCompanyMap by email. Returns error if email doesn't exist
 | 
				
			||||||
 | 
					func GetUserCompanyMapByEmail(o orm.Ormer, email string) (v *UserCompanyMap, err error) {
 | 
				
			||||||
 | 
						v = &UserCompanyMap{Email: email}
 | 
				
			||||||
 | 
						if err = o.Read(v, "email"); err == nil {
 | 
				
			||||||
 | 
							return v, nil
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						return nil, err
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// GetAllUserCompanyMap retrieves all UserCompanyMap matches certain condition. Returns empty list if
 | 
				
			||||||
 | 
					// no records exist
 | 
				
			||||||
 | 
					func GetAllUserCompanyMap(o orm.Ormer, query map[string]string, fields []string, sortby []string, order []string,
 | 
				
			||||||
 | 
						offset int64, limit int64) (ml []interface{}, err error) {
 | 
				
			||||||
 | 
						qs := o.QueryTable(new(UserCompanyMap))
 | 
				
			||||||
 | 
						// query k=v
 | 
				
			||||||
 | 
						for k, v := range query {
 | 
				
			||||||
 | 
							// rewrite dot-notation to Object__Attribute
 | 
				
			||||||
 | 
							k = strings.Replace(k, ".", "__", -1)
 | 
				
			||||||
 | 
							if strings.Contains(k, "isnull") {
 | 
				
			||||||
 | 
								qs = qs.Filter(k, (v == "true" || v == "1"))
 | 
				
			||||||
 | 
							} else {
 | 
				
			||||||
 | 
								qs = qs.Filter(k, v)
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						// order by:
 | 
				
			||||||
 | 
						var sortFields []string
 | 
				
			||||||
 | 
						if len(sortby) != 0 {
 | 
				
			||||||
 | 
							if len(sortby) == len(order) {
 | 
				
			||||||
 | 
								// 1) for each sort field, there is an associated order
 | 
				
			||||||
 | 
								for i, v := range sortby {
 | 
				
			||||||
 | 
									orderby := ""
 | 
				
			||||||
 | 
									if order[i] == "desc" {
 | 
				
			||||||
 | 
										orderby = "-" + v
 | 
				
			||||||
 | 
									} else if order[i] == "asc" {
 | 
				
			||||||
 | 
										orderby = v
 | 
				
			||||||
 | 
									} else {
 | 
				
			||||||
 | 
										return nil, errors.New("Error: Invalid order. Must be either [asc|desc]")
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
									sortFields = append(sortFields, orderby)
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
								qs = qs.OrderBy(sortFields...)
 | 
				
			||||||
 | 
							} else if len(sortby) != len(order) && len(order) == 1 {
 | 
				
			||||||
 | 
								// 2) there is exactly one order, all the sorted fields will be sorted by this order
 | 
				
			||||||
 | 
								for _, v := range sortby {
 | 
				
			||||||
 | 
									orderby := ""
 | 
				
			||||||
 | 
									if order[0] == "desc" {
 | 
				
			||||||
 | 
										orderby = "-" + v
 | 
				
			||||||
 | 
									} else if order[0] == "asc" {
 | 
				
			||||||
 | 
										orderby = v
 | 
				
			||||||
 | 
									} else {
 | 
				
			||||||
 | 
										return nil, errors.New("Error: Invalid order. Must be either [asc|desc]")
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
									sortFields = append(sortFields, orderby)
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							} else if len(sortby) != len(order) && len(order) != 1 {
 | 
				
			||||||
 | 
								return nil, errors.New("Error: 'sortby', 'order' sizes mismatch or 'order' size is not 1")
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						} else {
 | 
				
			||||||
 | 
							if len(order) != 0 {
 | 
				
			||||||
 | 
								return nil, errors.New("Error: unused 'order' fields")
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						var l []UserCompanyMap
 | 
				
			||||||
 | 
						qs = qs.OrderBy(sortFields...)
 | 
				
			||||||
 | 
						if _, err = qs.Limit(limit, offset).All(&l, fields...); err == nil {
 | 
				
			||||||
 | 
							if len(fields) == 0 {
 | 
				
			||||||
 | 
								for _, v := range l {
 | 
				
			||||||
 | 
									ml = append(ml, v)
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							} else {
 | 
				
			||||||
 | 
								// trim unused fields
 | 
				
			||||||
 | 
								for _, v := range l {
 | 
				
			||||||
 | 
									m := make(map[string]interface{})
 | 
				
			||||||
 | 
									val := reflect.ValueOf(v)
 | 
				
			||||||
 | 
									for _, fname := range fields {
 | 
				
			||||||
 | 
										m[fname] = val.FieldByName(fname).Interface()
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
									ml = append(ml, m)
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							return ml, nil
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						return nil, err
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// UpdateUserCompanyMapById updates UserCompanyMap by Id and returns error if the record to be updated doesn't exist
 | 
				
			||||||
 | 
					func UpdateUserCompanyMapById(o orm.Ormer, m *UserCompanyMap) (err error) {
 | 
				
			||||||
 | 
						v := UserCompanyMap{ID: m.ID}
 | 
				
			||||||
 | 
						// ascertain id exists in the database
 | 
				
			||||||
 | 
						if err = o.Read(&v); err == nil {
 | 
				
			||||||
 | 
							var num int64
 | 
				
			||||||
 | 
							if num, err = o.Update(m); err == nil {
 | 
				
			||||||
 | 
								fmt.Println("Number of records updated in database:", num)
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						return
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// DeleteUserCompanyMap deletes UserCompanyMap by Id and returns error if
 | 
				
			||||||
 | 
					// the record to be deleted doesn't exist
 | 
				
			||||||
 | 
					func DeleteUserCompanyMap(o orm.Ormer, id int) (err error) {
 | 
				
			||||||
 | 
						v := UserCompanyMap{ID: id}
 | 
				
			||||||
 | 
						// ascertain id exists in the database
 | 
				
			||||||
 | 
						if err = o.Read(&v); err == nil {
 | 
				
			||||||
 | 
							var num int64
 | 
				
			||||||
 | 
							if num, err = o.Delete(&UserCompanyMap{ID: id}); err == nil {
 | 
				
			||||||
 | 
								fmt.Println("Number of records deleted in database:", num)
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						return
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -1,12 +1,12 @@
 | 
				
			|||||||
package services
 | 
					package companydbservice
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import (
 | 
					import (
 | 
				
			||||||
	"database/sql"
 | 
						"database/sql"
 | 
				
			||||||
	"errors"
 | 
						"errors"
 | 
				
			||||||
	"fmt"
 | 
						"fmt"
 | 
				
			||||||
 | 
						"multitenantStack/services/jwtservice"
 | 
				
			||||||
	"os"
 | 
						"os"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	"github.com/astaxie/beego/orm"
 | 
					 | 
				
			||||||
	jwt "github.com/dgrijalva/jwt-go"
 | 
						jwt "github.com/dgrijalva/jwt-go"
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -17,9 +17,7 @@ func InitCompanyService() {
 | 
				
			|||||||
	fmt.Println("Hello from init") // test if init gets called from each orm
 | 
						fmt.Println("Hello from init") // test if init gets called from each orm
 | 
				
			||||||
	dbs := make(map[string]*sql.DB)
 | 
						dbs := make(map[string]*sql.DB)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	orm.RegisterDataBase("default", "postgres", "host=127.0.0.1 port=5435 user=postgres password=postgre sslmode=disable")
 | 
						systemDB, err := sql.Open("postgres", "host=127.0.0.1 port=5435 user=postgres password=postgre dbname=system sslmode=disable")
 | 
				
			||||||
 | 
					 | 
				
			||||||
	systemDB, err := sql.Open("postgres", "host=127.0.0.1 port=5435 user=postgres password=postgre dbname=company5 sslmode=disable")
 | 
					 | 
				
			||||||
	if err != nil {
 | 
						if err != nil {
 | 
				
			||||||
		fmt.Println("Fatal: could not connect to db, exiting... Error:", err)
 | 
							fmt.Println("Fatal: could not connect to db, exiting... Error:", err)
 | 
				
			||||||
		os.Exit(1)
 | 
							os.Exit(1)
 | 
				
			||||||
@@ -28,10 +26,35 @@ func InitCompanyService() {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// GetSystemDatabase returns system db
 | 
				
			||||||
 | 
					func GetSystemDatabase() *sql.DB {
 | 
				
			||||||
 | 
						return dbs["system"]
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// GetDatabase Get orm and user information
 | 
				
			||||||
 | 
					func GetDatabaseWithName(companyName string) (*sql.DB, error) {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if dbs[companyName] != nil {
 | 
				
			||||||
 | 
							fmt.Println("DB Already open")
 | 
				
			||||||
 | 
							return dbs[companyName], nil
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						conStr := fmt.Sprintf("host=127.0.0.1 port=5435 user=postgres password=postgre dbname=%s sslmode=disable", companyName)
 | 
				
			||||||
 | 
						fmt.Println(conStr)
 | 
				
			||||||
 | 
						db, err := sql.Open("postgres", conStr)
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							return nil, err
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// return db with orm or error
 | 
				
			||||||
 | 
						return db, nil
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// TODO: call upper function in this one to reduce code
 | 
				
			||||||
// GetDatabase Get orm and user information
 | 
					// GetDatabase Get orm and user information
 | 
				
			||||||
func GetDatabase(tokenString string) (jwt.MapClaims, *sql.DB, error) {
 | 
					func GetDatabase(tokenString string) (jwt.MapClaims, *sql.DB, error) {
 | 
				
			||||||
	// validate token
 | 
						// validate token
 | 
				
			||||||
	valid, token := Validate(tokenString)
 | 
						valid, token := jwtservice.Validate(tokenString)
 | 
				
			||||||
	if !valid {
 | 
						if !valid {
 | 
				
			||||||
		return nil, nil, errors.New("Token is invalid")
 | 
							return nil, nil, errors.New("Token is invalid")
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
@@ -44,7 +67,7 @@ func GetDatabase(tokenString string) (jwt.MapClaims, *sql.DB, error) {
 | 
				
			|||||||
		return tokenMap, dbs[companyName], nil
 | 
							return tokenMap, dbs[companyName], nil
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	conStr := fmt.Sprintf("host=127.0.0.1 port=5435 user=postgres password=postgre dbname=%s sslmode=disable", tokenMap["companyName"])
 | 
						conStr := fmt.Sprintf("host=127.0.0.1 port=5435 user=postgres password=postgre dbname=%s sslmode=disable", companyName)
 | 
				
			||||||
	fmt.Println(conStr)
 | 
						fmt.Println(conStr)
 | 
				
			||||||
	db, err := sql.Open("postgres", conStr)
 | 
						db, err := sql.Open("postgres", conStr)
 | 
				
			||||||
	if err != nil {
 | 
						if err != nil {
 | 
				
			||||||
@@ -69,15 +92,17 @@ func CreateDatabase(token string) {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
// DeleteDatabase Delete an entire database, this is very very dangerous :-)
 | 
					// DeleteDatabase Delete an entire database, this is very very dangerous :-)
 | 
				
			||||||
func DeleteDatabase(token string) {
 | 
					func DeleteDatabase(token string) {
 | 
				
			||||||
 | 
						//_, db, err := GetDatabase(token)
 | 
				
			||||||
	/*
 | 
						/*
 | 
				
			||||||
		db.Close()
 | 
							remove from map!
 | 
				
			||||||
		fmt.Println("Closed company5")
 | 
								db.Close()
 | 
				
			||||||
		//}
 | 
								fmt.Println("Closed company5")
 | 
				
			||||||
 | 
								//}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		res, err := o.Raw("DROP DATABASE company5;").Exec()
 | 
								res, err := o.Raw("DROP DATABASE company5;").Exec()
 | 
				
			||||||
		if err == nil {
 | 
								if err == nil {
 | 
				
			||||||
			num, _ := res.RowsAffected()
 | 
									num, _ := res.RowsAffected()
 | 
				
			||||||
			fmt.Println("mysql row affected number: ", num)
 | 
									fmt.Println("mysql row affected number: ", num)
 | 
				
			||||||
		}
 | 
								}
 | 
				
			||||||
	*/
 | 
						*/
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@@ -1,4 +1,4 @@
 | 
				
			|||||||
package services
 | 
					package jwtservice
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import (
 | 
					import (
 | 
				
			||||||
	"crypto/rand"
 | 
						"crypto/rand"
 | 
				
			||||||
		Reference in New Issue
	
	Block a user