// Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT. package operations import ( "github.com/LukeHagar/plexgo/internal/utils" "github.com/LukeHagar/plexgo/models/components" "net/http" ) type GetChannelsGlobals struct { // Indicates the client accepts the indicated media types Accepts *components.Accepts `default:"application/xml" header:"style=simple,explode=false,name=accepts"` // An opaque identifier unique to the client ClientIdentifier *string `header:"style=simple,explode=false,name=X-Plex-Client-Identifier"` // The name of the client product Product *string `header:"style=simple,explode=false,name=X-Plex-Product"` // The version of the client application Version *string `header:"style=simple,explode=false,name=X-Plex-Version"` // The platform of the client Platform *string `header:"style=simple,explode=false,name=X-Plex-Platform"` // The version of the platform PlatformVersion *string `header:"style=simple,explode=false,name=X-Plex-Platform-Version"` // A relatively friendly name for the client device Device *string `header:"style=simple,explode=false,name=X-Plex-Device"` // A potentially less friendly identifier for the device model Model *string `header:"style=simple,explode=false,name=X-Plex-Model"` // The device vendor DeviceVendor *string `header:"style=simple,explode=false,name=X-Plex-Device-Vendor"` // A friendly name for the client DeviceName *string `header:"style=simple,explode=false,name=X-Plex-Device-Name"` // The marketplace on which the client application is distributed Marketplace *string `header:"style=simple,explode=false,name=X-Plex-Marketplace"` } func (g GetChannelsGlobals) MarshalJSON() ([]byte, error) { return utils.MarshalJSON(g, "", false) } func (g *GetChannelsGlobals) UnmarshalJSON(data []byte) error { if err := utils.UnmarshalJSON(data, &g, "", false, nil); err != nil { return err } return nil } func (g *GetChannelsGlobals) GetAccepts() *components.Accepts { if g == nil { return nil } return g.Accepts } func (g *GetChannelsGlobals) GetClientIdentifier() *string { if g == nil { return nil } return g.ClientIdentifier } func (g *GetChannelsGlobals) GetProduct() *string { if g == nil { return nil } return g.Product } func (g *GetChannelsGlobals) GetVersion() *string { if g == nil { return nil } return g.Version } func (g *GetChannelsGlobals) GetPlatform() *string { if g == nil { return nil } return g.Platform } func (g *GetChannelsGlobals) GetPlatformVersion() *string { if g == nil { return nil } return g.PlatformVersion } func (g *GetChannelsGlobals) GetDevice() *string { if g == nil { return nil } return g.Device } func (g *GetChannelsGlobals) GetModel() *string { if g == nil { return nil } return g.Model } func (g *GetChannelsGlobals) GetDeviceVendor() *string { if g == nil { return nil } return g.DeviceVendor } func (g *GetChannelsGlobals) GetDeviceName() *string { if g == nil { return nil } return g.DeviceName } func (g *GetChannelsGlobals) GetMarketplace() *string { if g == nil { return nil } return g.Marketplace } type GetChannelsRequest struct { // Indicates the client accepts the indicated media types Accepts *components.Accepts `default:"application/xml" header:"style=simple,explode=false,name=accepts"` // An opaque identifier unique to the client ClientIdentifier *string `header:"style=simple,explode=false,name=X-Plex-Client-Identifier"` // The name of the client product Product *string `header:"style=simple,explode=false,name=X-Plex-Product"` // The version of the client application Version *string `header:"style=simple,explode=false,name=X-Plex-Version"` // The platform of the client Platform *string `header:"style=simple,explode=false,name=X-Plex-Platform"` // The version of the platform PlatformVersion *string `header:"style=simple,explode=false,name=X-Plex-Platform-Version"` // A relatively friendly name for the client device Device *string `header:"style=simple,explode=false,name=X-Plex-Device"` // A potentially less friendly identifier for the device model Model *string `header:"style=simple,explode=false,name=X-Plex-Model"` // The device vendor DeviceVendor *string `header:"style=simple,explode=false,name=X-Plex-Device-Vendor"` // A friendly name for the client DeviceName *string `header:"style=simple,explode=false,name=X-Plex-Device-Name"` // The marketplace on which the client application is distributed Marketplace *string `header:"style=simple,explode=false,name=X-Plex-Marketplace"` // The URI describing the lineup Lineup string `queryParam:"style=form,explode=true,name=lineup"` } func (g GetChannelsRequest) MarshalJSON() ([]byte, error) { return utils.MarshalJSON(g, "", false) } func (g *GetChannelsRequest) UnmarshalJSON(data []byte) error { if err := utils.UnmarshalJSON(data, &g, "", false, []string{"lineup"}); err != nil { return err } return nil } func (g *GetChannelsRequest) GetAccepts() *components.Accepts { if g == nil { return nil } return g.Accepts } func (g *GetChannelsRequest) GetClientIdentifier() *string { if g == nil { return nil } return g.ClientIdentifier } func (g *GetChannelsRequest) GetProduct() *string { if g == nil { return nil } return g.Product } func (g *GetChannelsRequest) GetVersion() *string { if g == nil { return nil } return g.Version } func (g *GetChannelsRequest) GetPlatform() *string { if g == nil { return nil } return g.Platform } func (g *GetChannelsRequest) GetPlatformVersion() *string { if g == nil { return nil } return g.PlatformVersion } func (g *GetChannelsRequest) GetDevice() *string { if g == nil { return nil } return g.Device } func (g *GetChannelsRequest) GetModel() *string { if g == nil { return nil } return g.Model } func (g *GetChannelsRequest) GetDeviceVendor() *string { if g == nil { return nil } return g.DeviceVendor } func (g *GetChannelsRequest) GetDeviceName() *string { if g == nil { return nil } return g.DeviceName } func (g *GetChannelsRequest) GetMarketplace() *string { if g == nil { return nil } return g.Marketplace } func (g *GetChannelsRequest) GetLineup() string { if g == nil { return "" } return g.Lineup } // GetChannelsMediaContainer - `MediaContainer` is the root element of most Plex API responses. It serves as a generic container for various types of content (Metadata, Hubs, Directories, etc.) and includes pagination information (offset, size, totalSize) when applicable. // Common attributes: - identifier: Unique identifier for this container - size: Number of items in this response page - totalSize: Total number of items available (for pagination) - offset: Starting index of this page (for pagination) // The container often "hoists" common attributes from its children. For example, if all tracks in a container share the same album title, the `parentTitle` attribute may appear on the MediaContainer rather than being repeated on each track. type GetChannelsMediaContainer struct { Identifier *string `json:"identifier,omitempty"` // The offset of where this container page starts among the total objects available. Also provided in the `X-Plex-Container-Start` header. // Offset *int64 `json:"offset,omitempty"` Size *int64 `json:"size,omitempty"` // The total size of objects available. Also provided in the `X-Plex-Container-Total-Size` header. // TotalSize *int64 `json:"totalSize,omitempty"` Channel []components.Channel `json:"Channel,omitempty"` } func (g *GetChannelsMediaContainer) GetIdentifier() *string { if g == nil { return nil } return g.Identifier } func (g *GetChannelsMediaContainer) GetOffset() *int64 { if g == nil { return nil } return g.Offset } func (g *GetChannelsMediaContainer) GetSize() *int64 { if g == nil { return nil } return g.Size } func (g *GetChannelsMediaContainer) GetTotalSize() *int64 { if g == nil { return nil } return g.TotalSize } func (g *GetChannelsMediaContainer) GetChannel() []components.Channel { if g == nil { return nil } return g.Channel } // GetChannelsResponseBody - OK type GetChannelsResponseBody struct { MediaContainer *GetChannelsMediaContainer `json:"MediaContainer,omitempty"` } func (g *GetChannelsResponseBody) GetMediaContainer() *GetChannelsMediaContainer { if g == nil { return nil } return g.MediaContainer } type GetChannelsResponse struct { // HTTP response content type for this operation ContentType string // HTTP response status code for this operation StatusCode int // Raw HTTP response; suitable for custom response parsing RawResponse *http.Response // OK Object *GetChannelsResponseBody Headers map[string][]string } func (g *GetChannelsResponse) GetContentType() string { if g == nil { return "" } return g.ContentType } func (g *GetChannelsResponse) GetStatusCode() int { if g == nil { return 0 } return g.StatusCode } func (g *GetChannelsResponse) GetRawResponse() *http.Response { if g == nil { return nil } return g.RawResponse } func (g *GetChannelsResponse) GetObject() *GetChannelsResponseBody { if g == nil { return nil } return g.Object } func (g *GetChannelsResponse) GetHeaders() map[string][]string { if g == nil { return map[string][]string{} } return g.Headers }