update version to 2025.0.2, enhance build scripts, add type exports, and improve reporting interfaces

This commit is contained in:
2025-08-18 02:03:47 -04:00
parent 5f73c1e5c4
commit 2a76c41960
6 changed files with 92 additions and 65 deletions

View File

@@ -1,11 +1,11 @@
import {PCastApi} from '../dist/node/index.js';
const applicationCredentials = {
id: 'phenixrts.com-alex.zinn',
secret: 'AMAsDzr.dIuGMZ.Zu52Dt~MQvP!DZwYg'
}
id: 'phenixrts.com-alex.zinn',
secret: 'AMAsDzr.dIuGMZ.Zu52Dt~MQvP!DZwYg'
};
const pcastUri = 'https://pcast-stg.phenixrts.com';
const pcastApi = new PCastApi(pcastUri, applicationCredentials);
pcastApi.channels.list().then(console.log);
pcastApi.channels.list().then(console.log);

View File

@@ -1,13 +1,20 @@
{
"name": "@techniker-me/pcast-api",
"version": "2025.0.1",
"version": "2025.0.2",
"module": "src/index.ts",
"type": "module",
"scripts": {
"clean": "bash scripts/clean.sh",
"ci-build": "bun run build:node && bun run build:browser",
"format": "prettier --write ./",
"test": "bun test",
"test:watch": "bun test --watch",
"test:coverage": "bun test --coverage",
"build": "bun run build:node && bun run build:browser && bun run build:types",
"ci-build": "bun run build:node && bun run build:browser && bun run build:types",
"build:node": "bun build src/index.ts --outdir dist/node --target node --format esm --minify --production",
"build:browser": "bun build src/index.ts --outdir dist/browser --target browser --format esm --minify --production"
"build:browser": "bun build src/index.ts --outdir dist/browser --target browser --format esm --minify --production",
"build:types": "tsc --outDir dist/types",
"prepublishOnly": "bun run build",
"clean": "rm -rf dist"
},
"devDependencies": {
"@types/bun": "latest",
@@ -19,10 +26,19 @@
"peerDependencies": {
"typescript": "^5"
},
"exports": {
".": {
"types": "./dist/types/index.d.ts",
"import": "./dist/node/index.js",
"default": "./dist/node/index.js"
},
"./browser": "./dist/browser/index.js"
},
"publishConfig": {
"registry": "https://registry-node.techniker.me"
},
"dependencies": {
"@types/node": "24.3.0"
"@types/node": "24.3.0",
"phenix-edge-auth": "1.2.7"
}
}
}

View File

