2021-01-22 21:47:22 +00:00
|
|
|
// Package groupme defines a client capable of executing API commands for the GroupMe chat service
|
2020-07-30 02:20:57 +00:00
|
|
|
package groupme
|
|
|
|
|
|
|
|
import (
|
2020-08-24 01:25:02 +00:00
|
|
|
"bytes"
|
2021-01-22 21:47:22 +00:00
|
|
|
"context"
|
2020-08-24 01:25:02 +00:00
|
|
|
"encoding/json"
|
2020-07-30 02:20:57 +00:00
|
|
|
"fmt"
|
|
|
|
"net/http"
|
|
|
|
)
|
|
|
|
|
|
|
|
// GroupMe documentation: https://dev.groupme.com/docs/v3#sms_mode
|
|
|
|
|
2021-01-22 21:47:22 +00:00
|
|
|
/*//////// Endpoints ////////*/
|
2020-07-30 02:20:57 +00:00
|
|
|
const (
|
|
|
|
// Used to build other endpoints
|
|
|
|
smsModeEndpointRoot = usersEndpointRoot + "/sms_mode"
|
|
|
|
|
|
|
|
// Actual Endpoints
|
|
|
|
createSMSModeEndpoint = smsModeEndpointRoot // POST
|
|
|
|
deleteSMSModeEndpoint = smsModeEndpointRoot + "/delete" // POST
|
|
|
|
)
|
|
|
|
|
2021-01-22 21:47:22 +00:00
|
|
|
/*//////// API Requests ////////*/
|
2020-07-30 02:20:57 +00:00
|
|
|
|
|
|
|
// Create
|
|
|
|
|
|
|
|
/*
|
|
|
|
CreateSMSMode -
|
|
|
|
Enables SMS mode for N hours, where N is at most 48. After N
|
|
|
|
hours have elapsed, user will receive push notfications.
|
|
|
|
|
|
|
|
Parameters:
|
2023-09-20 02:08:46 +00:00
|
|
|
|
2020-07-30 02:20:57 +00:00
|
|
|
duration - required, integer
|
|
|
|
registration_id - string; The push notification ID/token
|
|
|
|
that should be suppressed during SMS mode. If this is
|
|
|
|
omitted, both SMS and push notifications will be
|
|
|
|
delivered to the device.
|
|
|
|
*/
|
2023-09-20 02:08:46 +00:00
|
|
|
func (c *Client) CreateSMSMode(ctx context.Context, duration int, registrationID *ID, authToken string) error {
|
2020-08-24 01:25:02 +00:00
|
|
|
URL := fmt.Sprintf(c.endpointBase + createSMSModeEndpoint)
|
|
|
|
|
|
|
|
var data = struct {
|
|
|
|
Duration int `json:"duration"`
|
|
|
|
RegistrationID *ID `json:"registration_id,omitempty"`
|
|
|
|
}{
|
|
|
|
duration,
|
|
|
|
registrationID,
|
|
|
|
}
|
|
|
|
|
|
|
|
jsonBytes, err := json.Marshal(&data)
|
2020-07-30 02:20:57 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-08-24 01:25:02 +00:00
|
|
|
httpReq, err := http.NewRequest("POST", URL, bytes.NewBuffer(jsonBytes))
|
|
|
|
if err != nil {
|
|
|
|
return err
|
2020-07-30 02:20:57 +00:00
|
|
|
}
|
|
|
|
|
2023-09-20 02:08:46 +00:00
|
|
|
err = c.doWithAuthToken(ctx, httpReq, nil, authToken)
|
2020-07-30 02:20:57 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// Delete
|
|
|
|
|
|
|
|
/*
|
|
|
|
DeleteSMSMode -
|
|
|
|
|
|
|
|
Disables SMS mode
|
|
|
|
*/
|
2023-09-20 02:08:46 +00:00
|
|
|
func (c *Client) DeleteSMSMode(ctx context.Context, authToken string) error {
|
2020-07-30 02:20:57 +00:00
|
|
|
url := fmt.Sprintf(c.endpointBase + deleteSMSModeEndpoint)
|
|
|
|
|
|
|
|
httpReq, err := http.NewRequest("POST", url, nil)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2023-09-20 02:08:46 +00:00
|
|
|
return c.doWithAuthToken(ctx, httpReq, nil, authToken)
|
2020-07-30 02:20:57 +00:00
|
|
|
}
|