2018-12-01 10:55:35 -08:00
|
|
|
package slack
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"net/url"
|
|
|
|
)
|
|
|
|
|
|
|
|
// AuthRevokeResponse contains our Auth response from the auth.revoke endpoint
|
|
|
|
type AuthRevokeResponse struct {
|
|
|
|
SlackResponse // Contains the "ok", and "Error", if any
|
|
|
|
Revoked bool `json:"revoked,omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// authRequest sends the actual request, and unmarshals the response
|
2019-09-07 13:46:58 -07:00
|
|
|
func (api *Client) authRequest(ctx context.Context, path string, values url.Values) (*AuthRevokeResponse, error) {
|
2018-12-01 10:55:35 -08:00
|
|
|
response := &AuthRevokeResponse{}
|
2019-09-07 13:46:58 -07:00
|
|
|
err := api.postMethod(ctx, path, values, response)
|
2018-12-01 10:55:35 -08:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return response, response.Err()
|
|
|
|
}
|
|
|
|
|
|
|
|
// SendAuthRevoke will send a revocation for our token
|
|
|
|
func (api *Client) SendAuthRevoke(token string) (*AuthRevokeResponse, error) {
|
|
|
|
return api.SendAuthRevokeContext(context.Background(), token)
|
|
|
|
}
|
|
|
|
|
2020-03-28 15:50:47 -07:00
|
|
|
// SendAuthRevokeContext will send a revocation request for our token to api.revoke with context
|
2018-12-01 10:55:35 -08:00
|
|
|
func (api *Client) SendAuthRevokeContext(ctx context.Context, token string) (*AuthRevokeResponse, error) {
|
|
|
|
if token == "" {
|
|
|
|
token = api.token
|
|
|
|
}
|
|
|
|
values := url.Values{
|
|
|
|
"token": {token},
|
|
|
|
}
|
|
|
|
|
2019-09-07 13:46:58 -07:00
|
|
|
return api.authRequest(ctx, "auth.revoke", values)
|
2018-12-01 10:55:35 -08:00
|
|
|
}
|
2023-01-28 13:57:53 -08:00
|
|
|
|
|
|
|
type listTeamsResponse struct {
|
|
|
|
Teams []Team `json:"teams"`
|
|
|
|
SlackResponse
|
|
|
|
}
|
|
|
|
|
|
|
|
type ListTeamsParameters struct {
|
|
|
|
Limit int
|
|
|
|
Cursor string
|
|
|
|
}
|
|
|
|
|
|
|
|
// ListTeams returns all workspaces a token can access.
|
|
|
|
// More info: https://api.slack.com/methods/admin.teams.list
|
|
|
|
func (api *Client) ListTeams(params ListTeamsParameters) ([]Team, string, error) {
|
|
|
|
return api.ListTeamsContext(context.Background(), params)
|
|
|
|
}
|
|
|
|
|
|
|
|
// ListTeams returns all workspaces a token can access with a custom context.
|
|
|
|
func (api *Client) ListTeamsContext(ctx context.Context, params ListTeamsParameters) ([]Team, string, error) {
|
|
|
|
values := url.Values{
|
|
|
|
"token": {api.token},
|
|
|
|
}
|
|
|
|
if params.Cursor != "" {
|
|
|
|
values.Add("cursor", params.Cursor)
|
|
|
|
}
|
|
|
|
|
|
|
|
response := &listTeamsResponse{}
|
|
|
|
err := api.postMethod(ctx, "auth.teams.list", values, response)
|
|
|
|
if err != nil {
|
|
|
|
return nil, "", err
|
|
|
|
}
|
|
|
|
|
|
|
|
return response.Teams, response.ResponseMetadata.Cursor, response.Err()
|
|
|
|
}
|