2021-12-12 14:56:13 +01:00
|
|
|
package routes
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/gin-gonic/gin"
|
|
|
|
"github.com/uberswe/golang-base-project/models"
|
|
|
|
"log"
|
|
|
|
"net/http"
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
2022-01-09 14:42:03 +01:00
|
|
|
// Activate handles requests used to activate a users account
|
2021-12-12 14:56:13 +01:00
|
|
|
func (controller Controller) Activate(c *gin.Context) {
|
2022-01-29 10:21:05 +01:00
|
|
|
pd := controller.DefaultPageData(c)
|
|
|
|
activationError := pd.Trans("Please provide a valid activation token")
|
|
|
|
activationSuccess := pd.Trans("Account activated. You may now proceed to login to your account.")
|
|
|
|
pd.Title = pd.Trans("Activate")
|
2021-12-12 14:56:13 +01:00
|
|
|
token := c.Param("token")
|
|
|
|
activationToken := models.Token{
|
|
|
|
Value: token,
|
|
|
|
Type: models.TokenUserActivation,
|
|
|
|
}
|
|
|
|
|
|
|
|
res := controller.db.Where(&activationToken).First(&activationToken)
|
|
|
|
if res.Error != nil {
|
|
|
|
log.Println(res.Error)
|
|
|
|
pd.Messages = append(pd.Messages, Message{
|
|
|
|
Type: "error",
|
2021-12-13 20:33:50 +01:00
|
|
|
Content: activationError,
|
|
|
|
})
|
|
|
|
c.HTML(http.StatusBadRequest, "activate.html", pd)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if activationToken.HasExpired() {
|
|
|
|
pd.Messages = append(pd.Messages, Message{
|
|
|
|
Type: "error",
|
2021-12-12 14:56:13 +01:00
|
|
|
Content: activationError,
|
|
|
|
})
|
|
|
|
c.HTML(http.StatusBadRequest, "activate.html", pd)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
user := models.User{}
|
|
|
|
user.ID = uint(activationToken.ModelID)
|
|
|
|
|
|
|
|
res = controller.db.Where(&user).First(&user)
|
|
|
|
if res.Error != nil {
|
|
|
|
log.Println(res.Error)
|
|
|
|
pd.Messages = append(pd.Messages, Message{
|
|
|
|
Type: "error",
|
|
|
|
Content: activationError,
|
|
|
|
})
|
|
|
|
c.HTML(http.StatusBadRequest, "activate.html", pd)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
now := time.Now()
|
|
|
|
user.ActivatedAt = &now
|
|
|
|
|
|
|
|
res = controller.db.Save(&user)
|
|
|
|
if res.Error != nil {
|
|
|
|
log.Println(res.Error)
|
|
|
|
pd.Messages = append(pd.Messages, Message{
|
|
|
|
Type: "error",
|
|
|
|
Content: activationError,
|
|
|
|
})
|
|
|
|
c.HTML(http.StatusBadRequest, "activate.html", pd)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// We don't need to check for an error here, even if it's not deleted it will not really affect application logic
|
|
|
|
controller.db.Delete(&activationToken)
|
|
|
|
|
|
|
|
pd.Messages = append(pd.Messages, Message{
|
|
|
|
Type: "success",
|
|
|
|
Content: activationSuccess,
|
|
|
|
})
|
|
|
|
c.HTML(http.StatusOK, "activate.html", pd)
|
|
|
|
}
|