summaryrefslogtreecommitdiffstats
path: root/app
diff options
context:
space:
mode:
authorChris <ccbrown112@gmail.com>2017-11-20 11:57:45 -0600
committerHarrison Healey <harrisonmhealey@gmail.com>2017-11-20 12:57:45 -0500
commit5cf45d21559eb4f8c69f57e9d50bcd4d00b9d430 (patch)
tree87e4513f933e956390dced4c14c766adeac1081f /app
parent7eb75093937076df0d7f95ab85b6d10b40383521 (diff)
downloadchat-5cf45d21559eb4f8c69f57e9d50bcd4d00b9d430.tar.gz
chat-5cf45d21559eb4f8c69f57e9d50bcd4d00b9d430.tar.bz2
chat-5cf45d21559eb4f8c69f57e9d50bcd4d00b9d430.zip
refactor template code (#7860)
Diffstat (limited to 'app')
-rw-r--r--app/app.go18
-rw-r--r--app/apptestlib.go1
-rw-r--r--app/email.go54
-rw-r--r--app/email_batching.go6
-rw-r--r--app/notification.go4
-rw-r--r--app/session.go2
-rw-r--r--app/user.go4
7 files changed, 65 insertions, 24 deletions
diff --git a/app/app.go b/app/app.go
index 49ac620e8..55fb43b30 100644
--- a/app/app.go
+++ b/app/app.go
@@ -4,6 +4,7 @@
package app
import (
+ "html/template"
"net/http"
"runtime/debug"
"sync/atomic"
@@ -52,7 +53,8 @@ type App struct {
configFile string
newStore func() store.Store
- sessionCache *utils.Cache
+ htmlTemplateWatcher *utils.HTMLTemplateWatcher
+ sessionCache *utils.Cache
}
var appCount = 0
@@ -94,6 +96,12 @@ func New(options ...Option) *App {
}
}
+ if htmlTemplateWatcher, err := utils.NewHTMLTemplateWatcher("templates"); err != nil {
+ l4g.Error(utils.T("api.api.init.parsing_templates.error"), err)
+ } else {
+ app.htmlTemplateWatcher = htmlTemplateWatcher
+ }
+
app.Srv.Store = app.newStore()
app.initJobs()
@@ -125,6 +133,10 @@ func (a *App) Shutdown() {
a.Srv.Store.Close()
a.Srv = nil
+ if a.htmlTemplateWatcher != nil {
+ a.htmlTemplateWatcher.Close()
+ }
+
l4g.Info(utils.T("api.server.stop_server.stopped.info"))
}
@@ -327,6 +339,10 @@ func (a *App) WaitForGoroutines() {
}
}
+func (a *App) HTMLTemplates() *template.Template {
+ return a.htmlTemplateWatcher.Templates()
+}
+
func (a *App) Handle404(w http.ResponseWriter, r *http.Request) {
err := model.NewAppError("Handle404", "api.context.404.app_error", nil, "", http.StatusNotFound)
err.Translate(utils.T)
diff --git a/app/apptestlib.go b/app/apptestlib.go
index b34749be3..63a064d7f 100644
--- a/app/apptestlib.go
+++ b/app/apptestlib.go
@@ -66,7 +66,6 @@ func setupTestHelper(enterprise bool) *TestHelper {
}
th.App.StartServer()
th.App.UpdateConfig(func(cfg *model.Config) { *cfg.ServiceSettings.ListenAddress = prevListenAddress })
- utils.InitHTML()
utils.EnableDebugLogForTest()
th.App.Srv.Store.MarkSystemRanUnitTests()
diff --git a/app/email.go b/app/email.go
index b676685e2..00a32352a 100644
--- a/app/email.go
+++ b/app/email.go
@@ -10,6 +10,8 @@ import (
"net/http"
l4g "github.com/alecthomas/log4go"
+ "github.com/nicksnyder/go-i18n/i18n"
+
"github.com/mattermost/mattermost-server/model"
"github.com/mattermost/mattermost-server/utils"
)
@@ -21,7 +23,7 @@ func (a *App) SendChangeUsernameEmail(oldUsername, newUsername, email, locale, s
map[string]interface{}{"SiteName": utils.ClientCfg["SiteName"],
"TeamDisplayName": a.Config().TeamSettings.SiteName})
- bodyPage := utils.NewHTMLTemplate("email_change_body", locale)
+ bodyPage := a.NewEmailTemplate("email_change_body", locale)
bodyPage.Props["SiteURL"] = siteURL
bodyPage.Props["Title"] = T("api.templates.username_change_body.title")
bodyPage.Html["Info"] = utils.TranslateAsHtml(T, "api.templates.username_change_body.info",
@@ -43,7 +45,7 @@ func (a *App) SendEmailChangeVerifyEmail(newUserEmail, locale, siteURL, token st
map[string]interface{}{"SiteName": utils.ClientCfg["SiteName"],
"TeamDisplayName": a.Config().TeamSettings.SiteName})
- bodyPage := utils.NewHTMLTemplate("email_change_verify_body", locale)
+ bodyPage := a.NewEmailTemplate("email_change_verify_body", locale)
bodyPage.Props["SiteURL"] = siteURL
bodyPage.Props["Title"] = T("api.templates.email_change_verify_body.title")
bodyPage.Props["Info"] = T("api.templates.email_change_verify_body.info",
@@ -65,7 +67,7 @@ func (a *App) SendEmailChangeEmail(oldEmail, newEmail, locale, siteURL string) *
map[string]interface{}{"SiteName": utils.ClientCfg["SiteName"],
"TeamDisplayName": a.Config().TeamSettings.SiteName})
- bodyPage := utils.NewHTMLTemplate("email_change_body", locale)
+ bodyPage := a.NewEmailTemplate("email_change_body", locale)
bodyPage.Props["SiteURL"] = siteURL
bodyPage.Props["Title"] = T("api.templates.email_change_body.title")
bodyPage.Html["Info"] = utils.TranslateAsHtml(T, "api.templates.email_change_body.info",
@@ -88,7 +90,7 @@ func (a *App) SendVerifyEmail(userEmail, locale, siteURL, token string) *model.A
subject := T("api.templates.verify_subject",
map[string]interface{}{"SiteName": utils.ClientCfg["SiteName"]})
- bodyPage := utils.NewHTMLTemplate("verify_body", locale)
+ bodyPage := a.NewEmailTemplate("verify_body", locale)
bodyPage.Props["SiteURL"] = siteURL
bodyPage.Props["Title"] = T("api.templates.verify_body.title", map[string]interface{}{"ServerURL": url.Host})
bodyPage.Props["Info"] = T("api.templates.verify_body.info")
@@ -108,7 +110,7 @@ func (a *App) SendSignInChangeEmail(email, method, locale, siteURL string) *mode
subject := T("api.templates.signin_change_email.subject",
map[string]interface{}{"SiteName": utils.ClientCfg["SiteName"]})
- bodyPage := utils.NewHTMLTemplate("signin_change_body", locale)
+ bodyPage := a.NewEmailTemplate("signin_change_body", locale)
bodyPage.Props["SiteURL"] = siteURL
bodyPage.Props["Title"] = T("api.templates.signin_change_email.body.title")
bodyPage.Html["Info"] = utils.TranslateAsHtml(T, "api.templates.signin_change_email.body.info",
@@ -130,7 +132,7 @@ func (a *App) SendWelcomeEmail(userId string, email string, verified bool, local
map[string]interface{}{"SiteName": utils.ClientCfg["SiteName"],
"ServerURL": rawUrl.Host})
- bodyPage := utils.NewHTMLTemplate("welcome_body", locale)
+ bodyPage := a.NewEmailTemplate("welcome_body", locale)
bodyPage.Props["SiteURL"] = siteURL
bodyPage.Props["Title"] = T("api.templates.welcome_body.title", map[string]interface{}{"ServerURL": rawUrl.Host})
bodyPage.Props["Info"] = T("api.templates.welcome_body.info")
@@ -167,7 +169,7 @@ func (a *App) SendPasswordChangeEmail(email, method, locale, siteURL string) *mo
map[string]interface{}{"SiteName": utils.ClientCfg["SiteName"],
"TeamDisplayName": a.Config().TeamSettings.SiteName})
- bodyPage := utils.NewHTMLTemplate("password_change_body", locale)
+ bodyPage := a.NewEmailTemplate("password_change_body", locale)
bodyPage.Props["SiteURL"] = siteURL
bodyPage.Props["Title"] = T("api.templates.password_change_body.title")
bodyPage.Html["Info"] = utils.TranslateAsHtml(T, "api.templates.password_change_body.info",
@@ -180,13 +182,13 @@ func (a *App) SendPasswordChangeEmail(email, method, locale, siteURL string) *mo
return nil
}
-func SendUserAccessTokenAddedEmail(email, locale string) *model.AppError {
+func (a *App) SendUserAccessTokenAddedEmail(email, locale string) *model.AppError {
T := utils.GetUserTranslations(locale)
subject := T("api.templates.user_access_token_subject",
map[string]interface{}{"SiteName": utils.ClientCfg["SiteName"]})
- bodyPage := utils.NewHTMLTemplate("password_change_body", locale)
+ bodyPage := a.NewEmailTemplate("password_change_body", locale)
bodyPage.Props["Title"] = T("api.templates.user_access_token_body.title")
bodyPage.Html["Info"] = utils.TranslateAsHtml(T, "api.templates.user_access_token_body.info",
map[string]interface{}{"SiteName": utils.ClientCfg["SiteName"], "SiteURL": utils.GetSiteURL()})
@@ -198,7 +200,7 @@ func SendUserAccessTokenAddedEmail(email, locale string) *model.AppError {
return nil
}
-func SendPasswordResetEmail(email string, token *model.Token, locale, siteURL string) (bool, *model.AppError) {
+func (a *App) SendPasswordResetEmail(email string, token *model.Token, locale, siteURL string) (bool, *model.AppError) {
T := utils.GetUserTranslations(locale)
@@ -207,7 +209,7 @@ func SendPasswordResetEmail(email string, token *model.Token, locale, siteURL st
subject := T("api.templates.reset_subject",
map[string]interface{}{"SiteName": utils.ClientCfg["SiteName"]})
- bodyPage := utils.NewHTMLTemplate("reset_body", locale)
+ bodyPage := a.NewEmailTemplate("reset_body", locale)
bodyPage.Props["SiteURL"] = siteURL
bodyPage.Props["Title"] = T("api.templates.reset_body.title")
bodyPage.Html["Info"] = utils.TranslateAsHtml(T, "api.templates.reset_body.info", nil)
@@ -221,13 +223,13 @@ func SendPasswordResetEmail(email string, token *model.Token, locale, siteURL st
return true, nil
}
-func SendMfaChangeEmail(email string, activated bool, locale, siteURL string) *model.AppError {
+func (a *App) SendMfaChangeEmail(email string, activated bool, locale, siteURL string) *model.AppError {
T := utils.GetUserTranslations(locale)
subject := T("api.templates.mfa_change_subject",
map[string]interface{}{"SiteName": utils.ClientCfg["SiteName"]})
- bodyPage := utils.NewHTMLTemplate("mfa_change_body", locale)
+ bodyPage := a.NewEmailTemplate("mfa_change_body", locale)
bodyPage.Props["SiteURL"] = siteURL
bodyText := ""
@@ -258,7 +260,7 @@ func (a *App) SendInviteEmails(team *model.Team, senderName string, invites []st
"TeamDisplayName": team.DisplayName,
"SiteName": utils.ClientCfg["SiteName"]})
- bodyPage := utils.NewHTMLTemplate("invite_body", model.DEFAULT_LOCALE)
+ bodyPage := a.NewEmailTemplate("invite_body", model.DEFAULT_LOCALE)
bodyPage.Props["SiteURL"] = siteURL
bodyPage.Props["Title"] = utils.T("api.templates.invite_body.title")
bodyPage.Html["Info"] = utils.TranslateAsHtml(utils.T, "api.templates.invite_body.info",
@@ -288,3 +290,27 @@ func (a *App) SendInviteEmails(team *model.Team, senderName string, invites []st
}
}
}
+
+func (a *App) NewEmailTemplate(name, locale string) *utils.HTMLTemplate {
+ t := utils.NewHTMLTemplate(a.HTMLTemplates(), name)
+
+ var localT i18n.TranslateFunc
+ if locale != "" {
+ localT = utils.GetUserTranslations(locale)
+ } else {
+ localT = utils.T
+ }
+
+ t.Props["Footer"] = localT("api.templates.email_footer")
+
+ if *a.Config().EmailSettings.FeedbackOrganization != "" {
+ t.Props["Organization"] = localT("api.templates.email_organization") + *a.Config().EmailSettings.FeedbackOrganization
+ } else {
+ t.Props["Organization"] = ""
+ }
+
+ t.Html["EmailInfo"] = utils.TranslateAsHtml(localT, "api.templates.email_info",
+ map[string]interface{}{"SupportEmail": *a.Config().SupportSettings.SupportEmail, "SiteName": a.Config().TeamSettings.SiteName})
+
+ return t
+}
diff --git a/app/email_batching.go b/app/email_batching.go
index 80e0966d5..bdacc65f5 100644
--- a/app/email_batching.go
+++ b/app/email_batching.go
@@ -236,7 +236,7 @@ func (a *App) sendBatchedEmailNotification(userId string, notifications []*batch
"Day": tm.Day(),
})
- body := utils.NewHTMLTemplate("post_batched_body", user.Locale)
+ body := a.NewEmailTemplate("post_batched_body", user.Locale)
body.Props["SiteURL"] = *a.Config().ServiceSettings.SiteURL
body.Props["Posts"] = template.HTML(contents)
body.Props["BodyText"] = translateFunc("api.email_batching.send_batched_email_notification.body_text", len(notifications))
@@ -250,9 +250,9 @@ func (a *App) renderBatchedPost(notification *batchedNotification, channel *mode
// don't include message contents if email notification contents type is set to generic
var template *utils.HTMLTemplate
if emailNotificationContentsType == model.EMAIL_NOTIFICATION_CONTENTS_FULL {
- template = utils.NewHTMLTemplate("post_batched_post_full", userLocale)
+ template = a.NewEmailTemplate("post_batched_post_full", userLocale)
} else {
- template = utils.NewHTMLTemplate("post_batched_post_generic", userLocale)
+ template = a.NewEmailTemplate("post_batched_post_generic", userLocale)
}
template.Props["Button"] = translateFunc("api.email_batching.render_batched_post.go_to_post")
diff --git a/app/notification.go b/app/notification.go
index 386016250..7708270a4 100644
--- a/app/notification.go
+++ b/app/notification.go
@@ -413,10 +413,10 @@ func (a *App) getNotificationEmailBody(recipient *model.User, post *model.Post,
// only include message contents in notification email if email notification contents type is set to full
var bodyPage *utils.HTMLTemplate
if emailNotificationContentsType == model.EMAIL_NOTIFICATION_CONTENTS_FULL {
- bodyPage = utils.NewHTMLTemplate("post_body_full", recipient.Locale)
+ bodyPage = a.NewEmailTemplate("post_body_full", recipient.Locale)
bodyPage.Props["PostMessage"] = a.GetMessageForNotification(post, translateFunc)
} else {
- bodyPage = utils.NewHTMLTemplate("post_body_generic", recipient.Locale)
+ bodyPage = a.NewEmailTemplate("post_body_generic", recipient.Locale)
}
bodyPage.Props["SiteURL"] = utils.GetSiteURL()
diff --git a/app/session.go b/app/session.go
index 585b191ce..bf5f68fa3 100644
--- a/app/session.go
+++ b/app/session.go
@@ -247,7 +247,7 @@ func (a *App) CreateUserAccessToken(token *model.UserAccessToken) (*model.UserAc
l4g.Error(result.Err.Error())
} else {
user := result.Data.(*model.User)
- if err := SendUserAccessTokenAddedEmail(user.Email, user.Locale); err != nil {
+ if err := a.SendUserAccessTokenAddedEmail(user.Email, user.Locale); err != nil {
l4g.Error(err.Error())
}
}
diff --git a/app/user.go b/app/user.go
index 3bd549abe..a17521d9f 100644
--- a/app/user.go
+++ b/app/user.go
@@ -1065,7 +1065,7 @@ func (a *App) UpdateMfa(activate bool, userId, token string) *model.AppError {
return
}
- if err := SendMfaChangeEmail(user.Email, activate, user.Locale, utils.GetSiteURL()); err != nil {
+ if err := a.SendMfaChangeEmail(user.Email, activate, user.Locale, utils.GetSiteURL()); err != nil {
l4g.Error(err.Error())
}
})
@@ -1160,7 +1160,7 @@ func (a *App) SendPasswordReset(email string, siteURL string) (bool, *model.AppE
return false, err
}
- if _, err := SendPasswordResetEmail(user.Email, token, user.Locale, siteURL); err != nil {
+ if _, err := a.SendPasswordResetEmail(user.Email, token, user.Locale, siteURL); err != nil {
return false, model.NewAppError("SendPasswordReset", "api.user.send_password_reset.send.app_error", nil, "err="+err.Message, http.StatusInternalServerError)
}