mirror of
https://github.com/blakeblackshear/frigate.git
synced 2025-12-21 12:36:42 +03:00
Some checks are pending
CI / AMD64 Build (push) Waiting to run
CI / ARM Build (push) Waiting to run
CI / Jetson Jetpack 6 (push) Waiting to run
CI / AMD64 Extra Build (push) Blocked by required conditions
CI / ARM Extra Build (push) Blocked by required conditions
CI / Synaptics Build (push) Blocked by required conditions
CI / Assemble and push default build (push) Blocked by required conditions
* add reusable component for combined name / internal name form field * fix labels * refactor utilities * refactor image picker * lazy loading * don't clear text box * trigger wizard * image picker fixes * use name and ID field in trigger edit dialog * ensure wizard resets when reopening * icon size tweak * multiple triggers can trigger at once * remove scrolling * mobile tweaks * remove duplicated component * fix types * use table on desktop and keep cards on mobile * provide default
74 lines
1.9 KiB
TypeScript
74 lines
1.9 KiB
TypeScript
import { generateFixedHash, isValidId } from "./stringUtil";
|
|
|
|
/**
|
|
* Processes a user-entered camera name and returns both the final camera name
|
|
* and friendly name for Frigate configuration.
|
|
*
|
|
* @param userInput - The name entered by the user (could be display name)
|
|
* @returns Object with finalCameraName and friendlyName
|
|
*/
|
|
export function processCameraName(userInput: string): {
|
|
finalCameraName: string;
|
|
friendlyName?: string;
|
|
} {
|
|
const normalizedInput = userInput.replace(/\s+/g, "_").toLowerCase();
|
|
|
|
if (isValidId(normalizedInput)) {
|
|
return {
|
|
finalCameraName: normalizedInput,
|
|
friendlyName: userInput.includes(" ") ? userInput : undefined,
|
|
};
|
|
}
|
|
|
|
return {
|
|
finalCameraName: generateFixedHash(userInput, "cam"),
|
|
friendlyName: userInput,
|
|
};
|
|
}
|
|
|
|
// ==================== Reolink Camera Detection ====================
|
|
|
|
/**
|
|
* Detect Reolink camera capabilities and recommend optimal protocol
|
|
*
|
|
* Calls the Frigate backend API which queries the Reolink camera to determine
|
|
* its resolution and recommends either http-flv (for 5MP and below) or rtsp
|
|
* (for higher resolutions).
|
|
*
|
|
* @param host - Camera IP address or hostname
|
|
* @param username - Camera username
|
|
* @param password - Camera password
|
|
* @returns The recommended protocol key ("http-flv" or "rtsp"), or null if detection failed
|
|
*/
|
|
export async function detectReolinkCamera(
|
|
host: string,
|
|
username: string,
|
|
password: string,
|
|
): Promise<"http-flv" | "rtsp" | null> {
|
|
try {
|
|
const params = new URLSearchParams({
|
|
host,
|
|
username,
|
|
password,
|
|
});
|
|
|
|
const response = await fetch(`/api/reolink/detect?${params.toString()}`, {
|
|
method: "GET",
|
|
});
|
|
|
|
if (!response.ok) {
|
|
return null;
|
|
}
|
|
|
|
const data = await response.json();
|
|
|
|
if (data.success && data.protocol) {
|
|
return data.protocol;
|
|
}
|
|
|
|
return null;
|
|
} catch (error) {
|
|
return null;
|
|
}
|
|
}
|