Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 8 additions & 0 deletions __tests__/call.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -204,6 +204,14 @@ describe('call API', () => {
expect(response.call.settings.backstage.enabled).toBe(true);
});

it('generate SRT credentials', () => {
const creds = call.createSRTCredetials('john');

expect(creds).toBeDefined();
expect(creds.address).toBeDefined();
expect(creds.address).not.toBe('');
});

it('go live', async () => {
const response = await call.goLive();

Expand Down
57 changes: 56 additions & 1 deletion src/StreamCall.ts
Original file line number Diff line number Diff line change
@@ -1,8 +1,25 @@
import { GetOrCreateCallRequest, QueryCallMembersRequest } from './gen/models';
import { VideoApi } from './gen-imports';
import {
CallResponse,
GetOrCreateCallRequest,
QueryCallMembersRequest,
} from './gen/models';
import { CallApi } from './gen/video/CallApi';
import { StreamClient } from './StreamClient';
import { OmitTypeId } from './types';

export class StreamCall extends CallApi {
data?: CallResponse;

constructor(
videoApi: VideoApi,
readonly type: string,
readonly id: string,
private readonly streamClient: StreamClient,
) {
super(videoApi, type, id);
}

get cid() {
return `${this.type}:${this.id}`;
}
Expand All @@ -16,4 +33,42 @@ export class StreamCall extends CallApi {
...(request ?? {}),
});
};

getOrCreate = async (request?: GetOrCreateCallRequest) => {
const response = await super.getOrCreate(request);
this.data = response.call;
return response;
};

get = async () => {
const response = await super.get();
this.data = response.call;
return response;
};

createSRTCredetials = (
userID: string,
): {
address: string;
} => {
if (!this.data) {
throw new Error(
'Object is not initialized, call get() or getOrCreate() first',
);
}

const token = this.streamClient.generatePermanentUserToken({
user_id: userID,
});
const segments = token.split('.');
if (segments.length !== 3) {
throw new Error('Invalid token format');
}

return {
address: this.data.ingress.srt.address
.replace('{passphrase}', segments[2])
.replace('{token}', token),
};
};
}
18 changes: 18 additions & 0 deletions src/StreamClient.ts
Original file line number Diff line number Diff line change
Expand Up @@ -145,6 +145,24 @@ export class StreamClient extends CommonApi {
return JWTUserToken(this.secret, payload as UserTokenPayload);
};

/**
*
* @param payload
* - user_id - the id of the user the token is for
* - iat - issued at date of the token, unix timestamp in seconds, by default it's now
*/
generatePermanentUserToken = (
payload: {
user_id: string;
iat?: number;
} & Record<string, unknown>,
) => {
const defaultIat = Math.floor((Date.now() - 1000) / 1000);
payload.iat = payload.iat ?? defaultIat;

return JWTUserToken(this.secret, payload as UserTokenPayload);
};

/**
*
* @param payload
Expand Down
2 changes: 1 addition & 1 deletion src/StreamVideoClient.ts
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ export class StreamVideoClient extends VideoApi {
}

call = (type: string, id: string) => {
return new StreamCall(this, type, id);
return new StreamCall(this, type, id, this.streamClient);
};

connectOpenAi = async (options: {
Expand Down
3 changes: 2 additions & 1 deletion src/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ export interface ApiConfig {
/** The timeout for requests in milliseconds. The default is 3000. */
timeout: number;
agent?: RequestInit['dispatcher'];
secret?: string;
}

export interface RequestMetadata {
Expand Down Expand Up @@ -39,7 +40,7 @@ export interface RateLimit {

interface BaseTokenPayload {
user_id: string;
exp: number;
exp?: number;
iat: number;
call_cids?: string[];
}
Expand Down
2 changes: 1 addition & 1 deletion src/utils/create-token.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ export function JWTUserToken(
apiSecret: Secret,
payload: {
user_id: string;
exp: number;
exp?: number;
iat: number;
call_cids?: string[];
} & { [key: string]: any },
Expand Down
Loading