@@ -17,3 +17,11 @@ export interface ChannelsResponse extends IResponse<'channels', Channel[]> {
export interface MembersResponse extends IResponse<'members', Channel[]> {
members: Channel[];
}
export interface PublishingReportResponse extends IResponse<'publishingReport', string> {
publishingReport: string;
}
export interface ViewingReportResponse extends IResponse<'viewingReport', string> {
viewingReport: string;
}

View File

@@ -1,7 +1,7 @@
import assertUnreachable from '../lang/assertUnreachable';
import {HttpMethod} from '../net/http/HttpMethod';
import type IResponse from './IResponse';
import type { PCastHttpRequests } from './PCastRequests';
import type {PCastHttpRequests} from './PCastRequests';
import type {PublishingReportResponse, ViewingReportResponse} from './IResponse';
import assertUnreachable from '../lang/assertUnreachable';
export enum ReportKind {
Publishing = 0,
@@ -42,7 +42,7 @@ export type PublishingReportOptions = {
channelIds?: string[];
channelAliases?: string[];
roomIds?: string[];
roomAliases?:string[];
roomAliases?: string[];
tags?: string[];
start: string;
end: string;
@@ -57,7 +57,7 @@ export enum ViewingReportKind {
export type ViewingReportKindType = 'RealTime' | 'HLS' | 'DASH';
export type ViewingReportOptions = {
kind: ViewingReportKind,
kind: ViewingReportKind;
applicationIds?: string[];
streamIds?: string[];
sessionIds?: string[];
@@ -66,15 +66,12 @@ export type ViewingReportOptions = {
channelIds?: string[];
channelAliases?: string[];
roomIds?: string[];
roomAliases?:string[];
roomAliases?: string[];
tags?: string[];
start: string;
end: string;
};
export class Reporting {
private readonly _httpRequests: PCastHttpRequests;
@@ -97,36 +94,44 @@ export class Reporting {
}
public async requestPublishingReport(options: PublishingReportOptions): Promise<string> {
if (!(options.start || options.end)) {
throw new Error('[Reporting] [requestPublishingReport] requires a start and end Date');
}
const publishingReportOptions = {
...options
...options
};
const requestPublishingOptions = {
body: JSON.stringify({publishingReport: publishingReportOptions})
body: JSON.stringify({publishingReport: publishingReportOptions})
};
const response = await this._httpRequests.request<IResponse<'publishingReport', string>>(HttpMethod.PUT, '/pcast/reporting/publishing', requestPublishingOptions);
return response;
const response = await this._httpRequests.request<PublishingReportResponse>(
HttpMethod.PUT,
'/pcast/reporting/publishing',
requestPublishingOptions
);
if (!response.publishingReport) {
throw new Error('[Reporting] [requestPublishingReport] Invalid response format - missing publishingReport data');
}
private async requestViewingReport(options: ViewingReportOptions): Promise<string> {
const viewingReportOptions = {
...options
};
const requestViewingOptions = {
body: JSON.stringify({viewingReport: viewingReportOptions})
};
return response.publishingReport;
}
const response = await this._httpRequests.request<IResponse<'viewingReport', string>>(HttpMethod.PUT, '/pcast/reporting/viewing', requestViewingOptions);
private async requestViewingReport(options: ViewingReportOptions): Promise<string> {
const viewingReportOptions = {
...options
};
return response;
const requestViewingOptions = {
body: JSON.stringify({viewingReport: viewingReportOptions})
};
const response = await this._httpRequests.request<ViewingReportResponse>(HttpMethod.PUT, '/pcast/reporting/viewing', requestViewingOptions);
if (!response.viewingReport) {
throw new Error('[Reporting] [requestViewingReport] Invalid response format - missing viewingReport data');
}
return response.viewingReport;
}
}

View File

@@ -1,33 +1,29 @@
import { HttpMethod } from "../net/http/HttpMethod";
import type IResponse from "./IResponse";
import type { PCastHttpRequests } from "./PCastRequests";
import {HttpMethod} from '../net/http/HttpMethod';
import type IResponse from './IResponse';
import type {PCastHttpRequests} from './PCastRequests';
export class Streams {
private readonly _httpRequests: PCastHttpRequests;
private readonly _httpRequests: PCastHttpRequests;
constructor(httpRequests: PCastHttpRequests) {
this._httpRequests = httpRequests;
constructor(httpRequests: PCastHttpRequests) {
this._httpRequests = httpRequests;
}
public async publishUri(mediaUri: string, token: string) {
const mediaType = mediaUri.split('.')?.at(-1);
if (!mediaType) {
throw new Error('Invalid media URI no media type found');
}
const response = await this._httpRequests.request<IResponse<'publishUri', string>>(HttpMethod.PUT, `/stream/publish/uri/${mediaType}`, {
body: JSON.stringify({
token,
uri: mediaUri,
options: []
})
});
public async publishUri(mediaUri: string, token: string) {
const mediaType = mediaUri.split('.')?.at(-1);
if (!mediaType) {
throw new Error('Invalid media URI no media type found');
}
const response = await this._httpRequests.request<IResponse<'publishUri', string>>(HttpMethod.PUT, `/stream/publish/uri/${mediaType}`, {
body: JSON.stringify({
token,
uri: mediaUri,
options: []
})
});
return response;
}
}
return response;
}
}

View File

@@ -25,5 +25,7 @@
"noUnusedLocals": false,
"noUnusedParameters": false,
"noPropertyAccessFromIndexSignature": false
}
}
},
"include": ["src"],
"exclude": ["test", "dist", "node_modules"]
}