Add Entitlements endpoints to API
This commit is contained in:
parent
113327bd86
commit
1557797545
|
@ -13,6 +13,7 @@ import (
|
||||||
"go.fifitido.net/twitch/api/charity"
|
"go.fifitido.net/twitch/api/charity"
|
||||||
"go.fifitido.net/twitch/api/chat"
|
"go.fifitido.net/twitch/api/chat"
|
||||||
"go.fifitido.net/twitch/api/conduit"
|
"go.fifitido.net/twitch/api/conduit"
|
||||||
|
"go.fifitido.net/twitch/api/entitlements"
|
||||||
"go.fifitido.net/twitch/api/eventsub"
|
"go.fifitido.net/twitch/api/eventsub"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -31,6 +32,7 @@ type API struct {
|
||||||
Chat *chat.Chat
|
Chat *chat.Chat
|
||||||
Conduit *conduit.Conduit
|
Conduit *conduit.Conduit
|
||||||
CCLS *ccls.CCLS
|
CCLS *ccls.CCLS
|
||||||
|
Entitlements *entitlements.Entitlements
|
||||||
EventSub *eventsub.EventSub
|
EventSub *eventsub.EventSub
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -51,6 +53,7 @@ func New() *API {
|
||||||
Chat: chat.New(client, baseUrl),
|
Chat: chat.New(client, baseUrl),
|
||||||
Conduit: conduit.New(client, baseUrl),
|
Conduit: conduit.New(client, baseUrl),
|
||||||
CCLS: ccls.New(client, baseUrl),
|
CCLS: ccls.New(client, baseUrl),
|
||||||
|
Entitlements: entitlements.New(client, baseUrl),
|
||||||
EventSub: eventsub.New(client, baseUrl),
|
EventSub: eventsub.New(client, baseUrl),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,18 @@
|
||||||
|
package entitlements
|
||||||
|
|
||||||
|
import (
|
||||||
|
"net/http"
|
||||||
|
"net/url"
|
||||||
|
)
|
||||||
|
|
||||||
|
type Entitlements struct {
|
||||||
|
client *http.Client
|
||||||
|
baseUrl *url.URL
|
||||||
|
}
|
||||||
|
|
||||||
|
func New(client *http.Client, baseUrl *url.URL) *Entitlements {
|
||||||
|
return &Entitlements{
|
||||||
|
client: client,
|
||||||
|
baseUrl: baseUrl,
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,111 @@
|
||||||
|
package entitlements
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"encoding/json"
|
||||||
|
"net/http"
|
||||||
|
"net/url"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"github.com/google/go-querystring/query"
|
||||||
|
"go.fifitido.net/twitch/api/types"
|
||||||
|
)
|
||||||
|
|
||||||
|
type GetDropsEntitlementsParams struct {
|
||||||
|
// An ID that identifies the entitlement to get.
|
||||||
|
// Include this parameter for each entitlement you want to get.
|
||||||
|
// For example, id=1234&id=5678.
|
||||||
|
// You may specify a maximum of 100 IDs.
|
||||||
|
IDs []string `url:"id,omitempty"`
|
||||||
|
|
||||||
|
// An ID that identifies a user that was granted entitlements.
|
||||||
|
UserID *string `url:"user_id,omitempty"`
|
||||||
|
|
||||||
|
// An ID that identifies a game that offered entitlements.
|
||||||
|
GameID *string `url:"game_id,omitempty"`
|
||||||
|
|
||||||
|
// The entitlement’s fulfillment status. Used to filter the list to only those with the specified status.
|
||||||
|
FulfillmentStatus *FulfillmentStatus `url:"fulfillment_status,omitempty"`
|
||||||
|
|
||||||
|
// The cursor used to get the next page of results.
|
||||||
|
// The Pagination object in the response contains the cursor’s value.
|
||||||
|
// Read More: https://dev.twitch.tv/docs/api/guide#pagination
|
||||||
|
Cursor *string `url:"cursor,omitempty"`
|
||||||
|
|
||||||
|
// The maximum number of entitlements to return per page in the response.
|
||||||
|
// The minimum page size is 1 entitlement per page and the maximum is 1000.
|
||||||
|
// The default is 20.
|
||||||
|
First *int `url:"first,omitempty"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type GetDropsEntitlementsResponse struct {
|
||||||
|
// The list of entitlements.
|
||||||
|
Data []Entitlement `json:"data"`
|
||||||
|
|
||||||
|
// The information used to page through the list of results.
|
||||||
|
// The object is empty if there are no more pages left to page through.
|
||||||
|
// Read More: https://dev.twitch.tv/docs/api/guide#pagination
|
||||||
|
Pagination *types.Pagination `json:"pagination"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type Entitlement struct {
|
||||||
|
// An ID that identifies the entitlement.
|
||||||
|
ID string `json:"id"`
|
||||||
|
|
||||||
|
// An ID that identifies the benefit (reward).
|
||||||
|
BenefitID string `json:"benefit_id"`
|
||||||
|
|
||||||
|
// The UTC date and time (in RFC3339 format) of when the entitlement was granted.
|
||||||
|
Timestamp time.Time `json:"timestamp"`
|
||||||
|
|
||||||
|
// An ID that identifies the user who was granted the entitlement.
|
||||||
|
UserID string `json:"user_id"`
|
||||||
|
|
||||||
|
// An ID that identifies the game the user was playing when the reward was entitled.
|
||||||
|
GameID string `json:"game_id"`
|
||||||
|
|
||||||
|
// The entitlement’s fulfillment status.
|
||||||
|
FulfillmentStatus FulfillmentStatus `json:"fulfillment_status"`
|
||||||
|
|
||||||
|
// The UTC date and time (in RFC3339 format) of when the entitlement was last updated.
|
||||||
|
LastUpdated time.Time `json:"last_updated"`
|
||||||
|
}
|
||||||
|
|
||||||
|
// Gets an organization’s list of entitlements that have been granted to a game, a user, or both.
|
||||||
|
//
|
||||||
|
// NOTE: Entitlements returned in the response body data are not guaranteed to be sorted by any field returned by the API. To retrieve CLAIMED or FULFILLED entitlements, use the fulfillment_status query parameter to filter results. To retrieve entitlements for a specific game, use the game_id query parameter to filter results.
|
||||||
|
//
|
||||||
|
// The following table identifies the request parameters that you may specify based on the type of access token used.
|
||||||
|
// Access token type | Parameter | Description
|
||||||
|
// ------------------|------------------|---------------------------------------------------------------------------------------------------------------------
|
||||||
|
// App | None | If you don’t specify request parameters, the request returns all entitlements that your organization owns.
|
||||||
|
// App | user_id | The request returns all entitlements for any game that the organization granted to the specified user.
|
||||||
|
// App | user_id, game_id | The request returns all entitlements that the specified game granted to the specified user.
|
||||||
|
// App | game_id | The request returns all entitlements that the specified game granted to all entitled users.
|
||||||
|
// User | None | If you don’t specify request parameters, the request returns all entitlements for any game that the organization granted to the user identified in the access token.
|
||||||
|
// User | user_id | Invalid.
|
||||||
|
// User | user_id, game_id | Invalid.
|
||||||
|
// User | game_id | The request returns all entitlements that the specified game granted to the user identified in the access token.
|
||||||
|
//
|
||||||
|
// Requires an app access token or user access token. The client ID in the access token must own the game.
|
||||||
|
func (c *Entitlements) GetDropsEntitlements(ctx context.Context, params *GetDropsEntitlementsParams) (*GetDropsEntitlementsResponse, error) {
|
||||||
|
v, _ := query.Values(params)
|
||||||
|
endpoint := c.baseUrl.ResolveReference(&url.URL{Path: "entitlements/drops", RawQuery: v.Encode()})
|
||||||
|
|
||||||
|
req, err := http.NewRequestWithContext(ctx, http.MethodGet, endpoint.String(), nil)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
res, err := c.client.Do(req)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
var data GetDropsEntitlementsResponse
|
||||||
|
if err := json.NewDecoder(res.Body).Decode(&data); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
return &data, nil
|
||||||
|
}
|
|
@ -0,0 +1,18 @@
|
||||||
|
package entitlements
|
||||||
|
|
||||||
|
type FulfillmentStatus string
|
||||||
|
|
||||||
|
const (
|
||||||
|
FulfillmentStatusClaimed FulfillmentStatus = "CLAIMED"
|
||||||
|
FulfillmentStatusFulfilled FulfillmentStatus = "FULFILLED"
|
||||||
|
)
|
||||||
|
|
||||||
|
type UpdateStatus string
|
||||||
|
|
||||||
|
const (
|
||||||
|
UpdateStatusInvalidID UpdateStatus = "INVALID_ID"
|
||||||
|
UpdateStatusNotFound UpdateStatus = "NOT_FOUND"
|
||||||
|
UpdateStatusSuccess UpdateStatus = "SUCCESS"
|
||||||
|
UpdateStatusUnauthorized UpdateStatus = "UNAUTHORIZED"
|
||||||
|
UpdateStatusUpdateFailed UpdateStatus = "UPDATE_FAILED"
|
||||||
|
)
|
|
@ -0,0 +1,70 @@
|
||||||
|
package entitlements
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"encoding/json"
|
||||||
|
"io"
|
||||||
|
"net/http"
|
||||||
|
"net/url"
|
||||||
|
)
|
||||||
|
|
||||||
|
type UpdateDropsEntitlementsRequest struct {
|
||||||
|
// A list of IDs that identify the entitlements to update. You may specify a maximum of 100 IDs.
|
||||||
|
EntitlementIDs *[]string `json:"entitlement_ids,omitempty"`
|
||||||
|
|
||||||
|
// The fulfillment status to set the entitlements to.
|
||||||
|
FulfillmentStatus *FulfillmentStatus `json:"fulfillment_status,omitempty"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type UpdateDropsEntitlementsResponse struct {
|
||||||
|
// A list that indicates which entitlements were successfully updated and those that weren’t.
|
||||||
|
Data []UpdateDropsEntitlementsData `json:"data"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type UpdateDropsEntitlementsData struct {
|
||||||
|
// A string that indicates whether the status of the entitlements in the ids field were successfully updated.
|
||||||
|
Status UpdateStatus `json:"status"`
|
||||||
|
|
||||||
|
// The list of entitlements that the status in the status field applies to.
|
||||||
|
IDs []string `json:"ids"`
|
||||||
|
}
|
||||||
|
|
||||||
|
// Updates the Drop entitlement’s fulfillment status.
|
||||||
|
//
|
||||||
|
// The following table identifies which entitlements are updated based on the type of access token used.
|
||||||
|
// Access token type | Data that’s updated
|
||||||
|
// ------------------|------------------------------------------------------------------------------------------------------------------------------------------
|
||||||
|
// App | Updates all entitlements with benefits owned by the organization in the access token.
|
||||||
|
// User | Updates all entitlements owned by the user in the access token and where the benefits are owned by the organization in the access token.
|
||||||
|
//
|
||||||
|
// Requires an app access token or user access token. The client ID in the access token must own the game.
|
||||||
|
func (c *Entitlements) UpdateDropsEntitlements(ctx context.Context, request *UpdateDropsEntitlementsRequest) (*UpdateDropsEntitlementsResponse, error) {
|
||||||
|
endpoint := c.baseUrl.ResolveReference(&url.URL{Path: "entitlements/drops"})
|
||||||
|
|
||||||
|
r, w := io.Pipe()
|
||||||
|
|
||||||
|
go func() {
|
||||||
|
if err := json.NewEncoder(w).Encode(request); err != nil {
|
||||||
|
w.CloseWithError(err)
|
||||||
|
} else {
|
||||||
|
w.Close()
|
||||||
|
}
|
||||||
|
}()
|
||||||
|
|
||||||
|
req, err := http.NewRequestWithContext(ctx, http.MethodPatch, endpoint.String(), r)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
res, err := c.client.Do(req)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
var data UpdateDropsEntitlementsResponse
|
||||||
|
if err := json.NewDecoder(res.Body).Decode(&data); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
return &data, nil
|
||||||
|
}
|
12
ptr_types.go
12
ptr_types.go
|
@ -6,6 +6,7 @@ import (
|
||||||
"go.fifitido.net/twitch/api/bits"
|
"go.fifitido.net/twitch/api/bits"
|
||||||
"go.fifitido.net/twitch/api/channelpoints"
|
"go.fifitido.net/twitch/api/channelpoints"
|
||||||
"go.fifitido.net/twitch/api/conduit"
|
"go.fifitido.net/twitch/api/conduit"
|
||||||
|
"go.fifitido.net/twitch/api/entitlements"
|
||||||
"go.fifitido.net/twitch/api/types"
|
"go.fifitido.net/twitch/api/types"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -184,3 +185,14 @@ func ToLocale(s *types.Locale) types.Locale {
|
||||||
}
|
}
|
||||||
return *s
|
return *s
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func FulfillmentStatus(s entitlements.FulfillmentStatus) *entitlements.FulfillmentStatus {
|
||||||
|
return &s
|
||||||
|
}
|
||||||
|
|
||||||
|
func ToFulfillmentStatus(s *entitlements.FulfillmentStatus) entitlements.FulfillmentStatus {
|
||||||
|
if s == nil {
|
||||||
|
return ""
|
||||||
|
}
|
||||||
|
return *s
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue