summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChristopher Speller <crspeller@gmail.com>2017-01-03 17:12:55 -0500
committerHarrison Healey <harrisonmhealey@gmail.com>2017-01-03 17:12:55 -0500
commita71fc7ff7f9c5a04771b003c1cd195c5bc75336c (patch)
tree720cb3d538a0069f22f3ec9cd8ab0e61fe71bc3a
parent3df8f334379f1977b3122fb78d0c742309e91a3b (diff)
downloadchat-a71fc7ff7f9c5a04771b003c1cd195c5bc75336c.tar.gz
chat-a71fc7ff7f9c5a04771b003c1cd195c5bc75336c.tar.bz2
chat-a71fc7ff7f9c5a04771b003c1cd195c5bc75336c.zip
Removing old createTeamFromSignup api (#4945)
-rw-r--r--api/team.go90
-rw-r--r--api/team_test.go139
-rw-r--r--model/client.go15
-rw-r--r--webapp/client/client.jsx10
-rw-r--r--webapp/tests/client_team.test.jsx34
-rw-r--r--webapp/tests/test_helper.jsx94
6 files changed, 55 insertions, 327 deletions
diff --git a/api/team.go b/api/team.go
index af517d9ba..be64403a2 100644
--- a/api/team.go
+++ b/api/team.go
@@ -25,7 +25,6 @@ func InitTeam() {
l4g.Debug(utils.T("api.team.init.debug"))
BaseRoutes.Teams.Handle("/create", ApiAppHandler(createTeam)).Methods("POST")
- BaseRoutes.Teams.Handle("/create_from_signup", ApiAppHandler(createTeamFromSignup)).Methods("POST")
BaseRoutes.Teams.Handle("/signup", ApiAppHandler(signupTeam)).Methods("POST")
BaseRoutes.Teams.Handle("/all", ApiAppHandler(getAll)).Methods("GET")
BaseRoutes.Teams.Handle("/all_team_listings", ApiUserRequired(GetAllTeamListings)).Methods("GET")
@@ -104,94 +103,6 @@ func signupTeam(c *Context, w http.ResponseWriter, r *http.Request) {
w.Write([]byte(model.MapToJson(m)))
}
-func createTeamFromSignup(c *Context, w http.ResponseWriter, r *http.Request) {
- if !utils.Cfg.EmailSettings.EnableSignUpWithEmail {
- c.Err = model.NewLocAppError("createTeamFromSignup", "api.team.create_team_from_signup.email_disabled.app_error", nil, "")
- c.Err.StatusCode = http.StatusNotImplemented
- return
- }
-
- teamSignup := model.TeamSignupFromJson(r.Body)
-
- if teamSignup == nil {
- c.SetInvalidParam("createTeam", "teamSignup")
- return
- }
-
- props := model.MapFromJson(strings.NewReader(teamSignup.Data))
- teamSignup.Team.Email = props["email"]
- teamSignup.User.Email = props["email"]
-
- teamSignup.Team.PreSave()
-
- if err := teamSignup.Team.IsValid(); err != nil {
- c.Err = err
- return
- }
-
- if !isTeamCreationAllowed(c, teamSignup.Team.Email) {
- return
- }
-
- teamSignup.Team.Id = ""
-
- password := teamSignup.User.Password
- teamSignup.User.PreSave()
- if err := teamSignup.User.IsValid(); err != nil {
- c.Err = err
- return
- }
- teamSignup.User.Id = ""
- teamSignup.User.Password = password
-
- if !model.ComparePassword(teamSignup.Hash, fmt.Sprintf("%v:%v", teamSignup.Data, utils.Cfg.EmailSettings.InviteSalt)) {
- c.Err = model.NewLocAppError("createTeamFromSignup", "api.team.create_team_from_signup.invalid_link.app_error", nil, "")
- return
- }
-
- t, err := strconv.ParseInt(props["time"], 10, 64)
- if err != nil || model.GetMillis()-t > 1000*60*60 { // one hour
- c.Err = model.NewLocAppError("createTeamFromSignup", "api.team.create_team_from_signup.expired_link.app_error", nil, "")
- return
- }
-
- found := FindTeamByName(teamSignup.Team.Name)
-
- if found {
- c.Err = model.NewLocAppError("createTeamFromSignup", "api.team.create_team_from_signup.unavailable.app_error", nil, "d="+teamSignup.Team.Name)
- return
- }
-
- if result := <-Srv.Store.Team().Save(&teamSignup.Team); result.Err != nil {
- c.Err = result.Err
- return
- } else {
- rteam := result.Data.(*model.Team)
-
- if _, err := CreateDefaultChannels(c, rteam.Id); err != nil {
- c.Err = nil
- return
- }
-
- teamSignup.User.EmailVerified = true
-
- ruser, err := CreateUser(&teamSignup.User)
- if err != nil {
- c.Err = err
- return
- }
-
- JoinUserToTeam(rteam, ruser)
-
- InviteMembers(rteam, ruser.GetDisplayName(), teamSignup.Invites)
-
- teamSignup.Team = *rteam
- teamSignup.User = *ruser
-
- w.Write([]byte(teamSignup.ToJson()))
- }
-}
-
func createTeam(c *Context, w http.ResponseWriter, r *http.Request) {
team := model.TeamFromJson(r.Body)
@@ -374,6 +285,7 @@ func isTeamCreationAllowed(c *Context, email string) bool {
c.Err = model.NewLocAppError("isTeamCreationAllowed", "api.team.is_team_creation_allowed.disabled.app_error", nil, "")
return false
}
+ c.Err = nil
if result := <-Srv.Store.User().GetByEmail(email); result.Err == nil {
user := result.Data.(*model.User)
diff --git a/api/team_test.go b/api/team_test.go
index 52b23e1ba..174bbda76 100644
--- a/api/team_test.go
+++ b/api/team_test.go
@@ -4,8 +4,6 @@
package api
import (
- "fmt"
- "strings"
"testing"
"github.com/mattermost/platform/model"
@@ -24,57 +22,6 @@ func TestSignupTeam(t *testing.T) {
}
}
-func TestCreateFromSignupTeam(t *testing.T) {
- th := Setup().InitBasic()
- th.BasicClient.Logout()
- Client := th.BasicClient
-
- props := make(map[string]string)
- props["email"] = strings.ToLower(model.NewId()) + "success+test@simulator.amazonses.com"
- props["name"] = "Test Company name"
- props["time"] = fmt.Sprintf("%v", model.GetMillis())
-
- data := model.MapToJson(props)
- hash := model.HashPassword(fmt.Sprintf("%v:%v", data, utils.Cfg.EmailSettings.InviteSalt))
-
- team := model.Team{DisplayName: "Name", Name: "z-z-" + model.NewId() + "a", Email: "test@nowhere.com", Type: model.TEAM_OPEN}
- user := model.User{Email: props["email"], Nickname: "Corey Hulen", Password: "hello1"}
-
- ts := model.TeamSignup{Team: team, User: user, Invites: []string{"success+test@simulator.amazonses.com"}, Data: data, Hash: hash}
-
- rts, err := Client.CreateTeamFromSignup(&ts)
- if err != nil {
- t.Fatal(err)
- }
-
- if rts.Data.(*model.TeamSignup).Team.DisplayName != team.DisplayName {
- t.Fatal("full name didn't match")
- }
-
- ruser := rts.Data.(*model.TeamSignup).User
- rteam := rts.Data.(*model.TeamSignup).Team
- Client.SetTeamId(rteam.Id)
-
- if result, err := Client.LoginById(ruser.Id, user.Password); err != nil {
- t.Fatal(err)
- } else {
- if result.Data.(*model.User).Email != user.Email {
- t.Fatal("email's didn't match")
- }
- }
-
- c1 := Client.Must(Client.GetChannels("")).Data.(*model.ChannelList)
- if len(*c1) != 2 {
- t.Fatal("default channels not created")
- }
-
- ts.Data = "garbage"
- _, err = Client.CreateTeamFromSignup(&ts)
- if err == nil {
- t.Fatal(err)
- }
-}
-
func TestCreateTeam(t *testing.T) {
th := Setup().InitBasic()
th.BasicClient.Logout()
@@ -120,51 +67,25 @@ func TestCreateTeam(t *testing.T) {
}
func TestAddUserToTeam(t *testing.T) {
- th := Setup().InitBasic()
- th.BasicClient.Logout()
- Client := th.BasicClient
-
- props := make(map[string]string)
- props["email"] = strings.ToLower(model.NewId()) + "success+test@simulator.amazonses.com"
- props["name"] = "Test Company name"
- props["time"] = fmt.Sprintf("%v", model.GetMillis())
-
- data := model.MapToJson(props)
- hash := model.HashPassword(fmt.Sprintf("%v:%v", data, utils.Cfg.EmailSettings.InviteSalt))
-
- team := model.Team{DisplayName: "Name", Name: "z-z-" + model.NewId() + "a", Email: props["email"], Type: model.TEAM_OPEN}
- user := model.User{Email: props["email"], Nickname: "Corey Hulen", Password: "hello1"}
-
- ts := model.TeamSignup{Team: team, User: user, Invites: []string{"success+test@simulator.amazonses.com"}, Data: data, Hash: hash}
+ th := Setup().InitSystemAdmin().InitBasic()
- rts, err := Client.CreateTeamFromSignup(&ts)
- if err != nil {
- t.Fatal(err)
- }
+ user2 := th.CreateUser(th.BasicClient)
- if rts.Data.(*model.TeamSignup).Team.DisplayName != team.DisplayName {
- t.Fatal("full name didn't match")
+ if _, err := th.BasicClient.AddUserToTeam(th.BasicTeam.Id, user2.Id); err == nil {
+ t.Fatal("Should have failed because of permissions")
}
- ruser := rts.Data.(*model.TeamSignup).User
- rteam := rts.Data.(*model.TeamSignup).Team
- Client.SetTeamId(rteam.Id)
-
- if result, err := Client.LoginById(ruser.Id, user.Password); err != nil {
+ th.SystemAdminClient.SetTeamId(th.BasicTeam.Id)
+ if _, err := th.SystemAdminClient.UpdateTeamRoles(th.BasicUser.Id, "team_user team_admin"); err != nil {
t.Fatal(err)
- } else {
- if result.Data.(*model.User).Email != user.Email {
- t.Fatal("email's didn't match")
- }
}
- user2 := th.CreateUser(th.BasicClient)
- if result, err := th.BasicClient.AddUserToTeam("", user2.Id); err != nil {
+ if result, err := th.BasicClient.AddUserToTeam(th.BasicTeam.Id, user2.Id); err != nil {
t.Fatal(err)
} else {
rm := result.Data.(map[string]string)
if rm["user_id"] != user2.Id {
- t.Fatal("email's didn't match")
+ t.Fatal("ids didn't match")
}
}
}
@@ -204,52 +125,16 @@ func TestRemoveUserFromTeam(t *testing.T) {
func TestAddUserToTeamFromInvite(t *testing.T) {
th := Setup().InitBasic()
- th.BasicClient.Logout()
- Client := th.BasicClient
-
- props := make(map[string]string)
- props["email"] = strings.ToLower(model.NewId()) + "success+test@simulator.amazonses.com"
- props["name"] = "Test Company name"
- props["time"] = fmt.Sprintf("%v", model.GetMillis())
-
- data := model.MapToJson(props)
- hash := model.HashPassword(fmt.Sprintf("%v:%v", data, utils.Cfg.EmailSettings.InviteSalt))
-
- team := model.Team{DisplayName: "Name", Name: "z-z-" + model.NewId() + "a", Email: props["email"], Type: model.TEAM_OPEN}
- user := model.User{Email: props["email"], Nickname: "Corey Hulen", Password: "hello1"}
-
- ts := model.TeamSignup{Team: team, User: user, Invites: []string{"success+test@simulator.amazonses.com"}, Data: data, Hash: hash}
-
- rts, err := Client.CreateTeamFromSignup(&ts)
- if err != nil {
- t.Fatal(err)
- }
-
- if rts.Data.(*model.TeamSignup).Team.DisplayName != team.DisplayName {
- t.Fatal("full name didn't match")
- }
-
- ruser := rts.Data.(*model.TeamSignup).User
- rteam := rts.Data.(*model.TeamSignup).Team
- Client.SetTeamId(rteam.Id)
-
- if result, err := Client.LoginById(ruser.Id, user.Password); err != nil {
- t.Fatal(err)
- } else {
- if result.Data.(*model.User).Email != user.Email {
- t.Fatal("email's didn't match")
- }
- }
user2 := th.CreateUser(th.BasicClient)
- Client.Must(Client.Logout())
- Client.Must(Client.Login(user2.Email, user2.Password))
+ th.BasicClient.Must(th.BasicClient.Logout())
+ th.BasicClient.Must(th.BasicClient.Login(user2.Email, user2.Password))
- if result, err := th.BasicClient.AddUserToTeamFromInvite("", "", rteam.InviteId); err != nil {
+ if result, err := th.BasicClient.AddUserToTeamFromInvite("", "", th.BasicTeam.InviteId); err != nil {
t.Fatal(err)
} else {
rtm := result.Data.(*model.Team)
- if rtm.Id != rteam.Id {
+ if rtm.Id != th.BasicTeam.Id {
t.Fatal()
}
}
diff --git a/model/client.go b/model/client.go
index 7248ca951..0c8bdcc5b 100644
--- a/model/client.go
+++ b/model/client.go
@@ -6,7 +6,6 @@ package model
import (
"bytes"
"fmt"
- l4g "github.com/alecthomas/log4go"
"io"
"io/ioutil"
"mime/multipart"
@@ -15,6 +14,8 @@ import (
"strconv"
"strings"
"time"
+
+ l4g "github.com/alecthomas/log4go"
)
const (
@@ -314,18 +315,6 @@ func (c *Client) SignupTeam(email string, displayName string) (*Result, *AppErro
}
}
-// CreateTeamFromSignup creates a team based on the provided TeamSignup struct. On success
-// it returns the TeamSignup struct.
-func (c *Client) CreateTeamFromSignup(teamSignup *TeamSignup) (*Result, *AppError) {
- if r, err := c.DoApiPost("/teams/create_from_signup", teamSignup.ToJson()); err != nil {
- return nil, err
- } else {
- defer closeBody(r)
- return &Result{r.Header.Get(HEADER_REQUEST_ID),
- r.Header.Get(HEADER_ETAG_SERVER), TeamSignupFromJson(r.Body)}, nil
- }
-}
-
// CreateTeam creates a team based on the provided Team struct. On success it returns
// the Team struct with the Id, CreateAt and other server-decided fields populated.
func (c *Client) CreateTeam(team *Team) (*Result, *AppError) {
diff --git a/webapp/client/client.jsx b/webapp/client/client.jsx
index 5ce3e369d..e5fe25fcd 100644
--- a/webapp/client/client.jsx
+++ b/webapp/client/client.jsx
@@ -507,16 +507,6 @@ export default class Client {
// Team Routes Section
- createTeamFromSignup(teamSignup, success, error) {
- request.
- post(`${this.getTeamsRoute()}/create_from_signup`).
- set(this.defaultHeaders).
- type('application/json').
- accept('application/json').
- send(teamSignup).
- end(this.handleResponse.bind(this, 'createTeamFromSignup', success, error));
- }
-
findTeamByName(teamName, success, error) {
request.
post(`${this.getTeamsRoute()}/find_team_by_name`).
diff --git a/webapp/tests/client_team.test.jsx b/webapp/tests/client_team.test.jsx
index 61449fb15..012259d0c 100644
--- a/webapp/tests/client_team.test.jsx
+++ b/webapp/tests/client_team.test.jsx
@@ -38,40 +38,6 @@ describe('Client.Team', function() {
);
});
- it('createTeamFromSignup', function(done) {
- var client = TestHelper.createClient();
- var email = TestHelper.fakeEmail();
-
- client.signupTeam(
- email,
- function(data) {
- var teamSignup = {};
- teamSignup.invites = [];
- teamSignup.data = decodeURIComponent(data.follow_link.split('&h=')[0].replace('/signup_team_complete/?d=', ''));
- teamSignup.hash = decodeURIComponent(data.follow_link.split('&h=')[1]);
-
- teamSignup.user = TestHelper.fakeUser();
- teamSignup.team = TestHelper.fakeTeam();
- teamSignup.team.email = teamSignup.user.email;
-
- client.createTeamFromSignup(
- teamSignup,
- function(data2) {
- assert.equal(data2.team.id.length > 0, true);
- assert.equal(data2.user.id.length > 0, true);
- done();
- },
- function(err) {
- done(new Error(err.message));
- }
- );
- },
- function(err) {
- done(new Error(err.message));
- }
- );
- });
-
it('createTeam', function(done) {
var client = TestHelper.createClient();
var team = TestHelper.fakeTeam();
diff --git a/webapp/tests/test_helper.jsx b/webapp/tests/test_helper.jsx
index 310714e30..79788948b 100644
--- a/webapp/tests/test_helper.jsx
+++ b/webapp/tests/test_helper.jsx
@@ -106,78 +106,64 @@ class TestHelperClass {
initBasic = (callback, connectWS) => {
this.basicc = this.createClient();
+ function throwerror(err) {
+ throw err;
+ }
+
var d1 = jqd.Deferred();
var email = this.fakeEmail();
- var outer = this; // eslint-disable-line consistent-this
-
- this.basicClient().signupTeam(
- email,
- function(rsignUp) {
- var teamSignup = {};
- teamSignup.invites = [];
- teamSignup.data = decodeURIComponent(rsignUp.follow_link.split('&h=')[0].replace('/signup_team_complete/?d=', ''));
- teamSignup.hash = decodeURIComponent(rsignUp.follow_link.split('&h=')[1]);
-
- teamSignup.user = outer.fakeUser();
- teamSignup.team = outer.fakeTeam();
- teamSignup.team.email = email;
- teamSignup.user.email = email;
- var password = teamSignup.user.password;
-
- outer.basicClient().createTeamFromSignup(
- teamSignup,
- function(rteamSignup) {
- outer.basict = rteamSignup.team;
- outer.basicu = rteamSignup.user;
- outer.basicu.password = password;
- outer.basicClient().setTeamId(outer.basict.id);
- outer.basicClient().login(
- rteamSignup.user.email,
- password,
- null,
- function(data, res) {
- if (connectWS) {
- outer.basicwsc = outer.createWebSocketClient(res.header[HEADER_TOKEN]);
- }
- outer.basicClient().useHeaderToken();
- var channel = outer.fakeChannel();
- channel.team_id = outer.basicTeam().id;
- outer.basicClient().createChannel(
+ var user = this.fakeUser();
+ var team = this.fakeTeam();
+ team.email = email;
+ user.email = email;
+ var self = this;
+
+ this.basicClient().createUser(
+ user,
+ function(ruser) {
+ self.basicu = ruser;
+ self.basicu.password = user.password;
+ self.basicClient().login(
+ self.basicu.email,
+ self.basicu.password,
+ null,
+ function(data, res) {
+ if (connectWS) {
+ self.basicwsc = self.createWebSocketClient(res.header[HEADER_TOKEN]);
+ }
+ self.basicClient().useHeaderToken();
+ self.basicClient().createTeam(team,
+ function(rteam) {
+ self.basict = rteam;
+ self.basicClient().setTeamId(rteam.id);
+ var channel = self.fakeChannel();
+ channel.team_id = self.basicTeam().id;
+ self.basicClient().createChannel(
channel,
function(rchannel) {
- outer.basicch = rchannel;
- var post = outer.fakePost();
+ self.basicch = rchannel;
+ var post = self.fakePost();
post.channel_id = rchannel.id;
- outer.basicClient().createPost(
+ self.basicClient().createPost(
post,
function(rpost) {
- outer.basicp = rpost;
+ self.basicp = rpost;
d1.resolve();
},
- function(err) {
- throw err;
- }
+ throwerror
);
},
- function(err) {
- throw err;
- }
+ throwerror
);
},
- function(err) {
- throw err;
- }
+ throwerror
);
},
- function(err) {
- throw err;
- }
+ throwerror
);
},
- function(err) {
- throw err;
- }
+ throwerror
);
jqd.when(d1).done(() => {