Documentation ¶
Overview ¶
Package api provides types for communicating with the REST API
Index ¶
- type AVstream
- type AVstreamIO
- type About
- type Command
- type Config
- type ConfigData
- type ConfigError
- type ConfigVersion
- type Error
- type FileInfo
- type FilesystemInfo
- type GraphQuery
- type GraphResponse
- type JWT
- type JWTRefresh
- type LogEvent
- type Login
- type Metadata
- type MetricsDescription
- type MetricsQuery
- type MetricsQueryMetric
- type MetricsResponse
- type MetricsResponseMetric
- type MetricsResponseValue
- type MinimalAbout
- type PlayoutStatus
- type PlayoutStatusIO
- type PlayoutStatusSwap
- type Probe
- type ProbeIO
- type Process
- type ProcessConfig
- type ProcessConfigIO
- type ProcessConfigIOCleanup
- type ProcessConfigLimits
- type ProcessReport
- type ProcessReportHistoryEntry
- type ProcessState
- type Progress
- type ProgressIO
- type ProgressIOFramerate
- type RTMPChannel
- type SRTChannels
- type SRTConnection
- type SRTLog
- type SRTStatistics
- type Session
- type SessionPeers
- type SessionStats
- type SessionSummary
- type SessionSummaryActive
- type SessionSummarySummary
- type SessionsActive
- type SessionsSummary
- type SetConfig
- type SetConfigV1
- type SetConfigV2
- type Skills
- type SkillsCodec
- type SkillsDevice
- type SkillsFilter
- type SkillsFormat
- type SkillsHWAccel
- type SkillsHWDevice
- type SkillsLibrary
- type SkillsProtocol
- type Version
- type VersionMinimal
- type WidgetProcess
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type AVstream ¶
type AVstream struct { Input AVstreamIO `json:"input"` Output AVstreamIO `json:"output"` Aqueue uint64 `json:"aqueue" format:"uint64"` Queue uint64 `json:"queue" format:"uint64"` Dup uint64 `json:"dup" format:"uint64"` Drop uint64 `json:"drop" format:"uint64"` Enc uint64 `json:"enc" format:"uint64"` Looping bool `json:"looping"` LoopingRuntime uint64 `json:"looping_runtime" format:"uint64"` Duplicating bool `json:"duplicating"` GOP string `json:"gop"` }
type AVstreamIO ¶
type AVstreamIO struct { State string `json:"state" enums:"running,idle" jsonschema:"enum=running,enum=idle"` Packet uint64 `json:"packet" format:"uint64"` Time uint64 `json:"time"` Size uint64 `json:"size_kb"` }
func (*AVstreamIO) Unmarshal ¶
func (i *AVstreamIO) Unmarshal(io *app.AVstreamIO)
type About ¶
type About struct { App string `json:"app"` Auths []string `json:"auths"` Name string `json:"name"` ID string `json:"id"` CreatedAt string `json:"created_at"` Uptime uint64 `json:"uptime_seconds"` Version Version `json:"version"` }
About is some general information about the API
type Command ¶
type Command struct {
Command string `` /* 127-byte string literal not displayed */
}
Command is a command to send to a process
type Config ¶
type Config struct { CreatedAt time.Time `json:"created_at"` LoadedAt time.Time `json:"loaded_at"` UpdatedAt time.Time `json:"updated_at"` Config ConfigData `json:"config"` Overrides []string `json:"overrides"` }
Config is the config returned by the API
type ConfigError ¶
ConfigError is used to return error messages when uploading a new config
type ConfigVersion ¶ added in v16.11.0
type ConfigVersion struct {
Version int64 `json:"version"`
}
ConfigVersion is used to only unmarshal the version field in order find out which SetConfig should be used.
type Error ¶
type Error struct { Code int `json:"code" jsonschema:"required" format:"int"` Message string `json:"message" jsonschema:""` Details []string `json:"details" jsonschema:""` }
Error represents an error response of the API
func Err ¶
Err creates a new API error with the given HTTP status code. If message is empty, the default message for the given code is used. If the first entry in args is a string, it is interpreted as a format string for the remaining entries in args, that is used for fmt.Sprintf. Otherwise the args are ignored.
type FileInfo ¶
type FileInfo struct { Name string `json:"name" jsonschema:"minLength=1"` Size int64 `json:"size_bytes" jsonschema:"minimum=0" format:"int64"` LastMod int64 `json:"last_modified" jsonschema:"minimum=0" format:"int64"` }
FileInfo represents informatiion about a file on a filesystem
type FilesystemInfo ¶ added in v16.12.0
type FilesystemInfo struct { Name string `json:"name"` Type string `json:"type"` Mount string `json:"mount"` }
FilesystemInfo represents information about a filesystem
type GraphQuery ¶
type GraphQuery struct { Query string `json:"query"` Variables interface{} `json:"variables"` }
type GraphResponse ¶
type GraphResponse struct { Data interface{} `json:"data"` Errors []interface{} `json:"errors"` }
type JWT ¶
type JWT struct { AccessToken string `json:"access_token" jsonschema:"minLength=1"` RefreshToken string `json:"refresh_token" jsonschema:"minLength=1"` }
JWT is the JWT token and its expiry date
type JWTRefresh ¶
type JWTRefresh struct {
AccessToken string `json:"access_token" jsonschema:"minLength=1"`
}
type Login ¶
type Login struct { Username string `json:"username" validate:"required" jsonschema:"minLength=1"` Password string `json:"password" validate:"required" jsonschema:"minLength=1"` }
Login are the requires login credentials
type Metadata ¶
type Metadata interface{}
Metadata represents arbitrary metadata for a process of for the app
func NewMetadata ¶
func NewMetadata(data interface{}) Metadata
NewMetadata takes an interface and converts it to a Metadata type.
type MetricsDescription ¶ added in v16.10.0
type MetricsQuery ¶
type MetricsQuery struct { Timerange int64 `json:"timerange_sec" format:"int64"` Interval int64 `json:"interval_sec" format:"int64"` Metrics []MetricsQueryMetric `json:"metrics"` }
type MetricsQueryMetric ¶
type MetricsResponse ¶
type MetricsResponse struct { Timerange int64 `json:"timerange_sec" format:"int64"` Interval int64 `json:"interval_sec" format:"int64"` Metrics []MetricsResponseMetric `json:"metrics"` }
func (*MetricsResponse) Unmarshal ¶
func (m *MetricsResponse) Unmarshal(data []monitor.HistoryMetrics, timerange, interval time.Duration)
type MetricsResponseMetric ¶
type MetricsResponseMetric struct { Name string `json:"name"` Labels map[string]string `json:"labels"` Values []MetricsResponseValue `json:"values"` }
type MetricsResponseValue ¶
func (MetricsResponseValue) MarshalJSON ¶
func (v MetricsResponseValue) MarshalJSON() ([]byte, error)
MarshalJSON marshals a MetricsResponseValue to JSON
type MinimalAbout ¶
type MinimalAbout struct { App string `json:"app"` Auths []string `json:"auths"` Version VersionMinimal `json:"version"` }
MinimalAbout is the minimal information about the API
type PlayoutStatus ¶
type PlayoutStatus struct { ID string `json:"id"` Address string `json:"url"` Stream uint64 `json:"stream" format:"uint64"` Queue uint64 `json:"queue" format:"uint64"` AQueue uint64 `json:"aqueue" format:"uint64"` Dup uint64 `json:"dup" format:"uint64"` Drop uint64 `json:"drop" format:"uint64"` Enc uint64 `json:"enc" format:"uint64"` Looping bool `json:"looping"` Duplicating bool `json:"duplicating"` GOP string `json:"gop"` Debug interface{} `json:"debug"` Input PlayoutStatusIO `json:"input"` Output PlayoutStatusIO `json:"output"` Swap PlayoutStatusSwap `json:"swap"` }
func (*PlayoutStatus) Unmarshal ¶
func (s *PlayoutStatus) Unmarshal(status playout.Status)
type PlayoutStatusIO ¶
type PlayoutStatusIO struct { State string `json:"state" enums:"running,idle" jsonschema:"enum=running,enum=idle"` Packet uint64 `json:"packet" format:"uint64"` Time uint64 `json:"time" format:"uint64"` Size uint64 `json:"size_kb" format:"uint64"` }
func (*PlayoutStatusIO) Unmarshal ¶
func (i *PlayoutStatusIO) Unmarshal(io playout.StatusIO)
type PlayoutStatusSwap ¶
type PlayoutStatusSwap struct { Address string `json:"url"` Status string `json:"status"` LastAddress string `json:"lasturl"` LastError string `json:"lasterror"` }
func (*PlayoutStatusSwap) Unmarshal ¶
func (s *PlayoutStatusSwap) Unmarshal(swap playout.StatusSwap)
type Probe ¶
Probe represents the result of probing a file. It has a list of detected streams and a list of log lone from the probe process.
type ProbeIO ¶
type ProbeIO struct { // common Address string `json:"url"` Format string `json:"format"` Index uint64 `json:"index" format:"uint64"` Stream uint64 `json:"stream" format:"uint64"` Language string `json:"language"` Type string `json:"type"` Codec string `json:"codec"` Coder string `json:"coder"` Bitrate json.Number `json:"bitrate_kbps" swaggertype:"number" jsonschema:"type=number"` Duration json.Number `json:"duration_sec" swaggertype:"number" jsonschema:"type=number"` // video FPS json.Number `json:"fps" swaggertype:"number" jsonschema:"type=number"` Pixfmt string `json:"pix_fmt"` Width uint64 `json:"width" format:"uint64"` Height uint64 `json:"height" format:"uint64"` // audio Sampling uint64 `json:"sampling_hz" format:"uint64"` Layout string `json:"layout"` Channels uint64 `json:"channels" format:"uint64"` }
ProbeIO represents a stream of a probed file
type Process ¶
type Process struct { ID string `json:"id" jsonschema:"minLength=1"` Type string `json:"type" jsonschema:"enum=ffmpeg"` Reference string `json:"reference"` CreatedAt int64 `json:"created_at" jsonschema:"minimum=0" format:"int64"` UpdatedAt int64 `json:"updated_at" jsonschema:"minimum=0" format:"int64"` Config *ProcessConfig `json:"config,omitempty"` State *ProcessState `json:"state,omitempty"` Report *ProcessReport `json:"report,omitempty"` Metadata Metadata `json:"metadata,omitempty"` }
Process represents all information on a process
type ProcessConfig ¶
type ProcessConfig struct { ID string `json:"id"` Type string `json:"type" validate:"oneof='ffmpeg' ''" jsonschema:"enum=ffmpeg,enum="` Reference string `json:"reference"` Input []ProcessConfigIO `json:"input" validate:"required"` Output []ProcessConfigIO `json:"output" validate:"required"` Options []string `json:"options"` Reconnect bool `json:"reconnect"` ReconnectDelay uint64 `json:"reconnect_delay_seconds" format:"uint64"` Autostart bool `json:"autostart"` StaleTimeout uint64 `json:"stale_timeout_seconds" format:"uint64"` Limits ProcessConfigLimits `json:"limits"` }
ProcessConfig represents the configuration of an ffmpeg process
func (*ProcessConfig) Marshal ¶
func (cfg *ProcessConfig) Marshal() *app.Config
Marshal converts a process config in API representation to a restreamer process config
func (*ProcessConfig) Unmarshal ¶
func (cfg *ProcessConfig) Unmarshal(c *app.Config)
Unmarshal converts a restream process config to a process config in API representation
type ProcessConfigIO ¶
type ProcessConfigIO struct { ID string `json:"id"` Address string `json:"address" validate:"required" jsonschema:"minLength=1"` Options []string `json:"options"` Cleanup []ProcessConfigIOCleanup `json:"cleanup,omitempty"` }
ProcessConfigIO represents an input or output of an ffmpeg process config
type ProcessConfigIOCleanup ¶
type ProcessConfigLimits ¶
type ProcessReport ¶
type ProcessReport struct { ProcessReportHistoryEntry History []ProcessReportHistoryEntry `json:"history"` }
ProcessReport represents the current log and the logs of previous runs of a restream process
func (*ProcessReport) Unmarshal ¶
func (report *ProcessReport) Unmarshal(l *app.Log)
Unmarshal converts a restream log to a report
type ProcessReportHistoryEntry ¶
type ProcessReportHistoryEntry struct { CreatedAt int64 `json:"created_at" format:"int64"` Prelude []string `json:"prelude"` Log [][2]string `json:"log"` }
ProcessReportHistoryEntry represents the logs of a run of a restream process
type ProcessState ¶
type ProcessState struct { Order string `json:"order" jsonschema:"enum=start,enum=stop"` State string `json:"exec" jsonschema:"enum=finished,enum=starting,enum=running,enum=finishing,enum=killed,enum=failed"` Runtime int64 `json:"runtime_seconds" jsonschema:"minimum=0" format:"int64"` Reconnect int64 `json:"reconnect_seconds" format:"int64"` LastLog string `json:"last_logline"` Progress *Progress `json:"progress"` Memory uint64 `json:"memory_bytes" format:"uint64"` CPU json.Number `json:"cpu_usage" swaggertype:"number" jsonschema:"type=number"` Command []string `json:"command"` }
ProcessState represents the current state of an ffmpeg process
func (*ProcessState) Unmarshal ¶
func (s *ProcessState) Unmarshal(state *app.State)
Unmarshal converts a restreamer ffmpeg process state to a state in API representation
type Progress ¶
type Progress struct { Input []ProgressIO `json:"inputs"` Output []ProgressIO `json:"outputs"` Frame uint64 `json:"frame" format:"uint64"` Packet uint64 `json:"packet" format:"uint64"` FPS json.Number `json:"fps" swaggertype:"number" jsonschema:"type=number"` Quantizer json.Number `json:"q" swaggertype:"number" jsonschema:"type=number"` Size uint64 `json:"size_kb" format:"uint64"` // kbytes Time json.Number `json:"time" swaggertype:"number" jsonschema:"type=number"` Bitrate json.Number `json:"bitrate_kbit" swaggertype:"number" jsonschema:"type=number"` // kbit/s Speed json.Number `json:"speed" swaggertype:"number" jsonschema:"type=number"` Drop uint64 `json:"drop" format:"uint64"` Dup uint64 `json:"dup" format:"uint64"` }
Progress represents the progress of an ffmpeg process
type ProgressIO ¶
type ProgressIO struct { ID string `json:"id" jsonschema:"minLength=1"` Address string `json:"address" jsonschema:"minLength=1"` // General Index uint64 `json:"index" format:"uint64"` Stream uint64 `json:"stream" format:"uint64"` Format string `json:"format"` Type string `json:"type"` Codec string `json:"codec"` Coder string `json:"coder"` Frame uint64 `json:"frame" format:"uint64"` Keyframe uint64 `json:"keyframe" format:"uint64"` Framerate ProgressIOFramerate `json:"framerate"` FPS json.Number `json:"fps" swaggertype:"number" jsonschema:"type=number"` Packet uint64 `json:"packet" format:"uint64"` PPS json.Number `json:"pps" swaggertype:"number" jsonschema:"type=number"` Size uint64 `json:"size_kb" format:"uint64"` // kbytes Bitrate json.Number `json:"bitrate_kbit" swaggertype:"number" jsonschema:"type=number"` // kbit/s Extradata uint64 `json:"extradata_size_bytes" format:"uint64"` // bytes // Video Pixfmt string `json:"pix_fmt,omitempty"` Quantizer json.Number `json:"q,omitempty" swaggertype:"number" jsonschema:"type=number"` Width uint64 `json:"width,omitempty" format:"uint64"` Height uint64 `json:"height,omitempty" format:"uint64"` // Audio Sampling uint64 `json:"sampling_hz,omitempty" format:"uint64"` Layout string `json:"layout,omitempty"` Channels uint64 `json:"channels,omitempty" format:"uint64"` // avstream AVstream *AVstream `json:"avstream"` }
ProgressIO represents the progress of an ffmpeg input or output
func (*ProgressIO) Unmarshal ¶
func (i *ProgressIO) Unmarshal(io *app.ProgressIO)
Unmarshal converts a restreamer ProgressIO to a ProgressIO in API representation
type ProgressIOFramerate ¶ added in v16.13.0
type RTMPChannel ¶
type RTMPChannel struct {
Name string `json:"name" jsonschema:"minLength=1"`
}
RTMPChannel represents details about a currently connected RTMP publisher
type SRTChannels ¶
type SRTChannels struct { Publisher map[string]uint32 `json:"publisher"` Subscriber map[string][]uint32 `json:"subscriber"` Connections map[uint32]SRTConnection `json:"connections"` Log map[string][]SRTLog `json:"log"` }
SRTChannels represents all current SRT connections
func (*SRTChannels) Unmarshal ¶
func (s *SRTChannels) Unmarshal(ss *srt.Channels)
Unmarshal converts the SRT channels into API representation
type SRTConnection ¶
type SRTConnection struct { Log map[string][]SRTLog `json:"log"` Stats SRTStatistics `json:"stats"` }
SRTConnection represents a SRT connection with statistics and logs
func (*SRTConnection) Unmarshal ¶
func (s *SRTConnection) Unmarshal(ss *srt.Connection)
Unmarshal converts the SRT connection into API representation
type SRTStatistics ¶
type SRTStatistics struct { MsTimeStamp uint64 `json:"timestamp_ms" format:"uint64"` // The time elapsed, in milliseconds, since the SRT socket has been created PktSent uint64 `json:"sent_pkt" format:"uint64"` // The total number of sent DATA packets, including retransmitted packets PktRecv uint64 `json:"recv_pkt" format:"uint64"` // The total number of received DATA packets, including retransmitted packets PktSentUnique uint64 `json:"sent_unique_pkt" format:"uint64"` // The total number of unique DATA packets sent by the SRT sender PktRecvUnique uint64 `json:"recv_unique_pkt" format:"uint64"` // The total number of unique original, retransmitted or recovered by the packet filter DATA packets received in time, decrypted without errors and, as a result, scheduled for delivery to the upstream application by the SRT receiver. PktSndLoss uint64 `json:"send_loss_pkt" format:"uint64"` // The total number of data packets considered or reported as lost at the sender side. Does not correspond to the packets detected as lost at the receiver side. PktRcvLoss uint64 `json:"recv_loss_pkt" format:"uint64"` // The total number of SRT DATA packets detected as presently missing (either reordered or lost) at the receiver side PktRetrans uint64 `json:"sent_retrans_pkt" format:"uint64"` // The total number of retransmitted packets sent by the SRT sender PktRcvRetrans uint64 `json:"recv_retran_pkts" format:"uint64"` // The total number of retransmitted packets registered at the receiver side PktSentACK uint64 `json:"sent_ack_pkt" format:"uint64"` // The total number of sent ACK (Acknowledgement) control packets PktRecvACK uint64 `json:"recv_ack_pkt" format:"uint64"` // The total number of received ACK (Acknowledgement) control packets PktSentNAK uint64 `json:"sent_nak_pkt" format:"uint64"` // The total number of sent NAK (Negative Acknowledgement) control packets PktRecvNAK uint64 `json:"recv_nak_pkt" format:"uint64"` // The total number of received NAK (Negative Acknowledgement) control packets PktSentKM uint64 `json:"send_km_pkt" format:"uint64"` // The total number of sent KM (Key Material) control packets PktRecvKM uint64 `json:"recv_km_pkt" format:"uint64"` // The total number of received KM (Key Material) control packets UsSndDuration uint64 `json:"send_duration_us" format:"uint64"` // The total accumulated time in microseconds, during which the SRT sender has some data to transmit, including packets that have been sent, but not yet acknowledged PktSndDrop uint64 `json:"send_drop_pkt" format:"uint64"` // The total number of dropped by the SRT sender DATA packets that have no chance to be delivered in time PktRcvDrop uint64 `json:"recv_drop_pkt" format:"uint64"` // The total number of dropped by the SRT receiver and, as a result, not delivered to the upstream application DATA packets PktRcvUndecrypt uint64 `json:"recv_undecrypt_pkt" format:"uint64"` // The total number of packets that failed to be decrypted at the receiver side ByteSent uint64 `json:"sent_bytes" format:"uint64"` // Same as pktSent, but expressed in bytes, including payload and all the headers (IP, TCP, SRT) ByteRecv uint64 `json:"recv_bytes" format:"uint64"` // Same as pktRecv, but expressed in bytes, including payload and all the headers (IP, TCP, SRT) ByteSentUnique uint64 `json:"sent_unique_bytes" format:"uint64"` // Same as pktSentUnique, but expressed in bytes, including payload and all the headers (IP, TCP, SRT) ByteRecvUnique uint64 `json:"recv_unique_bytes" format:"uint64"` // Same as pktRecvUnique, but expressed in bytes, including payload and all the headers (IP, TCP, SRT) ByteRcvLoss uint64 `json:"recv_loss_bytes" format:"uint64"` // Same as pktRcvLoss, but expressed in bytes, including payload and all the headers (IP, TCP, SRT), bytes for the presently missing (either reordered or lost) packets' payloads are estimated based on the average packet size ByteRetrans uint64 `json:"sent_retrans_bytes" format:"uint64"` // Same as pktRetrans, but expressed in bytes, including payload and all the headers (IP, TCP, SRT) ByteSndDrop uint64 `json:"send_drop_bytes" format:"uint64"` // Same as pktSndDrop, but expressed in bytes, including payload and all the headers (IP, TCP, SRT) ByteRcvDrop uint64 `json:"recv_drop_bytes" format:"uint64"` // Same as pktRcvDrop, but expressed in bytes, including payload and all the headers (IP, TCP, SRT) ByteRcvUndecrypt uint64 `json:"recv_undecrypt_bytes" format:"uint64"` // Same as pktRcvUndecrypt, but expressed in bytes, including payload and all the headers (IP, TCP, SRT) UsPktSndPeriod float64 `json:"pkt_send_period_us"` // Current minimum time interval between which consecutive packets are sent, in microseconds PktFlowWindow uint64 `json:"flow_window_pkt" format:"uint64"` // The maximum number of packets that can be "in flight" PktFlightSize uint64 `json:"flight_size_pkt" format:"uint64"` // The number of packets in flight MsRTT float64 `json:"rtt_ms"` // Smoothed round-trip time (SRTT), an exponentially-weighted moving average (EWMA) of an endpoint's RTT samples, in milliseconds MbpsBandwidth float64 `json:"bandwidth_mbit"` // Estimated bandwidth of the network link, in Mbps ByteAvailSndBuf uint64 `json:"avail_send_buf_bytes" format:"uint64"` // The available space in the sender's buffer, in bytes ByteAvailRcvBuf uint64 `json:"avail_recv_buf_bytes" format:"uint64"` // The available space in the receiver's buffer, in bytes MbpsMaxBW float64 `json:"max_bandwidth_mbit"` // Transmission bandwidth limit, in Mbps ByteMSS uint64 `json:"mss_bytes" format:"uint64"` // Maximum Segment Size (MSS), in bytes PktSndBuf uint64 `json:"send_buf_pkt" format:"uint64"` // The number of packets in the sender's buffer that are already scheduled for sending or even possibly sent, but not yet acknowledged ByteSndBuf uint64 `json:"send_buf_bytes" format:"uint64"` // Instantaneous (current) value of pktSndBuf, but expressed in bytes, including payload and all headers (IP, TCP, SRT) MsSndBuf uint64 `json:"send_buf_ms" format:"uint64"` // The timespan (msec) of packets in the sender's buffer (unacknowledged packets) MsSndTsbPdDelay uint64 `json:"send_tsbpd_delay_ms" format:"uint64"` // Timestamp-based Packet Delivery Delay value of the peer PktRcvBuf uint64 `json:"recv_buf_pkt" format:"uint64"` // The number of acknowledged packets in receiver's buffer ByteRcvBuf uint64 `json:"recv_buf_bytes" format:"uint64"` // Instantaneous (current) value of pktRcvBuf, expressed in bytes, including payload and all headers (IP, TCP, SRT) MsRcvBuf uint64 `json:"recv_buf_ms" format:"uint64"` // The timespan (msec) of acknowledged packets in the receiver's buffer MsRcvTsbPdDelay uint64 `json:"recv_tsbpd_delay_ms" format:"uint64"` // Timestamp-based Packet Delivery Delay value set on the socket via SRTO_RCVLATENCY or SRTO_LATENCY PktReorderTolerance uint64 `json:"reorder_tolerance_pkt" format:"uint64"` // Instant value of the packet reorder tolerance PktRcvAvgBelatedTime uint64 `json:"pkt_recv_avg_belated_time_ms" format:"uint64"` // Accumulated difference between the current time and the time-to-play of a packet that is received late }
SRTStatistics represents the statistics of a SRT connection
func (*SRTStatistics) Unmarshal ¶
func (s *SRTStatistics) Unmarshal(ss *gosrt.Statistics)
Unmarshal converts the SRT statistics into API representation
type Session ¶
type Session struct { ID string `json:"id"` Reference string `json:"reference"` CreatedAt int64 `json:"created_at" format:"int64"` Location string `json:"local"` Peer string `json:"remote"` Extra string `json:"extra"` RxBytes uint64 `json:"bytes_rx" format:"uint64"` TxBytes uint64 `json:"bytes_tx" format:"uint64"` RxBitrate json.Number `json:"bandwidth_rx_kbit" swaggertype:"number" jsonschema:"type=number"` // kbit/s TxBitrate json.Number `json:"bandwidth_tx_kbit" swaggertype:"number" jsonschema:"type=number"` // kbit/s }
Session represents an active session
type SessionPeers ¶
type SessionPeers struct { SessionStats Locations map[string]SessionStats `json:"local"` }
SessionPeers is for the grouping by peers in the summary
type SessionStats ¶
type SessionStats struct { TotalSessions uint64 `json:"sessions" format:"uint64"` TotalRxBytes uint64 `json:"traffic_rx_mb" format:"uint64"` TotalTxBytes uint64 `json:"traffic_tx_mb" format:"uint64"` }
SessionStats are the accumulated numbers for the session summary
type SessionSummary ¶
type SessionSummary struct { Active SessionSummaryActive `json:"active"` Summary SessionSummarySummary `json:"summary"` }
SessionSummary is the API representation of a session.Summary
func (*SessionSummary) Unmarshal ¶
func (summary *SessionSummary) Unmarshal(sum session.Summary)
Unmarshal creates a new SessionSummary from a session.Summary
type SessionSummaryActive ¶
type SessionSummaryActive struct { SessionList []Session `json:"list"` Sessions uint64 `json:"sessions" format:"uint64"` RxBitrate json.Number `json:"bandwidth_rx_mbit" swaggertype:"number" jsonschema:"type=number"` // mbit/s TxBitrate json.Number `json:"bandwidth_tx_mbit" swaggertype:"number" jsonschema:"type=number"` // mbit/s MaxSessions uint64 `json:"max_sessions" format:"uint64"` MaxRxBitrate json.Number `json:"max_bandwidth_rx_mbit" swaggertype:"number" jsonschema:"type=number"` // mbit/s MaxTxBitrate json.Number `json:"max_bandwidth_tx_mbit" swaggertype:"number" jsonschema:"type=number"` // mbit/s }
SessionSummaryActive represents the currently active sessions
type SessionSummarySummary ¶
type SessionSummarySummary struct { Peers map[string]SessionPeers `json:"remote"` Locations map[string]SessionStats `json:"local"` References map[string]SessionStats `json:"reference"` SessionStats }
SessionSummarySummary represents the summary (history) of all finished sessions
type SessionsActive ¶
SessionsActive is the API representation of all active sessions
type SessionsSummary ¶
type SessionsSummary map[string]SessionSummary
type SetConfig ¶
SetConfig embeds config.Data. It is used to send a new config to the server.
func NewSetConfig ¶
NewSetConfig converts a config.Config into a SetConfig in order to prepopulate a SetConfig with the current values. The uploaded config can have missing fields that will be filled with the current values after unmarshalling the JSON.
type SetConfigV1 ¶ added in v16.11.0
func NewSetConfigV1 ¶ added in v16.11.0
func NewSetConfigV1(cfg *config.Config) SetConfigV1
NewSetConfigV1 creates a new SetConfigV1 based on the current config with downgrading.
func (*SetConfigV1) MergeTo ¶ added in v16.11.0
func (s *SetConfigV1) MergeTo(cfg *config.Config)
MergeTo merges the v1 config into the current config.
type SetConfigV2 ¶ added in v16.11.0
func NewSetConfigV2 ¶ added in v16.11.0
func NewSetConfigV2(cfg *config.Config) SetConfigV2
NewSetConfigV2 creates a new SetConfigV2 based on the current config with downgrading.
func (*SetConfigV2) MergeTo ¶ added in v16.11.0
func (s *SetConfigV2) MergeTo(cfg *config.Config)
MergeTo merges the v2 config into the current config.
type Skills ¶
type Skills struct { FFmpeg struct { Version string `json:"version"` Compiler string `json:"compiler"` Configuration string `json:"configuration"` Libraries []SkillsLibrary `json:"libraries"` } `json:"ffmpeg"` Filters []SkillsFilter `json:"filter"` HWAccels []SkillsHWAccel `json:"hwaccels"` Codecs struct { Audio []SkillsCodec `json:"audio"` Video []SkillsCodec `json:"video"` Subtitle []SkillsCodec `json:"subtitle"` } `json:"codecs"` Devices struct { Demuxers []SkillsDevice `json:"demuxers"` Muxers []SkillsDevice `json:"muxers"` } `json:"devices"` Formats struct { Demuxers []SkillsFormat `json:"demuxers"` Muxers []SkillsFormat `json:"muxers"` } `json:"formats"` Protocols struct { Input []SkillsProtocol `json:"input"` Output []SkillsProtocol `json:"output"` } `json:"protocols"` }
Skills represents a set of ffmpeg capabilities
type SkillsCodec ¶
type SkillsCodec struct { ID string `json:"id"` Name string `json:"name"` Encoders []string `json:"encoders"` Decoders []string `json:"decoders"` }
SkillsCodec represents an ffmpeg codec
func (*SkillsCodec) Unmarshal ¶
func (s *SkillsCodec) Unmarshal(codec skills.Codec)
Unmarshal converts a skills codec to its API representation
type SkillsDevice ¶
type SkillsDevice struct { ID string `json:"id"` Name string `json:"name"` Devices []SkillsHWDevice `json:"devices"` }
SkillsDevice represents a group of ffmpeg hardware devices
func (*SkillsDevice) Unmarshal ¶
func (s *SkillsDevice) Unmarshal(device skills.Device)
Unmarshal converts a skills device to its API representation
type SkillsFilter ¶
SkillsFilter represents an ffmpeg filter
func (*SkillsFilter) Unmarshal ¶
func (s *SkillsFilter) Unmarshal(filter skills.Filter)
Unmarshal converts a skills filter to its API representation
type SkillsFormat ¶
SkillsFormat represents an ffmpeg format
func (*SkillsFormat) Unmarshal ¶
func (s *SkillsFormat) Unmarshal(format skills.Format)
Unmarshal converts a skills format to its API representation
type SkillsHWAccel ¶
SkillsHWAccel represents an ffmpeg HW accelerator
func (*SkillsHWAccel) Unmarshal ¶
func (s *SkillsHWAccel) Unmarshal(hwaccel skills.HWAccel)
Unmarshal converts a skills HWAccel to its API representation
type SkillsHWDevice ¶
type SkillsHWDevice struct { ID string `json:"id"` Name string `json:"name"` Extra string `json:"extra"` Media string `json:"media"` }
SkillsHWDevice represents an ffmpeg hardware device
func (*SkillsHWDevice) Unmarshal ¶
func (s *SkillsHWDevice) Unmarshal(hwdevice skills.HWDevice)
Unmarshal converts a skills HW device to its API representation
type SkillsLibrary ¶
type SkillsLibrary struct { Name string `json:"name"` Compiled string `json:"compiled"` Linked string `json:"linked"` }
SkillsLibrary represents an avlib ffmpeg is compiled and linked with
func (*SkillsLibrary) Unmarshal ¶
func (s *SkillsLibrary) Unmarshal(lib skills.Library)
Unmarshal converts a skills library to its API representation
type SkillsProtocol ¶
SkillsProtocol represents an ffmpeg protocol
func (*SkillsProtocol) Unmarshal ¶
func (s *SkillsProtocol) Unmarshal(proto skills.Protocol)
Unmarshal converts a skills protocol to its API representation
type Version ¶
type Version struct { Number string `json:"number"` Commit string `json:"repository_commit"` Branch string `json:"repository_branch"` Build string `json:"build_date"` Arch string `json:"arch"` Compiler string `json:"compiler"` }
Version is some information about the binary
type VersionMinimal ¶
type VersionMinimal struct {
Number string `json:"number"`
}