fix command comparator and team store

This commit is contained in:
JoramWilander
2015-06-18 12:13:56 -04:00
parent 19d823f29b
commit 4af08121e6
3 changed files with 28 additions and 31 deletions

View File

@@ -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
}

View File

@@ -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;

View File

@@ -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) {
}