mirror of
https://github.com/mattermost/mattermost.git
synced 2025-02-25 18:55:24 -06:00
Removing old createTeamFromSignup api (#4945)
This commit is contained in:
committed by
Harrison Healey
parent
3df8f33437
commit
a71fc7ff7f
90
api/team.go
90
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)
|
||||
|
||||
149
api/team_test.go
149
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}
|
||||
|
||||
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")
|
||||
}
|
||||
}
|
||||
th := Setup().InitSystemAdmin().InitBasic()
|
||||
|
||||
user2 := th.CreateUser(th.BasicClient)
|
||||
if result, err := th.BasicClient.AddUserToTeam("", user2.Id); err != nil {
|
||||
|
||||
if _, err := th.BasicClient.AddUserToTeam(th.BasicTeam.Id, user2.Id); err == nil {
|
||||
t.Fatal("Should have failed because of permissions")
|
||||
}
|
||||
|
||||
th.SystemAdminClient.SetTeamId(th.BasicTeam.Id)
|
||||
if _, err := th.SystemAdminClient.UpdateTeamRoles(th.BasicUser.Id, "team_user team_admin"); err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
|
||||
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()
|
||||
}
|
||||
}
|
||||
|
||||
@@ -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) {
|
||||
|
||||
@@ -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`).
|
||||
|
||||
@@ -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();
|
||||
|
||||
@@ -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
|
||||
var user = this.fakeUser();
|
||||
var team = this.fakeTeam();
|
||||
team.email = email;
|
||||
user.email = email;
|
||||
var self = 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(
|
||||
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(() => {
|
||||
|
||||
Reference in New Issue
Block a user