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"))
|
l4g.Debug(utils.T("api.team.init.debug"))
|
||||||
|
|
||||||
BaseRoutes.Teams.Handle("/create", ApiAppHandler(createTeam)).Methods("POST")
|
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("/signup", ApiAppHandler(signupTeam)).Methods("POST")
|
||||||
BaseRoutes.Teams.Handle("/all", ApiAppHandler(getAll)).Methods("GET")
|
BaseRoutes.Teams.Handle("/all", ApiAppHandler(getAll)).Methods("GET")
|
||||||
BaseRoutes.Teams.Handle("/all_team_listings", ApiUserRequired(GetAllTeamListings)).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)))
|
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) {
|
func createTeam(c *Context, w http.ResponseWriter, r *http.Request) {
|
||||||
team := model.TeamFromJson(r.Body)
|
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, "")
|
c.Err = model.NewLocAppError("isTeamCreationAllowed", "api.team.is_team_creation_allowed.disabled.app_error", nil, "")
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
c.Err = nil
|
||||||
|
|
||||||
if result := <-Srv.Store.User().GetByEmail(email); result.Err == nil {
|
if result := <-Srv.Store.User().GetByEmail(email); result.Err == nil {
|
||||||
user := result.Data.(*model.User)
|
user := result.Data.(*model.User)
|
||||||
|
|||||||
149
api/team_test.go
149
api/team_test.go
@@ -4,8 +4,6 @@
|
|||||||
package api
|
package api
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
|
||||||
"strings"
|
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/mattermost/platform/model"
|
"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) {
|
func TestCreateTeam(t *testing.T) {
|
||||||
th := Setup().InitBasic()
|
th := Setup().InitBasic()
|
||||||
th.BasicClient.Logout()
|
th.BasicClient.Logout()
|
||||||
@@ -120,51 +67,25 @@ func TestCreateTeam(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestAddUserToTeam(t *testing.T) {
|
func TestAddUserToTeam(t *testing.T) {
|
||||||
th := Setup().InitBasic()
|
th := Setup().InitSystemAdmin().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)
|
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)
|
t.Fatal(err)
|
||||||
} else {
|
} else {
|
||||||
rm := result.Data.(map[string]string)
|
rm := result.Data.(map[string]string)
|
||||||
if rm["user_id"] != user2.Id {
|
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) {
|
func TestAddUserToTeamFromInvite(t *testing.T) {
|
||||||
th := Setup().InitBasic()
|
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)
|
user2 := th.CreateUser(th.BasicClient)
|
||||||
Client.Must(Client.Logout())
|
th.BasicClient.Must(th.BasicClient.Logout())
|
||||||
Client.Must(Client.Login(user2.Email, user2.Password))
|
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)
|
t.Fatal(err)
|
||||||
} else {
|
} else {
|
||||||
rtm := result.Data.(*model.Team)
|
rtm := result.Data.(*model.Team)
|
||||||
if rtm.Id != rteam.Id {
|
if rtm.Id != th.BasicTeam.Id {
|
||||||
t.Fatal()
|
t.Fatal()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -6,7 +6,6 @@ package model
|
|||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"fmt"
|
"fmt"
|
||||||
l4g "github.com/alecthomas/log4go"
|
|
||||||
"io"
|
"io"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"mime/multipart"
|
"mime/multipart"
|
||||||
@@ -15,6 +14,8 @@ import (
|
|||||||
"strconv"
|
"strconv"
|
||||||
"strings"
|
"strings"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
l4g "github.com/alecthomas/log4go"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
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
|
// 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.
|
// the Team struct with the Id, CreateAt and other server-decided fields populated.
|
||||||
func (c *Client) CreateTeam(team *Team) (*Result, *AppError) {
|
func (c *Client) CreateTeam(team *Team) (*Result, *AppError) {
|
||||||
|
|||||||
@@ -507,16 +507,6 @@ export default class Client {
|
|||||||
|
|
||||||
// Team Routes Section
|
// 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) {
|
findTeamByName(teamName, success, error) {
|
||||||
request.
|
request.
|
||||||
post(`${this.getTeamsRoute()}/find_team_by_name`).
|
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) {
|
it('createTeam', function(done) {
|
||||||
var client = TestHelper.createClient();
|
var client = TestHelper.createClient();
|
||||||
var team = TestHelper.fakeTeam();
|
var team = TestHelper.fakeTeam();
|
||||||
|
|||||||
@@ -106,78 +106,64 @@ class TestHelperClass {
|
|||||||
initBasic = (callback, connectWS) => {
|
initBasic = (callback, connectWS) => {
|
||||||
this.basicc = this.createClient();
|
this.basicc = this.createClient();
|
||||||
|
|
||||||
|
function throwerror(err) {
|
||||||
|
throw err;
|
||||||
|
}
|
||||||
|
|
||||||
var d1 = jqd.Deferred();
|
var d1 = jqd.Deferred();
|
||||||
var email = this.fakeEmail();
|
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(
|
this.basicClient().createUser(
|
||||||
email,
|
user,
|
||||||
function(rsignUp) {
|
function(ruser) {
|
||||||
var teamSignup = {};
|
self.basicu = ruser;
|
||||||
teamSignup.invites = [];
|
self.basicu.password = user.password;
|
||||||
teamSignup.data = decodeURIComponent(rsignUp.follow_link.split('&h=')[0].replace('/signup_team_complete/?d=', ''));
|
self.basicClient().login(
|
||||||
teamSignup.hash = decodeURIComponent(rsignUp.follow_link.split('&h=')[1]);
|
self.basicu.email,
|
||||||
|
self.basicu.password,
|
||||||
teamSignup.user = outer.fakeUser();
|
null,
|
||||||
teamSignup.team = outer.fakeTeam();
|
function(data, res) {
|
||||||
teamSignup.team.email = email;
|
if (connectWS) {
|
||||||
teamSignup.user.email = email;
|
self.basicwsc = self.createWebSocketClient(res.header[HEADER_TOKEN]);
|
||||||
var password = teamSignup.user.password;
|
}
|
||||||
|
self.basicClient().useHeaderToken();
|
||||||
outer.basicClient().createTeamFromSignup(
|
self.basicClient().createTeam(team,
|
||||||
teamSignup,
|
function(rteam) {
|
||||||
function(rteamSignup) {
|
self.basict = rteam;
|
||||||
outer.basict = rteamSignup.team;
|
self.basicClient().setTeamId(rteam.id);
|
||||||
outer.basicu = rteamSignup.user;
|
var channel = self.fakeChannel();
|
||||||
outer.basicu.password = password;
|
channel.team_id = self.basicTeam().id;
|
||||||
outer.basicClient().setTeamId(outer.basict.id);
|
self.basicClient().createChannel(
|
||||||
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(
|
|
||||||
channel,
|
channel,
|
||||||
function(rchannel) {
|
function(rchannel) {
|
||||||
outer.basicch = rchannel;
|
self.basicch = rchannel;
|
||||||
var post = outer.fakePost();
|
var post = self.fakePost();
|
||||||
post.channel_id = rchannel.id;
|
post.channel_id = rchannel.id;
|
||||||
|
|
||||||
outer.basicClient().createPost(
|
self.basicClient().createPost(
|
||||||
post,
|
post,
|
||||||
function(rpost) {
|
function(rpost) {
|
||||||
outer.basicp = rpost;
|
self.basicp = rpost;
|
||||||
d1.resolve();
|
d1.resolve();
|
||||||
},
|
},
|
||||||
function(err) {
|
throwerror
|
||||||
throw err;
|
|
||||||
}
|
|
||||||
);
|
);
|
||||||
},
|
},
|
||||||
function(err) {
|
throwerror
|
||||||
throw err;
|
|
||||||
}
|
|
||||||
);
|
);
|
||||||
},
|
},
|
||||||
function(err) {
|
throwerror
|
||||||
throw err;
|
|
||||||
}
|
|
||||||
);
|
);
|
||||||
},
|
},
|
||||||
function(err) {
|
throwerror
|
||||||
throw err;
|
|
||||||
}
|
|
||||||
);
|
);
|
||||||
},
|
},
|
||||||
function(err) {
|
throwerror
|
||||||
throw err;
|
|
||||||
}
|
|
||||||
);
|
);
|
||||||
|
|
||||||
jqd.when(d1).done(() => {
|
jqd.when(d1).done(() => {
|
||||||
|
|||||||
Reference in New Issue
Block a user