summaryrefslogtreecommitdiffstats
path: root/mattermost.go
diff options
context:
space:
mode:
Diffstat (limited to 'mattermost.go')
-rw-r--r--mattermost.go34
1 files changed, 25 insertions, 9 deletions
diff --git a/mattermost.go b/mattermost.go
index 712faf83b..67428275a 100644
--- a/mattermost.go
+++ b/mattermost.go
@@ -63,6 +63,7 @@ var flagLicenseFile string
var flagEmail string
var flagPassword string
var flagTeamName string
+var flagSiteURL string
var flagConfirmBackup string
var flagRole string
var flagRunCmds bool
@@ -262,6 +263,7 @@ func parseCmds() {
flag.StringVar(&flagEmail, "email", "", "")
flag.StringVar(&flagPassword, "password", "", "")
flag.StringVar(&flagTeamName, "team_name", "", "")
+ flag.StringVar(&flagSiteURL, "site_url", "", "")
flag.StringVar(&flagConfirmBackup, "confirm_backup", "", "")
flag.StringVar(&flagRole, "role", "", "")
@@ -821,14 +823,25 @@ func cmdInviteUser() {
os.Exit(1)
}
+ if len(flagSiteURL) == 0 {
+ fmt.Fprintln(os.Stderr, "flag needs an argument: -site_url")
+ flag.Usage()
+ os.Exit(1)
+ }
+
+ // basic validation of the URL format
+ if _, err := url.ParseRequestURI(flagSiteURL); err != nil {
+ fmt.Fprintln(os.Stderr, "-site_url flag is invalid. It should look like http://example.com")
+ flag.Usage()
+ os.Exit(1)
+ }
+
var team *model.Team
- if len(flagTeamName) > 0 {
- if result := <-api.Srv.Store.Team().GetByName(flagTeamName); result.Err != nil {
- l4g.Error("%v", result.Err)
- flushLogAndExit(1)
- } else {
- team = result.Data.(*model.Team)
- }
+ if result := <-api.Srv.Store.Team().GetByName(flagTeamName); result.Err != nil {
+ l4g.Error("%v", result.Err)
+ flushLogAndExit(1)
+ } else {
+ team = result.Data.(*model.Team)
}
var user *model.User
@@ -841,6 +854,7 @@ func cmdInviteUser() {
invites := []string{flagEmail}
c := getMockContext()
+ c.SetSiteURL(strings.TrimSuffix(flagSiteURL, "/"))
api.InviteMembers(c, team, user, invites)
os.Exit(0)
@@ -1237,6 +1251,8 @@ FLAGS:
-team_name="name" The team name used in other commands
+ -site_url="url" The site URL used in other commands
+
-role="system_admin" The role used in other commands
valid values are
"" - The empty role is basic user
@@ -1256,9 +1272,9 @@ COMMANDS:
platform -create_user -team_name="name" -email="user@example.com" -password="mypassword" -username="user"
-invite_user Invites a user to a team by email. It requires the -team_name
- and -email flags.
+ , -email and -site_url flags.
Example:
- platform -invite_user -team_name="name" -email="user@example.com"
+ platform -invite_user -team_name="name" -email="user@example.com" -site_url="https://mattermost.example.com"
-join_team Joins a user to the team. It required the -email and
-team_name. You may need to logout of your current session