mirror of
https://github.com/rjNemo/go-wiki
synced 2026-06-06 02:36:40 +00:00
60 lines
1.7 KiB
Go
60 lines
1.7 KiB
Go
package stripe
|
|
|
|
import (
|
|
"encoding/json"
|
|
)
|
|
|
|
// FileLinkParams is the set of parameters that can be used when creating or updating a file link.
|
|
type FileLinkParams struct {
|
|
Params `form:"*"`
|
|
ExpiresAt *int64 `form:"expires_at"`
|
|
File *string `form:"file"`
|
|
}
|
|
|
|
// FileLinkListParams is the set of parameters that can be used when listing file links.
|
|
type FileLinkListParams struct {
|
|
ListParams `form:"*"`
|
|
Created *int64 `form:"created"`
|
|
CreatedRange *RangeQueryParams `form:"created"`
|
|
Expired *bool `form:"expired"`
|
|
File *string `form:"file"`
|
|
}
|
|
|
|
// FileLink is the resource representing a Stripe file link.
|
|
// For more details see https://stripe.com/docs/api#file_links.
|
|
type FileLink struct {
|
|
Created int64 `json:"created"`
|
|
Expired bool `json:"expired"`
|
|
ExpiresAt int64 `json:"expires_at"`
|
|
File *File `json:"file"`
|
|
ID string `json:"id"`
|
|
Livemode bool `json:"livemode"`
|
|
Metadata map[string]string `json:"metadata"`
|
|
Object string `json:"object"`
|
|
URL string `json:"url"`
|
|
}
|
|
|
|
// UnmarshalJSON handles deserialization of a file link.
|
|
// This custom unmarshaling is needed because the resulting
|
|
// property may be an ID or the full struct if it was expanded.
|
|
func (c *FileLink) UnmarshalJSON(data []byte) error {
|
|
if id, ok := ParseID(data); ok {
|
|
c.ID = id
|
|
return nil
|
|
}
|
|
|
|
type fileLink FileLink
|
|
var v fileLink
|
|
if err := json.Unmarshal(data, &v); err != nil {
|
|
return err
|
|
}
|
|
|
|
*c = FileLink(v)
|
|
return nil
|
|
}
|
|
|
|
// FileLinkList is a list of file links as retrieved from a list endpoint.
|
|
type FileLinkList struct {
|
|
ListMeta
|
|
Data []*FileLink `json:"data"`
|
|
}
|