0

Do not support stream key UI or any persisted stream keys when overridden via cli flag. Closes #2749

This commit is contained in:
Gabe Kangas 2023-02-27 17:08:52 -08:00
parent 48dd490a50
commit 23a721857f
No known key found for this signature in database
GPG Key ID: 4345B2060657F330
6 changed files with 25 additions and 9 deletions

View File

@ -52,6 +52,7 @@ func GetServerConfig(w http.ResponseWriter, r *http.Request) {
FFmpegPath: ffmpeg, FFmpegPath: ffmpeg,
AdminPassword: data.GetAdminPassword(), AdminPassword: data.GetAdminPassword(),
StreamKeys: data.GetStreamKeys(), StreamKeys: data.GetStreamKeys(),
StreamKeyOverridden: config.TemporaryStreamKey != "",
WebServerPort: config.WebServerPort, WebServerPort: config.WebServerPort,
WebServerIP: config.WebServerIP, WebServerIP: config.WebServerIP,
RTMPServerPort: data.GetRTMPPortNumber(), RTMPServerPort: data.GetRTMPPortNumber(),
@ -101,6 +102,7 @@ type serverConfigAdminResponse struct {
FFmpegPath string `json:"ffmpegPath"` FFmpegPath string `json:"ffmpegPath"`
AdminPassword string `json:"adminPassword"` AdminPassword string `json:"adminPassword"`
StreamKeys []models.StreamKey `json:"streamKeys"` StreamKeys []models.StreamKey `json:"streamKeys"`
StreamKeyOverridden bool `json:"streamKeyOverridden"`
WebServerPort int `json:"webServerPort"` WebServerPort int `json:"webServerPort"`
WebServerIP string `json:"webServerIP"` WebServerIP string `json:"webServerIP"`
RTMPServerPort int `json:"rtmpServerPort"` RTMPServerPort int `json:"rtmpServerPort"`

View File

@ -81,6 +81,11 @@ func HandleConn(c *rtmp.Conn, nc net.Conn) {
accessGranted := false accessGranted := false
validStreamingKeys := data.GetStreamKeys() validStreamingKeys := data.GetStreamKeys()
// If a stream key override was specified then use that instead.
if config.TemporaryStreamKey != "" {
validStreamingKeys = []models.StreamKey{{Key: config.TemporaryStreamKey}}
}
for _, key := range validStreamingKeys { for _, key := range validStreamingKeys {
if secretMatch(key.Key, c.URL.Path) { if secretMatch(key.Key, c.URL.Path) {
accessGranted = true accessGranted = true
@ -88,11 +93,6 @@ func HandleConn(c *rtmp.Conn, nc net.Conn) {
} }
} }
// Test against the temporary key if it was set at runtime.
if config.TemporaryStreamKey != "" && secretMatch(config.TemporaryStreamKey, c.URL.Path) {
accessGranted = true
}
if !accessGranted { if !accessGranted {
log.Errorln("invalid streaming key; rejecting incoming stream") log.Errorln("invalid streaming key; rejecting incoming stream")
_ = nc.Close() _ = nc.Close()

View File

@ -44,7 +44,7 @@ export const Offline: FC<OfflineProps> = ({ logs = [], config }) => {
const serverStatusData = useContext(ServerStatusContext); const serverStatusData = useContext(ServerStatusContext);
const { serverConfig } = serverStatusData || {}; const { serverConfig } = serverStatusData || {};
const { rtmpServerPort } = serverConfig; const { rtmpServerPort, streamKeyOverridden } = serverConfig;
const instanceUrl = global.window?.location.hostname || ''; const instanceUrl = global.window?.location.hostname || '';
let rtmpURL; let rtmpURL;
@ -79,7 +79,13 @@ export const Offline: FC<OfflineProps> = ({ logs = [], config }) => {
Streaming Keys: Streaming Keys:
</Text> </Text>
<Text strong className="stream-info-box"> <Text strong className="stream-info-box">
{!streamKeyOverridden ? (
<Link href="/admin/config/server"> View </Link> <Link href="/admin/config/server"> View </Link>
) : (
<span style={{ paddingLeft: '10px', fontWeight: 'normal' }}>
Overridden via command line.
</span>
)}
</Text> </Text>
</div> </div>
</div> </div>

View File

@ -1,13 +1,19 @@
import React, { ReactElement } from 'react'; import React, { ReactElement, useContext } from 'react';
import { Tabs } from 'antd'; import { Tabs } from 'antd';
import StreamKeys from '../../../../components/admin/config/server/StreamKeys'; import StreamKeys from '../../../../components/admin/config/server/StreamKeys';
import ServerConfig from '../../../../components/admin/config/server/ServerConfig'; import ServerConfig from '../../../../components/admin/config/server/ServerConfig';
import StorageConfig from '../../../../components/admin/config/server/StorageConfig'; import StorageConfig from '../../../../components/admin/config/server/StorageConfig';
import { ServerStatusContext } from '../../../../utils/server-status-context';
import { AdminLayout } from '../../../../components/layouts/AdminLayout'; import { AdminLayout } from '../../../../components/layouts/AdminLayout';
export default function PublicFacingDetails() { export default function PublicFacingDetails() {
const serverStatusData = useContext(ServerStatusContext);
const { serverConfig } = serverStatusData || {};
const { streamKeyOverridden } = serverConfig;
return ( return (
<div className="config-public-details-page"> <div className="config-public-details-page">
<Tabs <Tabs
@ -19,7 +25,7 @@ export default function PublicFacingDetails() {
key: '1', key: '1',
children: <ServerConfig />, children: <ServerConfig />,
}, },
{ !streamKeyOverridden && {
label: `Stream Keys`, label: `Stream Keys`,
key: '2', key: '2',
children: <StreamKeys />, children: <StreamKeys />,

View File

@ -140,6 +140,7 @@ export interface ConfigDetails {
rtmpServerPort: string; rtmpServerPort: string;
s3: S3Field; s3: S3Field;
streamKeys: StreamKey[]; streamKeys: StreamKey[];
streamKeyOverridden: boolean;
adminPassword: string; adminPassword: string;
videoSettings: VideoSettingsFields; videoSettings: VideoSettingsFields;
webServerPort: string; webServerPort: string;

View File

@ -8,6 +8,7 @@ import { DEFAULT_VARIANT_STATE } from './config-constants';
export const initialServerConfigState: ConfigDetails = { export const initialServerConfigState: ConfigDetails = {
streamKeys: [], streamKeys: [],
streamKeyOverridden: false,
adminPassword: '', adminPassword: '',
instanceDetails: { instanceDetails: {
customStyles: '', customStyles: '',