datarhei-dragonfork-core/http/api/avstream.go

57 lines
1.4 KiB
Go
Raw Normal View History

2022-05-13 13:26:45 -04:00
package api
import (
"github.com/datarhei/core/v16/restream/app"
2022-05-13 13:26:45 -04:00
)
type AVstreamIO struct {
State string `json:"state" enums:"running,idle" jsonschema:"enum=running,enum=idle"`
Packet uint64 `json:"packet" format:"uint64"`
2022-05-13 13:26:45 -04:00
Time uint64 `json:"time"`
Size uint64 `json:"size_kb"`
}
func (i *AVstreamIO) Unmarshal(io *app.AVstreamIO) {
if io == nil {
return
}
i.State = io.State
i.Packet = io.Packet
i.Time = io.Time
i.Size = io.Size
}
type AVstream struct {
2023-05-05 06:03:48 -04:00
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"`
2022-05-13 13:26:45 -04:00
}
func (a *AVstream) Unmarshal(av *app.AVstream) {
if av == nil {
return
}
a.Aqueue = av.Aqueue
a.Queue = av.Queue
a.Dup = av.Dup
a.Drop = av.Drop
a.Enc = av.Enc
a.Looping = av.Looping
2023-05-05 06:03:48 -04:00
a.LoopingRuntime = av.LoopingRuntime
2022-05-13 13:26:45 -04:00
a.Duplicating = av.Duplicating
a.GOP = av.GOP
a.Input.Unmarshal(&av.Input)
a.Output.Unmarshal(&av.Output)
}