matterbridge/vendor/github.com/slack-go/slack/reminders.go

119 lines
3.9 KiB
Go
Raw Normal View History

package slack
import (
"context"
"net/url"
)
type Reminder struct {
2020-12-31 14:48:12 +01:00
ID string `json:"id"`
Creator string `json:"creator"`
User string `json:"user"`
Text string `json:"text"`
Recurring bool `json:"recurring"`
Time int `json:"time"`
CompleteTS int `json:"complete_ts"`
}
type reminderResp struct {
SlackResponse
Reminder Reminder `json:"reminder"`
}
2020-10-19 23:40:00 +02:00
type remindersResp struct {
SlackResponse
2021-03-20 22:40:23 +01:00
Reminders []*Reminder `json:"reminders"`
2020-10-19 23:40:00 +02:00
}
func (api *Client) doReminder(ctx context.Context, path string, values url.Values) (*Reminder, error) {
response := &reminderResp{}
2019-09-07 22:46:58 +02:00
if err := api.postMethod(ctx, path, values, response); err != nil {
return nil, err
}
return &response.Reminder, response.Err()
}
2020-10-19 23:40:00 +02:00
func (api *Client) doReminders(ctx context.Context, path string, values url.Values) ([]*Reminder, error) {
response := &remindersResp{}
if err := api.postMethod(ctx, path, values, response); err != nil {
return nil, err
}
// create an array of pointers to reminders
var reminders = make([]*Reminder, 0, len(response.Reminders))
reminders = append(reminders, response.Reminders...)
2020-10-19 23:40:00 +02:00
return reminders, response.Err()
}
// ListReminders lists all the reminders created by or for the authenticated user
// For more details, see ListRemindersContext documentation.
2020-10-19 23:40:00 +02:00
func (api *Client) ListReminders() ([]*Reminder, error) {
2022-04-25 23:50:10 +02:00
return api.ListRemindersContext(context.Background())
}
// ListRemindersContext lists all the reminders created by or for the authenticated user with a custom context.
// Slack API docs: https://api.slack.com/methods/reminders.list
2022-04-25 23:50:10 +02:00
func (api *Client) ListRemindersContext(ctx context.Context) ([]*Reminder, error) {
2020-10-19 23:40:00 +02:00
values := url.Values{
"token": {api.token},
}
2022-04-25 23:50:10 +02:00
return api.doReminders(ctx, "reminders.list", values)
2020-10-19 23:40:00 +02:00
}
// AddChannelReminder adds a reminder for a channel.
// For more details, see AddChannelReminderContext documentation.
func (api *Client) AddChannelReminder(channelID, text, time string) (*Reminder, error) {
2022-04-25 23:50:10 +02:00
return api.AddChannelReminderContext(context.Background(), channelID, text, time)
}
// AddChannelReminderContext adds a reminder for a channel with a custom context
// NOTE: the ability to set reminders on a channel is currently undocumented but has been tested to work.
// Slack API docs: https://api.slack.com/methods/reminders.add
2022-04-25 23:50:10 +02:00
func (api *Client) AddChannelReminderContext(ctx context.Context, channelID, text, time string) (*Reminder, error) {
values := url.Values{
"token": {api.token},
"text": {text},
"time": {time},
"channel": {channelID},
}
2022-04-25 23:50:10 +02:00
return api.doReminder(ctx, "reminders.add", values)
}
// AddUserReminder adds a reminder for a user.
// For more details, see AddUserReminderContext documentation.
func (api *Client) AddUserReminder(userID, text, time string) (*Reminder, error) {
2022-04-25 23:50:10 +02:00
return api.AddUserReminderContext(context.Background(), userID, text, time)
}
// AddUserReminderContext adds a reminder for a user with a custom context
// Slack API docs: https://api.slack.com/methods/reminders.add
2022-04-25 23:50:10 +02:00
func (api *Client) AddUserReminderContext(ctx context.Context, userID, text, time string) (*Reminder, error) {
values := url.Values{
"token": {api.token},
"text": {text},
"time": {time},
"user": {userID},
}
2022-04-25 23:50:10 +02:00
return api.doReminder(ctx, "reminders.add", values)
}
// DeleteReminder deletes an existing reminder.
// For more details, see DeleteReminderContext documentation.
func (api *Client) DeleteReminder(id string) error {
2022-04-25 23:50:10 +02:00
return api.DeleteReminderContext(context.Background(), id)
}
// DeleteReminderContext deletes an existing reminder with a custom context
// Slack API docs: https://api.slack.com/methods/reminders.delete
2022-04-25 23:50:10 +02:00
func (api *Client) DeleteReminderContext(ctx context.Context, id string) error {
values := url.Values{
"token": {api.token},
"reminder": {id},
}
response := &SlackResponse{}
2022-04-25 23:50:10 +02:00
if err := api.postMethod(ctx, "reminders.delete", values, response); err != nil {
return err
}
return response.Err()
}