diff options
author | Wim <wim@42.be> | 2016-11-06 00:07:24 +0100 |
---|---|---|
committer | Wim <wim@42.be> | 2016-11-06 00:07:24 +0100 |
commit | 37873acfcd328e7c9eaf2e69148de05b8d00a428 (patch) | |
tree | 9402715a83f140dda8d102aee6697366546a9382 /vendor/github.com/nlopes/slack/team.go | |
parent | 2dbe0eb55729620ffdfdb7e4f10003564d79c7e1 (diff) | |
download | matterbridge-msglm-37873acfcd328e7c9eaf2e69148de05b8d00a428.tar.gz matterbridge-msglm-37873acfcd328e7c9eaf2e69148de05b8d00a428.tar.bz2 matterbridge-msglm-37873acfcd328e7c9eaf2e69148de05b8d00a428.zip |
Update vendor (slack)
Diffstat (limited to 'vendor/github.com/nlopes/slack/team.go')
-rw-r--r-- | vendor/github.com/nlopes/slack/team.go | 73 |
1 files changed, 73 insertions, 0 deletions
diff --git a/vendor/github.com/nlopes/slack/team.go b/vendor/github.com/nlopes/slack/team.go index 41507f68..d4e7899f 100644 --- a/vendor/github.com/nlopes/slack/team.go +++ b/vendor/github.com/nlopes/slack/team.go @@ -3,6 +3,12 @@ package slack import ( "errors" "net/url" + "strconv" +) + +const ( + DEFAULT_LOGINS_COUNT = 100 + DEFAULT_LOGINS_PAGE = 1 ) type TeamResponse struct { @@ -18,6 +24,41 @@ type TeamInfo struct { Icon map[string]interface{} `json:"icon"` } +type LoginResponse struct { + Logins []Login `json:"logins"` + Paging `json:"paging"` + SlackResponse +} + + +type Login struct { + UserID string `json:"user_id"` + Username string `json:"username"` + DateFirst int `json:"date_first"` + DateLast int `json:"date_last"` + Count int `json:"count"` + IP string `json:"ip"` + UserAgent string `json:"user_agent"` + ISP string `json:"isp"` + Country string `json:"country"` + Region string `json:"region"` +} + +// AccessLogParameters contains all the parameters necessary (including the optional ones) for a GetAccessLogs() request +type AccessLogParameters struct { + Count int + Page int +} + +// NewAccessLogParameters provides an instance of AccessLogParameters with all the sane default values set +func NewAccessLogParameters() AccessLogParameters { + return AccessLogParameters{ + Count: DEFAULT_LOGINS_COUNT, + Page: DEFAULT_LOGINS_PAGE, + } +} + + func teamRequest(path string, values url.Values, debug bool) (*TeamResponse, error) { response := &TeamResponse{} err := post(path, values, response, debug) @@ -32,6 +73,19 @@ func teamRequest(path string, values url.Values, debug bool) (*TeamResponse, err return response, nil } +func accessLogsRequest(path string, values url.Values, debug bool) (*LoginResponse, error) { + response := &LoginResponse{} + err := post(path, values, response, debug) + if err != nil { + return nil, err + } + if !response.Ok { + return nil, errors.New(response.Error) + } + return response, nil +} + + // GetTeamInfo gets the Team Information of the user func (api *Client) GetTeamInfo() (*TeamInfo, error) { values := url.Values{ @@ -44,3 +98,22 @@ func (api *Client) GetTeamInfo() (*TeamInfo, error) { } return &response.Team, nil } + +// GetAccessLogs retrieves a page of logins according to the parameters given +func (api *Client) GetAccessLogs(params AccessLogParameters) ([]Login, *Paging, error) { + values := url.Values{ + "token": {api.config.token}, + } + if params.Count != DEFAULT_LOGINS_COUNT { + values.Add("count", strconv.Itoa(params.Count)) + } + if params.Page != DEFAULT_LOGINS_PAGE { + values.Add("page", strconv.Itoa(params.Page)) + } + response, err := accessLogsRequest("team.accessLogs", values, api.debug) + if err != nil { + return nil, nil, err + } + return response.Logins, &response.Paging, nil +} + |