Stream middleware
Stream middleware in Fishjam allows you to intercept and manipulate media tracks before they are sent to the Fishjam server. This feature is powerful for applying effects, custom encodings, or any other transformations to the media stream.
Overview
Define a TrackMiddleware
function which takes a MediaStreamTrack
and returns an object containing the modified MediaStreamTrack
and an optional onClear
function, which is called when the middleware needs to be removed or reapplied when a device changes.
Type definition
export type TrackMiddleware = (
track: MediaStreamTrack,
) => { track: MediaStreamTrack; onClear?: () => void } | null;
Setting middleware
You can set the middleware for your media tracks using setTrackMiddleware
method. This method accepts a TrackMiddleware
or null
for removing previously set middleware.
Example: Applying a blur effect
The following example demonstrates how to apply a custom blur effect to the camera track using the useCamera
hook and middleware.
import { useCallback, useEffect, useRef } from "react";
import type { TrackMiddleware } from "@fishjam-cloud/react-client";
import { useCamera } from "@fishjam-cloud/react-client";
import { BlurProcessor } from "path-to-blur-processor"; // Adjust import based on actual implementation
export function CameraWithBlurEffect() {
const videoRef = useRef<HTMLVideoElement>(null);
const { stream, currentMiddleware, setTrackMiddleware } = useCamera();
useEffect(() => {
if (!videoRef.current) return;
videoRef.current.srcObject = stream ?? null;
}, [stream]);
// Define blur middleware
const blurMiddleware: TrackMiddleware = useCallback(
(track: MediaStreamTrack) => {
const streamToBlur = new MediaStream([track]);
const blurProcessor = new BlurProcessor(streamToBlur);
return {
track: blurProcessor.track,
onClear: () => blurProcessor.destroy(),
};
},
[],
);
// Check if the current middleware is blur
const isBlurEnabled = currentMiddleware === blurMiddleware;
// Toggle blur effect
const toggleBlur = () => {
setTrackMiddleware(isBlurEnabled ? null : blurMiddleware);
};
return (
<>
<button onClick={toggleBlur}>
{isBlurEnabled ? "Disable Blur" : "Enable Blur"}
</button>
{stream && <video ref={videoRef} />}
</>
);
}
This example provides a button to toggle the blur effect on and off. The BlurProcessor
handles the actual processing logic and is assumed to be implemented elsewhere.