summaryrefslogtreecommitdiffstats
path: root/cmd/mattermost/commands/init.go
diff options
context:
space:
mode:
authorMartin Kraft <martinkraft@gmail.com>2018-05-18 08:23:02 -0400
committerMartin Kraft <martinkraft@gmail.com>2018-05-18 08:23:02 -0400
commit78d95a25f799f818de03e9aa58a131407b6c122f (patch)
tree2321e7967a0d9e05d96536e9ae9cff40f98d53f3 /cmd/mattermost/commands/init.go
parent8a0702e0c31014c5f2f8bad8c9e32e9343252469 (diff)
parente591fcf3d8c61c3df7d1d8457ae7b72bfe3abf1b (diff)
downloadchat-78d95a25f799f818de03e9aa58a131407b6c122f.tar.gz
chat-78d95a25f799f818de03e9aa58a131407b6c122f.tar.bz2
chat-78d95a25f799f818de03e9aa58a131407b6c122f.zip
Merge remote-tracking branch 'origin/master' into advanced-permissions-phase-2
Diffstat (limited to 'cmd/mattermost/commands/init.go')
-rw-r--r--cmd/mattermost/commands/init.go46
1 files changed, 46 insertions, 0 deletions
diff --git a/cmd/mattermost/commands/init.go b/cmd/mattermost/commands/init.go
new file mode 100644
index 000000000..aea2b1230
--- /dev/null
+++ b/cmd/mattermost/commands/init.go
@@ -0,0 +1,46 @@
+// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
+// See License.txt for license information.
+
+package commands
+
+import (
+ "github.com/mattermost/mattermost-server/app"
+ "github.com/mattermost/mattermost-server/model"
+ "github.com/mattermost/mattermost-server/utils"
+ "github.com/spf13/cobra"
+)
+
+func InitDBCommandContextCobra(command *cobra.Command) (*app.App, error) {
+ config, err := command.Flags().GetString("config")
+ if err != nil {
+ return nil, err
+ }
+
+ a, err := InitDBCommandContext(config)
+ if err != nil {
+ // Returning an error just prints the usage message, so actually panic
+ panic(err)
+ }
+
+ a.DoAdvancedPermissionsMigration()
+
+ return a, nil
+}
+
+func InitDBCommandContext(configFileLocation string) (*app.App, error) {
+ if err := utils.TranslationsPreInit(); err != nil {
+ return nil, err
+ }
+ model.AppErrorInit(utils.T)
+
+ a, err := app.New(app.ConfigFile(configFileLocation))
+ if err != nil {
+ return nil, err
+ }
+
+ if model.BuildEnterpriseReady == "true" {
+ a.LoadLicense()
+ }
+
+ return a, nil
+}