mirror of
https://github.com/mattermost/mattermost.git
synced 2025-02-25 18:55:24 -06:00
fix command comparator and team store
This commit is contained in:
@@ -9,6 +9,8 @@ import (
|
||||
"github.com/mattermost/platform/model"
|
||||
"github.com/mattermost/platform/utils"
|
||||
"net/http"
|
||||
"reflect"
|
||||
"runtime"
|
||||
"strconv"
|
||||
"strings"
|
||||
)
|
||||
@@ -19,14 +21,13 @@ var commands = []commandHandler{
|
||||
logoutCommand,
|
||||
joinCommand,
|
||||
loadTestCommand,
|
||||
echoCommand,
|
||||
}
|
||||
|
||||
func InitCommand(r *mux.Router) {
|
||||
l4g.Debug("Initializing command api routes")
|
||||
r.Handle("/command", ApiUserRequired(command)).Methods("POST")
|
||||
|
||||
commands = append(commands, echoCommand)
|
||||
|
||||
hub.Start()
|
||||
}
|
||||
|
||||
@@ -75,10 +76,10 @@ func checkCommand(c *Context, command *model.Command) bool {
|
||||
allowValet = tResult.Data.(*model.Team).AllowValet
|
||||
}
|
||||
|
||||
var ec commandHandler
|
||||
ec = echoCommand
|
||||
ec := runtime.FuncForPC(reflect.ValueOf(echoCommand).Pointer()).Name()
|
||||
|
||||
for _, v := range commands {
|
||||
if !allowValet && &v == &ec {
|
||||
if !allowValet && ec == runtime.FuncForPC(reflect.ValueOf(v).Pointer()).Name() {
|
||||
continue
|
||||
}
|
||||
|
||||
|
||||
@@ -33,6 +33,16 @@ var FeatureTab = React.createClass({
|
||||
this.setState({ allow_valet: val });
|
||||
this.refs.wrapper.getDOMNode().focus();
|
||||
},
|
||||
componentWillReceiveProps: function(newProps) {
|
||||
var team = newProps.team;
|
||||
|
||||
var allow_valet = "false";
|
||||
if (team && team.allow_valet) {
|
||||
allow_valet = "true";
|
||||
}
|
||||
|
||||
this.setState({ allow_valet: allow_valet });
|
||||
},
|
||||
getInitialState: function() {
|
||||
var team = this.props.team;
|
||||
|
||||
|
||||
@@ -22,35 +22,20 @@ var TeamStore = assign({}, EventEmitter.prototype, {
|
||||
this.removeListener(CHANGE_EVENT, callback);
|
||||
},
|
||||
get: function(id) {
|
||||
var current = null;
|
||||
var c = this._getTeams();
|
||||
|
||||
c.some(function(team) {
|
||||
if (team.id == id) {
|
||||
current = team;
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
});
|
||||
|
||||
return current;
|
||||
return c[id];
|
||||
},
|
||||
getByName: function(name) {
|
||||
var current = null;
|
||||
var c = this._getTeams();
|
||||
var t = this._getTeams();
|
||||
|
||||
c.some(function(team) {
|
||||
if (team.name == name) {
|
||||
current = team;
|
||||
return true;
|
||||
}
|
||||
|
||||
return false;
|
||||
|
||||
});
|
||||
|
||||
return current;
|
||||
for (id in t) {
|
||||
if (t[id].name == name) {
|
||||
return t[id];
|
||||
}
|
||||
}
|
||||
|
||||
return null;
|
||||
},
|
||||
getAll: function() {
|
||||
return this._getTeams();
|
||||
@@ -78,12 +63,13 @@ var TeamStore = assign({}, EventEmitter.prototype, {
|
||||
this._storeTeams(teams);
|
||||
},
|
||||
_storeTeams: function(teams) {
|
||||
sessionStorage.setItem("teams", JSON.stringify(teams));
|
||||
sessionStorage.setItem("user_teams", JSON.stringify(teams));
|
||||
},
|
||||
_getTeams: function() {
|
||||
var teams = [];
|
||||
var teams = {};
|
||||
|
||||
try {
|
||||
teams = JSON.parse(sessionStorage.teams);
|
||||
teams = JSON.parse(sessionStorage.user_teams);
|
||||
}
|
||||
catch (err) {
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user