Documentation ¶
Overview ¶
Package api implements various handlers for the API routes
Index ¶
- func Swagger(c echo.Context) error
- type AboutHandler
- type ConfigHandler
- type DiskFSHandler
- type GraphHandler
- type LogHandler
- type MemFSHandler
- type MetricsConfig
- type MetricsHandler
- type PlayoutHandler
- func (h *PlayoutHandler) EncodeErrorframe(c echo.Context) error
- func (h *PlayoutHandler) Keyframe(c echo.Context) error
- func (h *PlayoutHandler) ReopenInput(c echo.Context) error
- func (h *PlayoutHandler) SetErrorframe(c echo.Context) error
- func (h *PlayoutHandler) SetStream(c echo.Context) error
- func (h *PlayoutHandler) Status(c echo.Context) error
- type RTMPHandler
- type RestreamHandler
- func (h *RestreamHandler) Add(c echo.Context) error
- func (h *RestreamHandler) Command(c echo.Context) error
- func (h *RestreamHandler) Delete(c echo.Context) error
- func (h *RestreamHandler) Get(c echo.Context) error
- func (h *RestreamHandler) GetAll(c echo.Context) error
- func (h *RestreamHandler) GetConfig(c echo.Context) error
- func (h *RestreamHandler) GetMetadata(c echo.Context) error
- func (h *RestreamHandler) GetProcessMetadata(c echo.Context) error
- func (h *RestreamHandler) GetReport(c echo.Context) error
- func (h *RestreamHandler) GetState(c echo.Context) error
- func (h *RestreamHandler) Probe(c echo.Context) error
- func (h *RestreamHandler) ReloadSkills(c echo.Context) error
- func (h *RestreamHandler) SetMetadata(c echo.Context) error
- func (h *RestreamHandler) SetProcessMetadata(c echo.Context) error
- func (h *RestreamHandler) Skills(c echo.Context) error
- func (h *RestreamHandler) Update(c echo.Context) error
- type SRTHandler
- type SessionHandler
- type WidgetConfig
- type WidgetHandler
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
Types ¶
type AboutHandler ¶
type AboutHandler struct {
// contains filtered or unexported fields
}
The AboutHandler type provides handler functions for retrieving details about the API version and build infos.
func NewAbout ¶
func NewAbout(restream restream.Restreamer, auths []string) *AboutHandler
NewAbout returns a new About type
func (*AboutHandler) About ¶
func (p *AboutHandler) About(c echo.Context) error
About returns API version and build infos @Summary API version and build infos @Description API version and build infos in case auth is valid or not required. If auth is required, just the name field is populated. @ID about @Produce json @Success 200 {object} api.About @Security ApiKeyAuth @Router /api [get]
type ConfigHandler ¶
type ConfigHandler struct {
// contains filtered or unexported fields
}
The ConfigHandler type provides handler functions for reading and manipulating the current config.
func NewConfig ¶
func NewConfig(store cfgstore.Store) *ConfigHandler
NewConfig return a new Config type. You have to provide a valid config store.
func (*ConfigHandler) Get ¶
func (p *ConfigHandler) Get(c echo.Context) error
Get returns the currently active Restreamer configuration @Summary Retrieve the currently active Restreamer configuration @Description Retrieve the currently active Restreamer configuration @Tags v16.7.2 @ID config-3-get @Produce json @Success 200 {object} api.Config @Security ApiKeyAuth @Router /api/v3/config [get]
func (*ConfigHandler) Reload ¶
func (p *ConfigHandler) Reload(c echo.Context) error
Reload will reload the currently active configuration @Summary Reload the currently active configuration @Description Reload the currently active configuration. This will trigger a restart of the Restreamer. @Tags v16.7.2 @ID config-3-reload @Produce plain @Success 200 {string} string "OK" @Security ApiKeyAuth @Router /api/v3/config/reload [get]
func (*ConfigHandler) Set ¶
func (p *ConfigHandler) Set(c echo.Context) error
Set will set the given configuration as new active configuration @Summary Update the current Restreamer configuration @Description Update the current Restreamer configuration by providing a complete or partial configuration. Fields that are not provided will not be changed. @Tags v16.7.2 @ID config-3-set @Accept json @Produce json @Param config body api.SetConfig true "Restreamer configuration" @Success 200 {string} string @Failure 400 {object} api.Error @Failure 409 {object} api.ConfigError @Security ApiKeyAuth @Router /api/v3/config [put]
type DiskFSHandler ¶
type DiskFSHandler struct {
// contains filtered or unexported fields
}
The DiskFSHandler type provides handlers for manipulating a filesystem
func NewDiskFS ¶
func NewDiskFS(fs fs.Filesystem, cache cache.Cacher) *DiskFSHandler
NewDiskFS return a new DiskFS type. You have to provide a filesystem to act on and optionally a Cacher where files will be purged from if the Cacher is related to the filesystem.
func (*DiskFSHandler) DeleteFile ¶
func (h *DiskFSHandler) DeleteFile(c echo.Context) error
DeleteFile removes a file from the filesystem @Summary Remove a file from the filesystem @Description Remove a file from the filesystem @Tags v16.7.2 @ID diskfs-3-delete-file @Produce text/plain @Param path path string true "Path to file" @Success 200 {string} string @Failure 404 {object} api.Error @Security ApiKeyAuth @Router /api/v3/fs/disk/{path} [delete]
func (*DiskFSHandler) GetFile ¶
func (h *DiskFSHandler) GetFile(c echo.Context) error
GetFile returns the file at the given path @Summary Fetch a file from the filesystem @Description Fetch a file from the filesystem. The contents of that file are returned. @Tags v16.7.2 @ID diskfs-3-get-file @Produce application/data @Produce json @Param path path string true "Path to file" @Success 200 {file} byte @Success 301 {string} string @Failure 404 {object} api.Error @Security ApiKeyAuth @Router /api/v3/fs/disk/{path} [get]
func (*DiskFSHandler) ListFiles ¶
func (h *DiskFSHandler) ListFiles(c echo.Context) error
ListFiles lists all files on the filesystem @Summary List all files on the filesystem @Description List all files on the filesystem. The listing can be ordered by name, size, or date of last modification in ascending or descending order. @Tags v16.7.2 @ID diskfs-3-list-files @Produce json @Param glob query string false "glob pattern for file names" @Param sort query string false "none, name, size, lastmod" @Param order query string false "asc, desc" @Success 200 {array} api.FileInfo @Security ApiKeyAuth @Router /api/v3/fs/disk [get]
func (*DiskFSHandler) PutFile ¶
func (h *DiskFSHandler) PutFile(c echo.Context) error
PutFile adds or overwrites a file at the given path @Summary Add a file to the filesystem @Description Writes or overwrites a file on the filesystem @Tags v16.7.2 @ID diskfs-3-put-file @Accept application/data @Produce text/plain @Produce json @Param path path string true "Path to file" @Param data body []byte true "File data" @Success 201 {string} string @Success 204 {string} string @Failure 507 {object} api.Error @Security ApiKeyAuth @Router /api/v3/fs/disk/{path} [put]
type GraphHandler ¶
type GraphHandler struct {
// contains filtered or unexported fields
}
func NewGraph ¶
func NewGraph(resolver resolver.Resolver, path string) *GraphHandler
NewRestream return a new Restream type. You have to provide a valid Restreamer instance.
func (*GraphHandler) Playground ¶
func (g *GraphHandler) Playground(c echo.Context) error
Load GraphQL playground @Summary Load GraphQL playground @Description Load GraphQL playground @ID graph-playground @Produce html @Success 200 @Security ApiKeyAuth @Router /api/graph [get]
func (*GraphHandler) Query ¶
func (g *GraphHandler) Query(c echo.Context) error
Query the GraphAPI @Summary Query the GraphAPI @Description Query the GraphAPI @ID graph-query @Accept json @Produce json @Param query body api.GraphQuery true "GraphQL Query" @Success 200 {object} api.GraphResponse @Failure 400 {object} api.GraphResponse @Security ApiKeyAuth @Router /api/graph/query [post]
type LogHandler ¶
type LogHandler struct {
// contains filtered or unexported fields
}
The LogHandler type provides handler functions for reading the application log
func NewLog ¶
func NewLog(buffer log.BufferWriter) *LogHandler
NewLog return a new Log type. You have to provide log buffer.
func (*LogHandler) Log ¶
func (p *LogHandler) Log(c echo.Context) error
Log returns the last log lines of the Restreamer application @Summary Application log @Description Get the last log lines of the Restreamer application @Tags v16.7.2 @ID log-3 @Param format query string false "Format of the list of log events (*console, raw)" @Produce json @Success 200 {array} api.LogEvent "application log" @Success 200 {array} string "application log" @Security ApiKeyAuth @Router /api/v3/log [get]
type MemFSHandler ¶
type MemFSHandler struct {
// contains filtered or unexported fields
}
The MemFSHandler type provides handlers for manipulating a filesystem
func NewMemFS ¶
func NewMemFS(fs fs.Filesystem) *MemFSHandler
NewMemFS return a new MemFS type. You have to provide a filesystem to act on.
func (*MemFSHandler) DeleteFile ¶
func (h *MemFSHandler) DeleteFile(c echo.Context) error
DeleteFileAPI removes a file from the filesystem @Summary Remove a file from the memory filesystem @Description Remove a file from the memory filesystem @Tags v16.7.2 @ID memfs-3-delete-file @Produce text/plain @Param path path string true "Path to file" @Success 200 {string} string @Failure 404 {object} api.Error @Security ApiKeyAuth @Router /api/v3/fs/mem/{path} [delete]
func (*MemFSHandler) GetFile ¶
func (h *MemFSHandler) GetFile(c echo.Context) error
GetFileAPI returns the file at the given path @Summary Fetch a file from the memory filesystem @Description Fetch a file from the memory filesystem @Tags v16.7.2 @ID memfs-3-get-file @Produce application/data @Produce json @Param path path string true "Path to file" @Success 200 {file} byte @Success 301 {string} string @Failure 404 {object} api.Error @Security ApiKeyAuth @Router /api/v3/fs/mem/{path} [get]
func (*MemFSHandler) ListFiles ¶
func (h *MemFSHandler) ListFiles(c echo.Context) error
ListFiles lists all files on the filesystem @Summary List all files on the memory filesystem @Description List all files on the memory filesystem. The listing can be ordered by name, size, or date of last modification in ascending or descending order. @Tags v16.7.2 @ID memfs-3-list-files @Produce json @Param glob query string false "glob pattern for file names" @Param sort query string false "none, name, size, lastmod" @Param order query string false "asc, desc" @Success 200 {array} api.FileInfo @Security ApiKeyAuth @Router /api/v3/fs/mem [get]
func (*MemFSHandler) PatchFile ¶
func (h *MemFSHandler) PatchFile(c echo.Context) error
PatchFile creates a symbolic link to a file in the filesystem @Summary Create a link to a file in the memory filesystem @Description Create a link to a file in the memory filesystem. The file linked to has to exist. @Tags v16.7.2 @ID memfs-3-patch @Accept application/data @Produce text/plain @Produce json @Param path path string true "Path to file" @Param url body string true "Path to the file to link to" @Success 201 {string} string @Failure 400 {object} api.Error @Security ApiKeyAuth @Router /api/v3/fs/mem/{path} [patch]
func (*MemFSHandler) PutFile ¶
func (h *MemFSHandler) PutFile(c echo.Context) error
PutFileAPI adds or overwrites a file at the given path @Summary Add a file to the memory filesystem @Description Writes or overwrites a file on the memory filesystem @Tags v16.7.2 @ID memfs-3-put-file @Accept application/data @Produce text/plain @Produce json @Param path path string true "Path to file" @Param data body []byte true "File data" @Success 201 {string} string @Success 204 {string} string @Failure 507 {object} api.Error @Security ApiKeyAuth @Router /api/v3/fs/mem/{path} [put]
type MetricsConfig ¶
type MetricsConfig struct {
Metrics monitor.HistoryReader
}
type MetricsHandler ¶
type MetricsHandler struct {
// contains filtered or unexported fields
}
The MetricsHandler type provides handlers for the widget API
func NewMetrics ¶
func NewMetrics(config MetricsConfig) *MetricsHandler
NewWidget return a new Widget type
func (*MetricsHandler) Describe ¶ added in v16.10.0
func (r *MetricsHandler) Describe(c echo.Context) error
Describe the known metrics @Summary List all known metrics with their description and labels @Description List all known metrics with their description and labels @Tags v16.10.0 @ID metrics-3-describe @Produce json @Success 200 {array} api.MetricsDescription @Security ApiKeyAuth @Router /api/v3/metrics [get]
func (*MetricsHandler) Metrics ¶
func (r *MetricsHandler) Metrics(c echo.Context) error
Query the collected metrics @Summary Query the collected metrics @Description Query the collected metrics @Tags v16.7.2 @ID metrics-3-metrics @Accept json @Produce json @Param config body api.MetricsQuery true "Metrics query" @Success 200 {object} api.MetricsResponse @Failure 400 {object} api.Error @Security ApiKeyAuth @Router /api/v3/metrics [post]
type PlayoutHandler ¶
type PlayoutHandler struct {
// contains filtered or unexported fields
}
The PlayoutHandler type provides handlers for accessing the playout API of a process
func NewPlayout ¶
func NewPlayout(restream restream.Restreamer) *PlayoutHandler
NewPlayout returns a new Playout type. You have to provide a Restreamer instance.
func (*PlayoutHandler) EncodeErrorframe ¶
func (h *PlayoutHandler) EncodeErrorframe(c echo.Context) error
EncodeErrorframe encodes the errorframe @Summary Encode the errorframe @Description Immediately encode the errorframe (if available and looping) @Tags v16.7.2 @ID process-3-playout-errorframencode @Produce text/plain @Produce json @Param id path string true "Process ID" @Param inputid path string true "Process Input ID" @Success 204 {string} string @Failure 404 {object} api.Error @Failure 500 {object} api.Error @Security ApiKeyAuth @Router /api/v3/process/{id}/playout/{inputid}/errorframe/encode [get]
func (*PlayoutHandler) Keyframe ¶
func (h *PlayoutHandler) Keyframe(c echo.Context) error
Keyframe returns the last keyframe @Summary Get the last keyframe @Description Get the last keyframe of an input of a process. The extension of the name determines the return type. @Tags v16.7.2 @ID process-3-playout-keyframe @Produce image/jpeg @Produce image/png @Produce json @Param id path string true "Process ID" @Param inputid path string true "Process Input ID" @Param name path string true "Any filename with an extension of .jpg or .png" @Success 200 {file} byte @Failure 404 {object} api.Error @Failure 500 {object} api.Error @Security ApiKeyAuth @Router /api/v3/process/{id}/playout/{inputid}/keyframe/{name} [get]
func (*PlayoutHandler) ReopenInput ¶
func (h *PlayoutHandler) ReopenInput(c echo.Context) error
ReopenInput closes the current input stream @Summary Close the current input stream @Description Close the current input stream such that it will be automatically re-opened @Tags v16.7.2 @ID process-3-playout-reopen-input @Produce plain @Param id path string true "Process ID" @Param inputid path string true "Process Input ID" @Success 200 {string} string @Failure 404 {object} api.Error @Failure 500 {object} api.Error @Security ApiKeyAuth @Router /api/v3/process/{id}/playout/{inputid}/reopen [get]
func (*PlayoutHandler) SetErrorframe ¶
func (h *PlayoutHandler) SetErrorframe(c echo.Context) error
SetErrorframe sets an errorframe @Summary Upload an error frame @Description Upload an error frame which will be encoded immediately @Tags v16.7.2 @ID process-3-playout-errorframe @Produce text/plain @Produce json @Accept application/octet-stream @Param id path string true "Process ID" @Param inputid path string true "Process Input ID" @Param name path string true "Any filename with a suitable extension" @Param image body []byte true "Image to be used a error frame" @Success 204 {string} string @Failure 404 {object} api.Error @Failure 500 {object} api.Error @Security ApiKeyAuth @Router /api/v3/process/{id}/playout/{inputid}/errorframe/{name} [post]
func (*PlayoutHandler) SetStream ¶
func (h *PlayoutHandler) SetStream(c echo.Context) error
SetStream replaces the current stream @Summary Switch to a new stream @Description Replace the current stream with the one from the given URL. The switch will only happen if the stream parameters match. @Tags v16.7.2 @ID process-3-playout-stream @Produce text/plain @Produce json @Accept text/plain @Param id path string true "Process ID" @Param inputid path string true "Process Input ID" @Param url body string true "URL of the new stream" @Success 204 {string} string @Failure 404 {object} api.Error @Failure 500 {object} api.Error @Security ApiKeyAuth @Router /api/v3/process/{id}/playout/{inputid}/stream [put]
func (*PlayoutHandler) Status ¶
func (h *PlayoutHandler) Status(c echo.Context) error
Status return the current playout status @Summary Get the current playout status @Description Get the current playout status of an input of a process @Tags v16.7.2 @ID process-3-playout-status @Produce json @Param id path string true "Process ID" @Param inputid path string true "Process Input ID" @Success 200 {object} api.PlayoutStatus @Failure 404 {object} api.Error @Failure 500 {object} api.Error @Security ApiKeyAuth @Router /api/v3/process/{id}/playout/{inputid}/status [get]
type RTMPHandler ¶
type RTMPHandler struct {
// contains filtered or unexported fields
}
The RTMPHandler type provides a handler for retrieving details from the RTMPHandler server
func NewRTMP ¶
func NewRTMP(rtmp rtmp.Server) *RTMPHandler
NewRTMP returns a new RTMP type. You have to provide a RTMP server instance.
func (*RTMPHandler) ListChannels ¶
func (rtmph *RTMPHandler) ListChannels(c echo.Context) error
ListChannels lists all currently publishing RTMP streams @Summary List all publishing RTMP streams @Description List all currently publishing RTMP streams. @Tags v16.7.2 @ID rtmp-3-list-channels @Produce json @Success 200 {array} api.RTMPChannel @Security ApiKeyAuth @Router /api/v3/rtmp [get]
type RestreamHandler ¶
type RestreamHandler struct {
// contains filtered or unexported fields
}
The RestreamHandler type provides functions to interact with a Restreamer instance
func NewRestream ¶
func NewRestream(restream restream.Restreamer) *RestreamHandler
NewRestream return a new Restream type. You have to provide a valid Restreamer instance.
func (*RestreamHandler) Add ¶
func (h *RestreamHandler) Add(c echo.Context) error
Add adds a new process @Summary Add a new process @Description Add a new FFmpeg process @Tags v16.7.2 @ID process-3-add @Accept json @Produce json @Param config body api.ProcessConfig true "Process config" @Success 200 {object} api.ProcessConfig @Failure 400 {object} api.Error @Security ApiKeyAuth @Router /api/v3/process [post]
func (*RestreamHandler) Command ¶
func (h *RestreamHandler) Command(c echo.Context) error
Command issues a command to a process @Summary Issue a command to a process @Description Issue a command to a process: start, stop, reload, restart @Tags v16.7.2 @ID process-3-command @Accept json @Produce json @Param id path string true "Process ID" @Param command body api.Command true "Process command" @Success 200 {string} string @Failure 400 {object} api.Error @Failure 404 {object} api.Error @Security ApiKeyAuth @Router /api/v3/process/{id}/command [put]
func (*RestreamHandler) Delete ¶
func (h *RestreamHandler) Delete(c echo.Context) error
Delete deletes the process with the given ID @Summary Delete a process by its ID @Description Delete a process by its ID @Tags v16.7.2 @ID process-3-delete @Produce json @Param id path string true "Process ID" @Success 200 {string} string @Failure 404 {object} api.Error @Security ApiKeyAuth @Router /api/v3/process/{id} [delete]
func (*RestreamHandler) Get ¶
func (h *RestreamHandler) Get(c echo.Context) error
Get returns the process with the given ID @Summary List a process by its ID @Description List a process by its ID. Use the filter parameter to specifiy the level of detail of the output. @Tags v16.7.2 @ID process-3-get @Produce json @Param id path string true "Process ID" @Param filter query string false "Comma separated list of fields (config, state, report, metadata) to be part of the output. If empty, all fields will be part of the output" @Success 200 {object} api.Process @Failure 404 {object} api.Error @Security ApiKeyAuth @Router /api/v3/process/{id} [get]
func (*RestreamHandler) GetAll ¶
func (h *RestreamHandler) GetAll(c echo.Context) error
GetAll returns all known processes @Summary List all known processes @Description List all known processes. Use the query parameter to filter the listed processes. @Tags v16.7.2 @ID process-3-get-all @Produce json @Param filter query string false "Comma separated list of fields (config, state, report, metadata) that will be part of the output. If empty, all fields will be part of the output." @Param reference query string false "Return only these process that have this reference value. If empty, the reference will be ignored." @Param id query string false "Comma separated list of process ids to list. Overrides the reference. If empty all IDs will be returned." @Param idpattern query string false "Glob pattern for process IDs. If empty all IDs will be returned. Intersected with results from refpattern." @Param refpattern query string false "Glob pattern for process references. If empty all IDs will be returned. Intersected with results from idpattern." @Success 200 {array} api.Process @Security ApiKeyAuth @Router /api/v3/process [get]
func (*RestreamHandler) GetConfig ¶
func (h *RestreamHandler) GetConfig(c echo.Context) error
GetConfig returns the configuration of a process @Summary Get the configuration of a process @Description Get the configuration of a process. This is the configuration as provided by Add or Update. @Tags v16.7.2 @ID process-3-get-config @Produce json @Param id path string true "Process ID" @Success 200 {object} api.ProcessConfig @Failure 404 {object} api.Error @Failure 400 {object} api.Error @Security ApiKeyAuth @Router /api/v3/process/{id}/config [get]
func (*RestreamHandler) GetMetadata ¶
func (h *RestreamHandler) GetMetadata(c echo.Context) error
GetMetadata returns the metadata stored with the Restreamer @Summary Retrieve JSON metadata from a key @Description Retrieve the previously stored JSON metadata under the given key. If the key is empty, all metadata will be returned. @Tags v16.7.2 @ID metadata-3-get @Produce json @Param key path string true "Key for data store" @Success 200 {object} api.Metadata @Failure 404 {object} api.Error @Failure 400 {object} api.Error @Security ApiKeyAuth @Router /api/v3/metadata/{key} [get]
func (*RestreamHandler) GetProcessMetadata ¶
func (h *RestreamHandler) GetProcessMetadata(c echo.Context) error
GetProcessMetadata returns the metadata stored with a process @Summary Retrieve JSON metadata stored with a process under a key @Description Retrieve the previously stored JSON metadata under the given key. If the key is empty, all metadata will be returned. @Tags v16.7.2 @ID process-3-get-process-metadata @Produce json @Param id path string true "Process ID" @Param key path string true "Key for data store" @Success 200 {object} api.Metadata @Failure 404 {object} api.Error @Failure 400 {object} api.Error @Security ApiKeyAuth @Router /api/v3/process/{id}/metadata/{key} [get]
func (*RestreamHandler) GetReport ¶
func (h *RestreamHandler) GetReport(c echo.Context) error
GetReport return the current log and the log history of a process @Summary Get the logs of a process @Description Get the logs and the log history of a process. @Tags v16.7.2 @ID process-3-get-report @Produce json @Param id path string true "Process ID" @Success 200 {object} api.ProcessReport @Failure 404 {object} api.Error @Failure 400 {object} api.Error @Security ApiKeyAuth @Router /api/v3/process/{id}/report [get]
func (*RestreamHandler) GetState ¶
func (h *RestreamHandler) GetState(c echo.Context) error
GetState returns the current state of a process @Summary Get the state of a process @Description Get the state and progress data of a process. @Tags v16.7.2 @ID process-3-get-state @Produce json @Param id path string true "Process ID" @Success 200 {object} api.ProcessState @Failure 404 {object} api.Error @Failure 400 {object} api.Error @Security ApiKeyAuth @Router /api/v3/process/{id}/state [get]
func (*RestreamHandler) Probe ¶
func (h *RestreamHandler) Probe(c echo.Context) error
Probe probes a process @Summary Probe a process @Description Probe an existing process to get a detailed stream information on the inputs. @Tags v16.7.2 @ID process-3-probe @Produce json @Param id path string true "Process ID" @Success 200 {object} api.Probe @Security ApiKeyAuth @Router /api/v3/process/{id}/probe [get]
func (*RestreamHandler) ReloadSkills ¶
func (h *RestreamHandler) ReloadSkills(c echo.Context) error
ReloadSkills will refresh the FFmpeg capabilities @Summary Refresh FFmpeg capabilities @Description Refresh the available FFmpeg capabilities. @Tags v16.7.2 @ID skills-3-reload @Produce json @Success 200 {object} api.Skills @Security ApiKeyAuth @Router /api/v3/skills/reload [get]
func (*RestreamHandler) SetMetadata ¶
func (h *RestreamHandler) SetMetadata(c echo.Context) error
SetMetadata stores metadata with the Restreamer @Summary Add JSON metadata under the given key @Description Add arbitrary JSON metadata under the given key. If the key exists, all already stored metadata with this key will be overwritten. If the key doesn't exist, it will be created. @Tags v16.7.2 @ID metadata-3-set @Produce json @Param key path string true "Key for data store" @Param data body api.Metadata true "Arbitrary JSON data" @Success 200 {object} api.Metadata @Failure 400 {object} api.Error @Security ApiKeyAuth @Router /api/v3/metadata/{key} [put]
func (*RestreamHandler) SetProcessMetadata ¶
func (h *RestreamHandler) SetProcessMetadata(c echo.Context) error
SetProcessMetadata stores metadata with a process @Summary Add JSON metadata with a process under the given key @Description Add arbitrary JSON metadata under the given key. If the key exists, all already stored metadata with this key will be overwritten. If the key doesn't exist, it will be created. @Tags v16.7.2 @ID process-3-set-process-metadata @Produce json @Param id path string true "Process ID" @Param key path string true "Key for data store" @Param data body api.Metadata true "Arbitrary JSON data. The null value will remove the key and its contents" @Success 200 {object} api.Metadata @Failure 404 {object} api.Error @Failure 400 {object} api.Error @Security ApiKeyAuth @Router /api/v3/process/{id}/metadata/{key} [put]
func (*RestreamHandler) Skills ¶
func (h *RestreamHandler) Skills(c echo.Context) error
Skills returns the detected FFmpeg capabilities @Summary FFmpeg capabilities @Description List all detected FFmpeg capabilities. @Tags v16.7.2 @ID skills-3 @Produce json @Success 200 {object} api.Skills @Security ApiKeyAuth @Router /api/v3/skills [get]
func (*RestreamHandler) Update ¶
func (h *RestreamHandler) Update(c echo.Context) error
Update replaces an existing process @Summary Replace an existing process @Description Replace an existing process. @Tags v16.7.2 @ID process-3-update @Accept json @Produce json @Param id path string true "Process ID" @Param config body api.ProcessConfig true "Process config" @Success 200 {object} api.ProcessConfig @Failure 400 {object} api.Error @Failure 404 {object} api.Error @Security ApiKeyAuth @Router /api/v3/process/{id} [put]
type SRTHandler ¶
type SRTHandler struct {
// contains filtered or unexported fields
}
The SRTHandler type provides a handler for retrieving details from the SRTHandler server
func NewSRT ¶
func NewSRT(srt srt.Server) *SRTHandler
NewSRT returns a new SRT type. You have to provide a SRT server instance.
func (*SRTHandler) ListChannels ¶
func (srth *SRTHandler) ListChannels(c echo.Context) error
ListChannels lists all currently publishing SRT streams @Summary List all publishing SRT treams @Description List all currently publishing SRT streams. This endpoint is EXPERIMENTAL and may change in future. @Tags v16.9.0 @ID srt-3-list-channels @Produce json @Success 200 {array} api.SRTChannels @Security ApiKeyAuth @Router /api/v3/srt [get]
type SessionHandler ¶
type SessionHandler struct {
// contains filtered or unexported fields
}
The SessionHandler type provides handlers to retrieve session information
func NewSession ¶
func NewSession(registry session.RegistryReader) *SessionHandler
NewSession returns a new Session type. You have to provide a session registry.
func (*SessionHandler) Active ¶
func (s *SessionHandler) Active(c echo.Context) error
Active returns a list of active sessions @Summary Get a minimal summary of all active sessions @Description Get a minimal summary of all active sessions (i.e. number of sessions, bandwidth). @Tags v16.7.2 @ID session-3-current @Produce json @Security ApiKeyAuth @Param collectors query string false "Comma separated list of collectors" @Success 200 {object} api.SessionsActive "Active sessions listing" @Router /api/v3/session/active [get]
func (*SessionHandler) Summary ¶
func (s *SessionHandler) Summary(c echo.Context) error
Summary returns a summary of all active and past sessions @Summary Get a summary of all active and past sessions @Description Get a summary of all active and past sessions of the given collector. @Tags v16.7.2 @ID session-3-summary @Produce json @Security ApiKeyAuth @Param collectors query string false "Comma separated list of collectors" @Success 200 {object} api.SessionsSummary "Sessions summary" @Router /api/v3/session [get]
type WidgetConfig ¶
type WidgetConfig struct { Restream restream.Restreamer Registry session.RegistryReader }
type WidgetHandler ¶
type WidgetHandler struct {
// contains filtered or unexported fields
}
The WidgetHandler type provides handlers for the widget API
func NewWidget ¶
func NewWidget(config WidgetConfig) *WidgetHandler
NewWidget return a new Widget type
func (*WidgetHandler) Get ¶
func (w *WidgetHandler) Get(c echo.Context) error
Get returns minimal public statistics about a process @Summary Fetch minimal statistics about a process @Description Fetch minimal statistics about a process, which is not protected by any auth. @Tags v16.7.2 @ID widget-3-get @Produce json @Param id path string true "ID of a process" @Success 200 {object} api.WidgetProcess @Failure 404 {object} api.Error @Router /api/v3/widget/process/{id} [get]