summaryrefslogtreecommitdiffstats
path: root/plugin
diff options
context:
space:
mode:
authorChris <ccbrown112@gmail.com>2017-09-21 14:00:14 -0500
committerGitHub <noreply@github.com>2017-09-21 14:00:14 -0500
commite525383c52b0c65ad3b3f6cdbee73f56e1e3f67d (patch)
treee46d2dcd0dcad346da8641f4bd62f9134bc80699 /plugin
parent266ff8670244da288aec937320d9eecc7996af35 (diff)
downloadchat-e525383c52b0c65ad3b3f6cdbee73f56e1e3f67d.tar.gz
chat-e525383c52b0c65ad3b3f6cdbee73f56e1e3f67d.tar.bz2
chat-e525383c52b0c65ad3b3f6cdbee73f56e1e3f67d.zip
plugin CRUD operations for users, posts, channels, and teams (#7479)
Diffstat (limited to 'plugin')
-rw-r--r--plugin/api.go58
-rw-r--r--plugin/plugintest/api.go188
-rw-r--r--plugin/rpcplugin/api.go326
-rw-r--r--plugin/rpcplugin/api_test.go122
4 files changed, 669 insertions, 25 deletions
diff --git a/plugin/api.go b/plugin/api.go
index 00361ff40..4df6cb30a 100644
--- a/plugin/api.go
+++ b/plugin/api.go
@@ -9,15 +9,69 @@ type API interface {
// struct that the configuration JSON can be unmarshalled to.
LoadPluginConfiguration(dest interface{}) error
- // GetTeamByName gets a team by its name.
- GetTeamByName(name string) (*model.Team, *model.AppError)
+ // CreateUser creates a user.
+ CreateUser(user *model.User) (*model.User, *model.AppError)
+
+ // DeleteUser deletes a user.
+ DeleteUser(userId string) *model.AppError
+
+ // GetUser gets a user.
+ GetUser(userId string) (*model.User, *model.AppError)
+
+ // GetUserByEmail gets a user by their email address.
+ GetUserByEmail(email string) (*model.User, *model.AppError)
// GetUserByUsername gets a user by their username.
GetUserByUsername(name string) (*model.User, *model.AppError)
+ // UpdateUser updates a user.
+ UpdateUser(user *model.User) (*model.User, *model.AppError)
+
+ // CreateTeam creates a team.
+ CreateTeam(team *model.Team) (*model.Team, *model.AppError)
+
+ // DeleteTeam deletes a team.
+ DeleteTeam(teamId string) *model.AppError
+
+ // GetTeam gets a team.
+ GetTeam(teamId string) (*model.Team, *model.AppError)
+
+ // GetTeamByName gets a team by its name.
+ GetTeamByName(name string) (*model.Team, *model.AppError)
+
+ // UpdateTeam updates a team.
+ UpdateTeam(team *model.Team) (*model.Team, *model.AppError)
+
+ // CreateChannel creates a channel.
+ CreateChannel(channel *model.Channel) (*model.Channel, *model.AppError)
+
+ // DeleteChannel deletes a channel.
+ DeleteChannel(channelId string) *model.AppError
+
+ // GetChannel gets a channel.
+ GetChannel(channelId string) (*model.Channel, *model.AppError)
+
// GetChannelByName gets a channel by its name.
GetChannelByName(name, teamId string) (*model.Channel, *model.AppError)
+ // GetDirectChannel gets a direct message channel.
+ GetDirectChannel(userId1, userId2 string) (*model.Channel, *model.AppError)
+
+ // GetGroupChannel gets a group message channel.
+ GetGroupChannel(userIds []string) (*model.Channel, *model.AppError)
+
+ // UpdateChannel updates a channel.
+ UpdateChannel(channel *model.Channel) (*model.Channel, *model.AppError)
+
// CreatePost creates a post.
CreatePost(post *model.Post) (*model.Post, *model.AppError)
+
+ // DeletePost deletes a post.
+ DeletePost(postId string) *model.AppError
+
+ // GetPost gets a post.
+ GetPost(postId string) (*model.Post, *model.AppError)
+
+ // Update post updates a post.
+ UpdatePost(post *model.Post) (*model.Post, *model.AppError)
}
diff --git a/plugin/plugintest/api.go b/plugin/plugintest/api.go
index 887cdd24e..6c8646c23 100644
--- a/plugin/plugintest/api.go
+++ b/plugin/plugintest/api.go
@@ -17,14 +17,43 @@ func (m *API) LoadPluginConfiguration(dest interface{}) error {
return m.Called(dest).Error(0)
}
-func (m *API) GetTeamByName(name string) (*model.Team, *model.AppError) {
- ret := m.Called(name)
- if f, ok := ret.Get(0).(func(string) (*model.Team, *model.AppError)); ok {
- return f(name)
+func (m *API) CreateUser(user *model.User) (*model.User, *model.AppError) {
+ ret := m.Called(user)
+ if f, ok := ret.Get(0).(func(*model.User) (*model.User, *model.AppError)); ok {
+ return f(user)
}
- team, _ := ret.Get(0).(*model.Team)
+ userOut, _ := ret.Get(0).(*model.User)
err, _ := ret.Get(1).(*model.AppError)
- return team, err
+ return userOut, err
+}
+
+func (m *API) DeleteUser(userId string) *model.AppError {
+ ret := m.Called(userId)
+ if f, ok := ret.Get(0).(func(string) *model.AppError); ok {
+ return f(userId)
+ }
+ err, _ := ret.Get(0).(*model.AppError)
+ return err
+}
+
+func (m *API) GetUser(userId string) (*model.User, *model.AppError) {
+ ret := m.Called(userId)
+ if f, ok := ret.Get(0).(func(string) (*model.User, *model.AppError)); ok {
+ return f(userId)
+ }
+ user, _ := ret.Get(0).(*model.User)
+ err, _ := ret.Get(1).(*model.AppError)
+ return user, err
+}
+
+func (m *API) GetUserByEmail(email string) (*model.User, *model.AppError) {
+ ret := m.Called(email)
+ if f, ok := ret.Get(0).(func(string) (*model.User, *model.AppError)); ok {
+ return f(email)
+ }
+ user, _ := ret.Get(0).(*model.User)
+ err, _ := ret.Get(1).(*model.AppError)
+ return user, err
}
func (m *API) GetUserByUsername(name string) (*model.User, *model.AppError) {
@@ -37,6 +66,94 @@ func (m *API) GetUserByUsername(name string) (*model.User, *model.AppError) {
return user, err
}
+func (m *API) UpdateUser(user *model.User) (*model.User, *model.AppError) {
+ ret := m.Called(user)
+ if f, ok := ret.Get(0).(func(*model.User) (*model.User, *model.AppError)); ok {
+ return f(user)
+ }
+ userOut, _ := ret.Get(0).(*model.User)
+ err, _ := ret.Get(1).(*model.AppError)
+ return userOut, err
+}
+
+func (m *API) CreateTeam(team *model.Team) (*model.Team, *model.AppError) {
+ ret := m.Called(team)
+ if f, ok := ret.Get(0).(func(*model.Team) (*model.Team, *model.AppError)); ok {
+ return f(team)
+ }
+ teamOut, _ := ret.Get(0).(*model.Team)
+ err, _ := ret.Get(1).(*model.AppError)
+ return teamOut, err
+}
+
+func (m *API) DeleteTeam(teamId string) *model.AppError {
+ ret := m.Called(teamId)
+ if f, ok := ret.Get(0).(func(string) *model.AppError); ok {
+ return f(teamId)
+ }
+ err, _ := ret.Get(0).(*model.AppError)
+ return err
+}
+
+func (m *API) GetTeam(teamId string) (*model.Team, *model.AppError) {
+ ret := m.Called(teamId)
+ if f, ok := ret.Get(0).(func(string) (*model.Team, *model.AppError)); ok {
+ return f(teamId)
+ }
+ team, _ := ret.Get(0).(*model.Team)
+ err, _ := ret.Get(1).(*model.AppError)
+ return team, err
+}
+
+func (m *API) GetTeamByName(name string) (*model.Team, *model.AppError) {
+ ret := m.Called(name)
+ if f, ok := ret.Get(0).(func(string) (*model.Team, *model.AppError)); ok {
+ return f(name)
+ }
+ team, _ := ret.Get(0).(*model.Team)
+ err, _ := ret.Get(1).(*model.AppError)
+ return team, err
+}
+
+func (m *API) UpdateTeam(team *model.Team) (*model.Team, *model.AppError) {
+ ret := m.Called(team)
+ if f, ok := ret.Get(0).(func(*model.Team) (*model.Team, *model.AppError)); ok {
+ return f(team)
+ }
+ teamOut, _ := ret.Get(0).(*model.Team)
+ err, _ := ret.Get(1).(*model.AppError)
+ return teamOut, err
+}
+
+func (m *API) CreateChannel(channel *model.Channel) (*model.Channel, *model.AppError) {
+ ret := m.Called(channel)
+ if f, ok := ret.Get(0).(func(*model.Channel) (*model.Channel, *model.AppError)); ok {
+ return f(channel)
+ }
+ channelOut, _ := ret.Get(0).(*model.Channel)
+ err, _ := ret.Get(1).(*model.AppError)
+ return channelOut, err
+}
+
+func (m *API) DeleteChannel(channelId string) *model.AppError {
+ ret := m.Called(channelId)
+ if f, ok := ret.Get(0).(func(string) *model.AppError); ok {
+ return f(channelId)
+ }
+ err, _ := ret.Get(0).(*model.AppError)
+ return err
+}
+
+func (m *API) GetChannel(channelId string) (*model.Channel, *model.AppError) {
+ ret := m.Called(channelId)
+ if f, ok := ret.Get(0).(func(string) (*model.Channel, *model.AppError)); ok {
+ return f(channelId)
+ }
+ channel, _ := ret.Get(0).(*model.Channel)
+ err, _ := ret.Get(1).(*model.AppError)
+ return channel, err
+}
+
func (m *API) GetChannelByName(name, teamId string) (*model.Channel, *model.AppError) {
ret := m.Called(name, teamId)
if f, ok := ret.Get(0).(func(_, _ string) (*model.Channel, *model.AppError)); ok {
@@ -47,6 +164,36 @@ func (m *API) GetChannelByName(name, teamId string) (*model.Channel, *model.AppE
return channel, err
}
+func (m *API) GetDirectChannel(userId1, userId2 string) (*model.Channel, *model.AppError) {
+ ret := m.Called(userId1, userId2)
+ if f, ok := ret.Get(0).(func(_, _ string) (*model.Channel, *model.AppError)); ok {
+ return f(userId1, userId2)
+ }
+ channel, _ := ret.Get(0).(*model.Channel)
+ err, _ := ret.Get(1).(*model.AppError)
+ return channel, err
+}
+
+func (m *API) GetGroupChannel(userIds []string) (*model.Channel, *model.AppError) {
+ ret := m.Called(userIds)
+ if f, ok := ret.Get(0).(func([]string) (*model.Channel, *model.AppError)); ok {
+ return f(userIds)
+ }
+ channel, _ := ret.Get(0).(*model.Channel)
+ err, _ := ret.Get(1).(*model.AppError)
+ return channel, err
+}
+
+func (m *API) UpdateChannel(channel *model.Channel) (*model.Channel, *model.AppError) {
+ ret := m.Called(channel)
+ if f, ok := ret.Get(0).(func(*model.Channel) (*model.Channel, *model.AppError)); ok {
+ return f(channel)
+ }
+ channelOut, _ := ret.Get(0).(*model.Channel)
+ err, _ := ret.Get(1).(*model.AppError)
+ return channelOut, err
+}
+
func (m *API) CreatePost(post *model.Post) (*model.Post, *model.AppError) {
ret := m.Called(post)
if f, ok := ret.Get(0).(func(*model.Post) (*model.Post, *model.AppError)); ok {
@@ -56,3 +203,32 @@ func (m *API) CreatePost(post *model.Post) (*model.Post, *model.AppError) {
err, _ := ret.Get(1).(*model.AppError)
return postOut, err
}
+
+func (m *API) DeletePost(postId string) *model.AppError {
+ ret := m.Called(postId)
+ if f, ok := ret.Get(0).(func(string) *model.AppError); ok {
+ return f(postId)
+ }
+ err, _ := ret.Get(0).(*model.AppError)
+ return err
+}
+
+func (m *API) GetPost(postId string) (*model.Post, *model.AppError) {
+ ret := m.Called(postId)
+ if f, ok := ret.Get(0).(func(string) (*model.Post, *model.AppError)); ok {
+ return f(postId)
+ }
+ post, _ := ret.Get(0).(*model.Post)
+ err, _ := ret.Get(1).(*model.AppError)
+ return post, err
+}
+
+func (m *API) UpdatePost(post *model.Post) (*model.Post, *model.AppError) {
+ ret := m.Called(post)
+ if f, ok := ret.Get(0).(func(*model.Post) (*model.Post, *model.AppError)); ok {
+ return f(post)
+ }
+ postOut, _ := ret.Get(0).(*model.Post)
+ err, _ := ret.Get(1).(*model.AppError)
+ return postOut, err
+}
diff --git a/plugin/rpcplugin/api.go b/plugin/rpcplugin/api.go
index 29ed95258..4195a4f86 100644
--- a/plugin/rpcplugin/api.go
+++ b/plugin/rpcplugin/api.go
@@ -28,11 +28,40 @@ func (api *LocalAPI) LoadPluginConfiguration(args struct{}, reply *[]byte) error
return nil
}
+type APIErrorReply struct {
+ Error *model.AppError
+}
+
type APITeamReply struct {
Team *model.Team
Error *model.AppError
}
+func (api *LocalAPI) CreateTeam(args *model.Team, reply *APITeamReply) error {
+ team, err := api.api.CreateTeam(args)
+ *reply = APITeamReply{
+ Team: team,
+ Error: err,
+ }
+ return nil
+}
+
+func (api *LocalAPI) DeleteTeam(args string, reply *APIErrorReply) error {
+ *reply = APIErrorReply{
+ Error: api.api.DeleteTeam(args),
+ }
+ return nil
+}
+
+func (api *LocalAPI) GetTeam(args string, reply *APITeamReply) error {
+ team, err := api.api.GetTeam(args)
+ *reply = APITeamReply{
+ Team: team,
+ Error: err,
+ }
+ return nil
+}
+
func (api *LocalAPI) GetTeamByName(args string, reply *APITeamReply) error {
team, err := api.api.GetTeamByName(args)
*reply = APITeamReply{
@@ -42,11 +71,54 @@ func (api *LocalAPI) GetTeamByName(args string, reply *APITeamReply) error {
return nil
}
+func (api *LocalAPI) UpdateTeam(args *model.Team, reply *APITeamReply) error {
+ team, err := api.api.UpdateTeam(args)
+ *reply = APITeamReply{
+ Team: team,
+ Error: err,
+ }
+ return nil
+}
+
type APIUserReply struct {
User *model.User
Error *model.AppError
}
+func (api *LocalAPI) CreateUser(args *model.User, reply *APIUserReply) error {
+ user, err := api.api.CreateUser(args)
+ *reply = APIUserReply{
+ User: user,
+ Error: err,
+ }
+ return nil
+}
+
+func (api *LocalAPI) DeleteUser(args string, reply *APIErrorReply) error {
+ *reply = APIErrorReply{
+ Error: api.api.DeleteUser(args),
+ }
+ return nil
+}
+
+func (api *LocalAPI) GetUser(args string, reply *APIUserReply) error {
+ user, err := api.api.GetUser(args)
+ *reply = APIUserReply{
+ User: user,
+ Error: err,
+ }
+ return nil
+}
+
+func (api *LocalAPI) GetUserByEmail(args string, reply *APIUserReply) error {
+ user, err := api.api.GetUserByEmail(args)
+ *reply = APIUserReply{
+ User: user,
+ Error: err,
+ }
+ return nil
+}
+
func (api *LocalAPI) GetUserByUsername(args string, reply *APIUserReply) error {
user, err := api.api.GetUserByUsername(args)
*reply = APIUserReply{
@@ -56,16 +128,59 @@ func (api *LocalAPI) GetUserByUsername(args string, reply *APIUserReply) error {
return nil
}
+func (api *LocalAPI) UpdateUser(args *model.User, reply *APIUserReply) error {
+ user, err := api.api.UpdateUser(args)
+ *reply = APIUserReply{
+ User: user,
+ Error: err,
+ }
+ return nil
+}
+
type APIGetChannelByNameArgs struct {
Name string
TeamId string
}
+type APIGetDirectChannelArgs struct {
+ UserId1 string
+ UserId2 string
+}
+
+type APIGetGroupChannelArgs struct {
+ UserIds []string
+}
+
type APIChannelReply struct {
Channel *model.Channel
Error *model.AppError
}
+func (api *LocalAPI) CreateChannel(args *model.Channel, reply *APIChannelReply) error {
+ channel, err := api.api.CreateChannel(args)
+ *reply = APIChannelReply{
+ Channel: channel,
+ Error: err,
+ }
+ return nil
+}
+
+func (api *LocalAPI) DeleteChannel(args string, reply *APIErrorReply) error {
+ *reply = APIErrorReply{
+ Error: api.api.DeleteChannel(args),
+ }
+ return nil
+}
+
+func (api *LocalAPI) GetChannel(args string, reply *APIChannelReply) error {
+ channel, err := api.api.GetChannel(args)
+ *reply = APIChannelReply{
+ Channel: channel,
+ Error: err,
+ }
+ return nil
+}
+
func (api *LocalAPI) GetChannelByName(args *APIGetChannelByNameArgs, reply *APIChannelReply) error {
channel, err := api.api.GetChannelByName(args.Name, args.TeamId)
*reply = APIChannelReply{
@@ -75,6 +190,33 @@ func (api *LocalAPI) GetChannelByName(args *APIGetChannelByNameArgs, reply *APIC
return nil
}
+func (api *LocalAPI) GetDirectChannel(args *APIGetDirectChannelArgs, reply *APIChannelReply) error {
+ channel, err := api.api.GetDirectChannel(args.UserId1, args.UserId2)
+ *reply = APIChannelReply{
+ Channel: channel,
+ Error: err,
+ }
+ return nil
+}
+
+func (api *LocalAPI) GetGroupChannel(args *APIGetGroupChannelArgs, reply *APIChannelReply) error {
+ channel, err := api.api.GetGroupChannel(args.UserIds)
+ *reply = APIChannelReply{
+ Channel: channel,
+ Error: err,
+ }
+ return nil
+}
+
+func (api *LocalAPI) UpdateChannel(args *model.Channel, reply *APIChannelReply) error {
+ channel, err := api.api.UpdateChannel(args)
+ *reply = APIChannelReply{
+ Channel: channel,
+ Error: err,
+ }
+ return nil
+}
+
type APIPostReply struct {
Post *model.Post
Error *model.AppError
@@ -89,6 +231,31 @@ func (api *LocalAPI) CreatePost(args *model.Post, reply *APIPostReply) error {
return nil
}
+func (api *LocalAPI) DeletePost(args string, reply *APIErrorReply) error {
+ *reply = APIErrorReply{
+ Error: api.api.DeletePost(args),
+ }
+ return nil
+}
+
+func (api *LocalAPI) GetPost(args string, reply *APIPostReply) error {
+ post, err := api.api.GetPost(args)
+ *reply = APIPostReply{
+ Post: post,
+ Error: err,
+ }
+ return nil
+}
+
+func (api *LocalAPI) UpdatePost(args *model.Post, reply *APIPostReply) error {
+ post, err := api.api.UpdatePost(args)
+ *reply = APIPostReply{
+ Post: post,
+ Error: err,
+ }
+ return nil
+}
+
func ServeAPI(api plugin.API, conn io.ReadWriteCloser, muxer *Muxer) {
server := rpc.NewServer()
server.Register(&LocalAPI{
@@ -113,12 +280,36 @@ func (api *RemoteAPI) LoadPluginConfiguration(dest interface{}) error {
return json.Unmarshal(config, dest)
}
-func (api *RemoteAPI) GetTeamByName(name string) (*model.Team, *model.AppError) {
- var reply APITeamReply
- if err := api.client.Call("LocalAPI.GetTeamByName", name, &reply); err != nil {
- return nil, model.NewAppError("RemoteAPI.GetTeamByName", "plugin.rpcplugin.invocation.error", nil, "err="+err.Error(), http.StatusInternalServerError)
+func (api *RemoteAPI) CreateUser(user *model.User) (*model.User, *model.AppError) {
+ var reply APIUserReply
+ if err := api.client.Call("LocalAPI.CreateUser", user, &reply); err != nil {
+ return nil, model.NewAppError("RemoteAPI.CreateUser", "plugin.rpcplugin.invocation.error", nil, "err="+err.Error(), http.StatusInternalServerError)
}
- return reply.Team, reply.Error
+ return reply.User, reply.Error
+}
+
+func (api *RemoteAPI) DeleteUser(userId string) *model.AppError {
+ var reply APIErrorReply
+ if err := api.client.Call("LocalAPI.DeleteUser", userId, &reply); err != nil {
+ return model.NewAppError("RemoteAPI.DeleteUser", "plugin.rpcplugin.invocation.error", nil, "err="+err.Error(), http.StatusInternalServerError)
+ }
+ return reply.Error
+}
+
+func (api *RemoteAPI) GetUser(userId string) (*model.User, *model.AppError) {
+ var reply APIUserReply
+ if err := api.client.Call("LocalAPI.GetUser", userId, &reply); err != nil {
+ return nil, model.NewAppError("RemoteAPI.GetUser", "plugin.rpcplugin.invocation.error", nil, "err="+err.Error(), http.StatusInternalServerError)
+ }
+ return reply.User, reply.Error
+}
+
+func (api *RemoteAPI) GetUserByEmail(email string) (*model.User, *model.AppError) {
+ var reply APIUserReply
+ if err := api.client.Call("LocalAPI.GetUserByEmail", email, &reply); err != nil {
+ return nil, model.NewAppError("RemoteAPI.GetUserByEmail", "plugin.rpcplugin.invocation.error", nil, "err="+err.Error(), http.StatusInternalServerError)
+ }
+ return reply.User, reply.Error
}
func (api *RemoteAPI) GetUserByUsername(name string) (*model.User, *model.AppError) {
@@ -129,6 +320,78 @@ func (api *RemoteAPI) GetUserByUsername(name string) (*model.User, *model.AppErr
return reply.User, reply.Error
}
+func (api *RemoteAPI) UpdateUser(user *model.User) (*model.User, *model.AppError) {
+ var reply APIUserReply
+ if err := api.client.Call("LocalAPI.UpdateUser", user, &reply); err != nil {
+ return nil, model.NewAppError("RemoteAPI.UpdateUser", "plugin.rpcplugin.invocation.error", nil, "err="+err.Error(), http.StatusInternalServerError)
+ }
+ return reply.User, reply.Error
+}
+
+func (api *RemoteAPI) CreateTeam(team *model.Team) (*model.Team, *model.AppError) {
+ var reply APITeamReply
+ if err := api.client.Call("LocalAPI.CreateTeam", team, &reply); err != nil {
+ return nil, model.NewAppError("RemoteAPI.CreateTeam", "plugin.rpcplugin.invocation.error", nil, "err="+err.Error(), http.StatusInternalServerError)
+ }
+ return reply.Team, reply.Error
+}
+
+func (api *RemoteAPI) DeleteTeam(teamId string) *model.AppError {
+ var reply APIErrorReply
+ if err := api.client.Call("LocalAPI.DeleteTeam", teamId, &reply); err != nil {
+ return model.NewAppError("RemoteAPI.DeleteTeam", "plugin.rpcplugin.invocation.error", nil, "err="+err.Error(), http.StatusInternalServerError)
+ }
+ return reply.Error
+}
+
+func (api *RemoteAPI) GetTeam(teamId string) (*model.Team, *model.AppError) {
+ var reply APITeamReply
+ if err := api.client.Call("LocalAPI.GetTeam", teamId, &reply); err != nil {
+ return nil, model.NewAppError("RemoteAPI.GetTeam", "plugin.rpcplugin.invocation.error", nil, "err="+err.Error(), http.StatusInternalServerError)
+ }
+ return reply.Team, reply.Error
+}
+
+func (api *RemoteAPI) GetTeamByName(name string) (*model.Team, *model.AppError) {
+ var reply APITeamReply
+ if err := api.client.Call("LocalAPI.GetTeamByName", name, &reply); err != nil {
+ return nil, model.NewAppError("RemoteAPI.GetTeamByName", "plugin.rpcplugin.invocation.error", nil, "err="+err.Error(), http.StatusInternalServerError)
+ }
+ return reply.Team, reply.Error
+}
+
+func (api *RemoteAPI) UpdateTeam(team *model.Team) (*model.Team, *model.AppError) {
+ var reply APITeamReply
+ if err := api.client.Call("LocalAPI.UpdateTeam", team, &reply); err != nil {
+ return nil, model.NewAppError("RemoteAPI.UpdateTeam", "plugin.rpcplugin.invocation.error", nil, "err="+err.Error(), http.StatusInternalServerError)
+ }
+ return reply.Team, reply.Error
+}
+
+func (api *RemoteAPI) CreateChannel(channel *model.Channel) (*model.Channel, *model.AppError) {
+ var reply APIChannelReply
+ if err := api.client.Call("LocalAPI.CreateChannel", channel, &reply); err != nil {
+ return nil, model.NewAppError("RemoteAPI.CreateChannel", "plugin.rpcplugin.invocation.error", nil, "err="+err.Error(), http.StatusInternalServerError)
+ }
+ return reply.Channel, reply.Error
+}
+
+func (api *RemoteAPI) DeleteChannel(channelId string) *model.AppError {
+ var reply APIErrorReply
+ if err := api.client.Call("LocalAPI.DeleteChannel", channelId, &reply); err != nil {
+ return model.NewAppError("RemoteAPI.DeleteChannel", "plugin.rpcplugin.invocation.error", nil, "err="+err.Error(), http.StatusInternalServerError)
+ }
+ return reply.Error
+}
+
+func (api *RemoteAPI) GetChannel(channelId string) (*model.Channel, *model.AppError) {
+ var reply APIChannelReply
+ if err := api.client.Call("LocalAPI.GetChannel", channelId, &reply); err != nil {
+ return nil, model.NewAppError("RemoteAPI.GetChannel", "plugin.rpcplugin.invocation.error", nil, "err="+err.Error(), http.StatusInternalServerError)
+ }
+ return reply.Channel, reply.Error
+}
+
func (api *RemoteAPI) GetChannelByName(name, teamId string) (*model.Channel, *model.AppError) {
var reply APIChannelReply
if err := api.client.Call("LocalAPI.GetChannelByName", &APIGetChannelByNameArgs{
@@ -140,6 +403,35 @@ func (api *RemoteAPI) GetChannelByName(name, teamId string) (*model.Channel, *mo
return reply.Channel, reply.Error
}
+func (api *RemoteAPI) GetDirectChannel(userId1, userId2 string) (*model.Channel, *model.AppError) {
+ var reply APIChannelReply
+ if err := api.client.Call("LocalAPI.GetDirectChannel", &APIGetDirectChannelArgs{
+ UserId1: userId1,
+ UserId2: userId2,
+ }, &reply); err != nil {
+ return nil, model.NewAppError("RemoteAPI.GetDirectChannel", "plugin.rpcplugin.invocation.error", nil, "err="+err.Error(), http.StatusInternalServerError)
+ }
+ return reply.Channel, reply.Error
+}
+
+func (api *RemoteAPI) GetGroupChannel(userIds []string) (*model.Channel, *model.AppError) {
+ var reply APIChannelReply
+ if err := api.client.Call("LocalAPI.GetGroupChannel", &APIGetGroupChannelArgs{
+ UserIds: userIds,
+ }, &reply); err != nil {
+ return nil, model.NewAppError("RemoteAPI.GetGroupChannel", "plugin.rpcplugin.invocation.error", nil, "err="+err.Error(), http.StatusInternalServerError)
+ }
+ return reply.Channel, reply.Error
+}
+
+func (api *RemoteAPI) UpdateChannel(channel *model.Channel) (*model.Channel, *model.AppError) {
+ var reply APIChannelReply
+ if err := api.client.Call("LocalAPI.UpdateChannel", channel, &reply); err != nil {
+ return nil, model.NewAppError("RemoteAPI.UpdateChannel", "plugin.rpcplugin.invocation.error", nil, "err="+err.Error(), http.StatusInternalServerError)
+ }
+ return reply.Channel, reply.Error
+}
+
func (api *RemoteAPI) CreatePost(post *model.Post) (*model.Post, *model.AppError) {
var reply APIPostReply
if err := api.client.Call("LocalAPI.CreatePost", post, &reply); err != nil {
@@ -148,6 +440,30 @@ func (api *RemoteAPI) CreatePost(post *model.Post) (*model.Post, *model.AppError
return reply.Post, reply.Error
}
+func (api *RemoteAPI) DeletePost(postId string) *model.AppError {
+ var reply APIErrorReply
+ if err := api.client.Call("LocalAPI.DeletePost", postId, &reply); err != nil {
+ return model.NewAppError("RemoteAPI.DeletePost", "plugin.rpcplugin.invocation.error", nil, "err="+err.Error(), http.StatusInternalServerError)
+ }
+ return reply.Error
+}
+
+func (api *RemoteAPI) GetPost(postId string) (*model.Post, *model.AppError) {
+ var reply APIPostReply
+ if err := api.client.Call("LocalAPI.GetPost", postId, &reply); err != nil {
+ return nil, model.NewAppError("RemoteAPI.GetPost", "plugin.rpcplugin.invocation.error", nil, "err="+err.Error(), http.StatusInternalServerError)
+ }
+ return reply.Post, reply.Error
+}
+
+func (api *RemoteAPI) UpdatePost(post *model.Post) (*model.Post, *model.AppError) {
+ var reply APIPostReply
+ if err := api.client.Call("LocalAPI.UpdatePost", post, &reply); err != nil {
+ return nil, model.NewAppError("RemoteAPI.UpdatePost", "plugin.rpcplugin.invocation.error", nil, "err="+err.Error(), http.StatusInternalServerError)
+ }
+ return reply.Post, reply.Error
+}
+
func (h *RemoteAPI) Close() error {
return h.client.Close()
}
diff --git a/plugin/rpcplugin/api_test.go b/plugin/rpcplugin/api_test.go
index dbcb5d279..080f2825f 100644
--- a/plugin/rpcplugin/api_test.go
+++ b/plugin/rpcplugin/api_test.go
@@ -66,40 +66,138 @@ func TestAPI(t *testing.T) {
Message: "hello",
}
- api.On("GetChannelByName", "foo", "theteamid").Return(testChannel, nil)
- api.On("GetTeamByName", "foo").Return(testTeam, nil)
- api.On("GetTeamByName", "notateam").Return(nil, teamNotFoundError)
- api.On("GetUserByUsername", "foo").Return(testUser, nil)
- api.On("CreatePost", mock.AnythingOfType("*model.Post")).Return(func(p *model.Post) (*model.Post, *model.AppError) {
- p.Id = "thepostid"
- return p, nil
- })
-
testAPIRPC(&api, func(remote plugin.API) {
var config Config
assert.NoError(t, remote.LoadPluginConfiguration(&config))
assert.Equal(t, "foo", config.Foo)
assert.Equal(t, "baz", config.Bar.Baz)
- channel, err := remote.GetChannelByName("foo", "theteamid")
+ api.On("CreateChannel", mock.AnythingOfType("*model.Channel")).Return(func(c *model.Channel) (*model.Channel, *model.AppError) {
+ c.Id = "thechannelid"
+ return c, nil
+ }).Once()
+ channel, err := remote.CreateChannel(testChannel)
+ assert.Equal(t, "thechannelid", channel.Id)
+ assert.Nil(t, err)
+
+ api.On("DeleteChannel", "thechannelid").Return(nil).Once()
+ assert.Nil(t, remote.DeleteChannel("thechannelid"))
+
+ api.On("GetChannel", "thechannelid").Return(testChannel, nil).Once()
+ channel, err = remote.GetChannel("thechannelid")
+ assert.Equal(t, testChannel, channel)
+ assert.Nil(t, err)
+
+ api.On("GetChannelByName", "foo", "theteamid").Return(testChannel, nil).Once()
+ channel, err = remote.GetChannelByName("foo", "theteamid")
+ assert.Equal(t, testChannel, channel)
+ assert.Nil(t, err)
+
+ api.On("GetDirectChannel", "user1", "user2").Return(testChannel, nil).Once()
+ channel, err = remote.GetDirectChannel("user1", "user2")
assert.Equal(t, testChannel, channel)
assert.Nil(t, err)
- user, err := remote.GetUserByUsername("foo")
+ api.On("GetGroupChannel", []string{"user1", "user2", "user3"}).Return(testChannel, nil).Once()
+ channel, err = remote.GetGroupChannel([]string{"user1", "user2", "user3"})
+ assert.Equal(t, testChannel, channel)
+ assert.Nil(t, err)
+
+ api.On("UpdateChannel", mock.AnythingOfType("*model.Channel")).Return(func(c *model.Channel) (*model.Channel, *model.AppError) {
+ return c, nil
+ }).Once()
+ channel, err = remote.UpdateChannel(testChannel)
+ assert.Equal(t, testChannel, channel)
+ assert.Nil(t, err)
+
+ api.On("CreateUser", mock.AnythingOfType("*model.User")).Return(func(u *model.User) (*model.User, *model.AppError) {
+ u.Id = "theuserid"
+ return u, nil
+ }).Once()
+ user, err := remote.CreateUser(testUser)
+ assert.Equal(t, "theuserid", user.Id)
+ assert.Nil(t, err)
+
+ api.On("DeleteUser", "theuserid").Return(nil).Once()
+ assert.Nil(t, remote.DeleteUser("theuserid"))
+
+ api.On("GetUser", "theuserid").Return(testUser, nil).Once()
+ user, err = remote.GetUser("theuserid")
assert.Equal(t, testUser, user)
assert.Nil(t, err)
- team, err := remote.GetTeamByName("foo")
+ api.On("GetUserByEmail", "foo@foo").Return(testUser, nil).Once()
+ user, err = remote.GetUserByEmail("foo@foo")
+ assert.Equal(t, testUser, user)
+ assert.Nil(t, err)
+
+ api.On("GetUserByUsername", "foo").Return(testUser, nil).Once()
+ user, err = remote.GetUserByUsername("foo")
+ assert.Equal(t, testUser, user)
+ assert.Nil(t, err)
+
+ api.On("UpdateUser", mock.AnythingOfType("*model.User")).Return(func(u *model.User) (*model.User, *model.AppError) {
+ return u, nil
+ }).Once()
+ user, err = remote.UpdateUser(testUser)
+ assert.Equal(t, testUser, user)
+ assert.Nil(t, err)
+
+ api.On("CreateTeam", mock.AnythingOfType("*model.Team")).Return(func(t *model.Team) (*model.Team, *model.AppError) {
+ t.Id = "theteamid"
+ return t, nil
+ }).Once()
+ team, err := remote.CreateTeam(testTeam)
+ assert.Equal(t, "theteamid", team.Id)
+ assert.Nil(t, err)
+
+ api.On("DeleteTeam", "theteamid").Return(nil).Once()
+ assert.Nil(t, remote.DeleteTeam("theteamid"))
+
+ api.On("GetTeam", "theteamid").Return(testTeam, nil).Once()
+ team, err = remote.GetTeam("theteamid")
assert.Equal(t, testTeam, team)
assert.Nil(t, err)
+ api.On("GetTeamByName", "foo").Return(testTeam, nil).Once()
+ team, err = remote.GetTeamByName("foo")
+ assert.Equal(t, testTeam, team)
+ assert.Nil(t, err)
+
+ api.On("GetTeamByName", "notateam").Return(nil, teamNotFoundError).Once()
team, err = remote.GetTeamByName("notateam")
assert.Nil(t, team)
assert.Equal(t, teamNotFoundError, err)
+ api.On("UpdateTeam", mock.AnythingOfType("*model.Team")).Return(func(t *model.Team) (*model.Team, *model.AppError) {
+ return t, nil
+ }).Once()
+ team, err = remote.UpdateTeam(testTeam)
+ assert.Equal(t, testTeam, team)
+ assert.Nil(t, err)
+
+ api.On("CreatePost", mock.AnythingOfType("*model.Post")).Return(func(p *model.Post) (*model.Post, *model.AppError) {
+ p.Id = "thepostid"
+ return p, nil
+ }).Once()
post, err := remote.CreatePost(testPost)
assert.NotEmpty(t, post.Id)
assert.Equal(t, testPost.Message, post.Message)
assert.Nil(t, err)
+
+ api.On("DeletePost", "thepostid").Return(nil).Once()
+ assert.Nil(t, remote.DeletePost("thepostid"))
+
+ api.On("GetPost", "thepostid").Return(testPost, nil).Once()
+ post, err = remote.GetPost("thepostid")
+ assert.Equal(t, testPost, post)
+ assert.Nil(t, err)
+
+ api.On("UpdatePost", mock.AnythingOfType("*model.Post")).Return(func(p *model.Post) (*model.Post, *model.AppError) {
+ return p, nil
+ }).Once()
+ post, err = remote.UpdatePost(testPost)
+ assert.Equal(t, testPost, post)
+ assert.Nil(t, err)
})
}