camstreamerlib 4.0.0-beta.62 → 4.0.0-beta.64

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (98) hide show
  1. package/README.md +1 -0
  2. package/cjs/CamOverlayAPI.d.ts +867 -0
  3. package/cjs/CamOverlayAPI.js +5 -5
  4. package/cjs/CamScripterAPI.d.ts +46 -0
  5. package/cjs/CamScripterAPI.js +2 -3
  6. package/cjs/CamStreamerAPI.d.ts +64 -0
  7. package/cjs/CamStreamerAPI.js +1 -2
  8. package/cjs/CamSwitcherAPI.d.ts +167 -0
  9. package/cjs/CamSwitcherAPI.js +2 -2
  10. package/cjs/PlaneTrackerAPI.d.ts +229 -0
  11. package/cjs/PlaneTrackerAPI.js +8 -8
  12. package/cjs/VapixAPI.d.ts +118 -0
  13. package/cjs/VapixAPI.js +10 -10
  14. package/cjs/bin/CreatePackage.d.ts +1 -0
  15. package/cjs/errors/errors.d.ts +91 -0
  16. package/cjs/errors/errors.js +32 -26
  17. package/cjs/index.d.ts +27 -0
  18. package/cjs/internal/ProxyClient.d.ts +10 -0
  19. package/cjs/internal/WsEvents.d.ts +37 -0
  20. package/cjs/internal/constants.d.ts +1 -0
  21. package/cjs/internal/transformers.d.ts +5 -0
  22. package/cjs/internal/types.d.ts +47 -0
  23. package/cjs/internal/utils.d.ts +13 -0
  24. package/cjs/internal/utils.js +1 -16
  25. package/cjs/internal/versionCompare.d.ts +6 -0
  26. package/cjs/node/CamOverlayDrawingAPI.d.ts +41 -0
  27. package/cjs/node/CamOverlayPainter/Frame.d.ts +67 -0
  28. package/cjs/node/CamOverlayPainter/Painter.d.ts +32 -0
  29. package/cjs/node/CamOverlayPainter/ResourceManager.d.ts +15 -0
  30. package/cjs/node/CamScripterAPICameraEventsGenerator.d.ts +31 -0
  31. package/cjs/node/DefaultClient.d.ts +16 -0
  32. package/cjs/node/Digest.d.ts +4 -0
  33. package/cjs/node/Digest.test.d.ts +1 -0
  34. package/cjs/node/HttpRequestSender.d.ts +29 -0
  35. package/cjs/node/HttpServer.d.ts +21 -0
  36. package/cjs/node/TimeZoneDaemon.d.ts +6 -0
  37. package/cjs/node/TimeZoneDaemon.js +29 -0
  38. package/cjs/node/VapixEvents.d.ts +16 -0
  39. package/cjs/node/WsClient.d.ts +30 -0
  40. package/cjs/node/events/AxisCameraStationEvents.d.ts +12 -0
  41. package/cjs/node/events/GenetecAgent.d.ts +16 -0
  42. package/cjs/node/events/GenetecAgent.js +5 -4
  43. package/cjs/node/index.d.ts +17 -0
  44. package/cjs/types/CamOverlayAPI/CamOverlayAPI.d.ts +4330 -0
  45. package/cjs/types/CamOverlayAPI/accuweatherSchema.d.ts +84 -0
  46. package/cjs/types/CamOverlayAPI/customGraphicsSchema.d.ts +700 -0
  47. package/cjs/types/CamOverlayAPI/imagesSchema.d.ts +95 -0
  48. package/cjs/types/CamOverlayAPI/index.d.ts +11 -0
  49. package/cjs/types/CamOverlayAPI/infotickerSchema.d.ts +96 -0
  50. package/cjs/types/CamOverlayAPI/pipSchema.d.ts +125 -0
  51. package/cjs/types/CamOverlayAPI/ptzCompassSchema.d.ts +96 -0
  52. package/cjs/types/CamOverlayAPI/ptzSchema.d.ts +118 -0
  53. package/cjs/types/CamOverlayAPI/scoreBoardSchema.d.ts +357 -0
  54. package/cjs/types/CamOverlayAPI/screenSharingSchema.d.ts +58 -0
  55. package/cjs/types/CamOverlayAPI/serviceCommonTypes.d.ts +145 -0
  56. package/cjs/types/CamOverlayAPI/webCameraSharingSchema.d.ts +58 -0
  57. package/cjs/types/CamOverlayDrawingAPI.d.ts +48 -0
  58. package/cjs/types/CamOverlayPainter.d.ts +76 -0
  59. package/cjs/types/CamScripterAPI.d.ts +130 -0
  60. package/cjs/types/CamScripterAPICameraEventsGenerator.d.ts +45 -0
  61. package/cjs/types/CamStreamerAPI.d.ts +272 -0
  62. package/cjs/types/CamSwitcherAPI.d.ts +893 -0
  63. package/cjs/types/GenetecAgent.d.ts +174 -0
  64. package/cjs/types/PlaneTrackerAPI.d.ts +926 -0
  65. package/cjs/types/PlaneTrackerAPI.js +4 -1
  66. package/cjs/types/VapixAPI.d.ts +1865 -0
  67. package/cjs/types/VapixEvents.d.ts +15 -0
  68. package/cjs/types/common.d.ts +49 -0
  69. package/cjs/types/ws/CamOverlayEvents.d.ts +88 -0
  70. package/cjs/types/ws/CamStreamerEvents.d.ts +249 -0
  71. package/cjs/types/ws/CamSwitcherEvents.d.ts +568 -0
  72. package/cjs/types/ws/PlaneTrackerEvents.d.ts +1637 -0
  73. package/cjs/types/ws/PlaneTrackerEvents.js +2 -0
  74. package/cjs/web/DefaultClient.d.ts +8 -0
  75. package/cjs/web/WsClient.d.ts +17 -0
  76. package/cjs/web/index.d.ts +2 -0
  77. package/cjs/ws/CamOverlayEvents.d.ts +8 -0
  78. package/cjs/ws/CamStreamerEvents.d.ts +8 -0
  79. package/cjs/ws/CamSwitcherEvents.d.ts +8 -0
  80. package/cjs/ws/PlaneTrackerEvents.d.ts +9 -0
  81. package/esm/CamOverlayAPI.js +7 -7
  82. package/esm/CamScripterAPI.js +3 -4
  83. package/esm/CamStreamerAPI.js +2 -3
  84. package/esm/CamSwitcherAPI.js +4 -4
  85. package/esm/PlaneTrackerAPI.js +10 -10
  86. package/esm/VapixAPI.js +12 -12
  87. package/esm/errors/errors.js +30 -24
  88. package/esm/internal/utils.js +0 -11
  89. package/esm/node/TimeZoneDaemon.js +25 -0
  90. package/esm/node/events/GenetecAgent.js +6 -5
  91. package/esm/types/PlaneTrackerAPI.js +3 -0
  92. package/esm/types/ws/PlaneTrackerEvents.js +2 -0
  93. package/package.json +1 -1
  94. package/types/errors/errors.d.ts +17 -22
  95. package/types/internal/utils.d.ts +1 -13
  96. package/types/node/TimeZoneDaemon.d.ts +6 -0
  97. package/types/types/PlaneTrackerAPI.d.ts +8 -0
  98. package/types/types/ws/PlaneTrackerEvents.d.ts +40 -0
@@ -83,7 +83,7 @@ class CamOverlayAPI {
83
83
  throw new errors_1.ServiceNotFoundError();
84
84
  }
85
85
  else {
86
- throw new errors_1.GeneralResponseNotOKError(await (0, utils_1.responseStringify)(res));
86
+ throw new errors_1.ErrorWithResponse(res);
87
87
  }
88
88
  }
89
89
  async getSingleService(serviceId, options) {
@@ -165,7 +165,7 @@ class CamOverlayAPI {
165
165
  timeout: options?.timeout,
166
166
  });
167
167
  if (!res.ok) {
168
- throw new errors_1.GeneralResponseNotOKError(await (0, utils_1.responseStringify)(res));
168
+ throw new errors_1.ErrorWithResponse(res);
169
169
  }
170
170
  }
171
171
  async _getJson(path, parameters, options) {
@@ -175,7 +175,7 @@ class CamOverlayAPI {
175
175
  return await res.json();
176
176
  }
177
177
  else {
178
- throw new errors_1.GeneralResponseNotOKError(await (0, utils_1.responseStringify)(res));
178
+ throw new errors_1.ErrorWithResponse(res);
179
179
  }
180
180
  }
181
181
  async _post(path, data, parameters, options, headers) {
@@ -185,7 +185,7 @@ class CamOverlayAPI {
185
185
  return await res.json();
186
186
  }
187
187
  else {
188
- throw new errors_1.GeneralResponseNotOKError(await (0, utils_1.responseStringify)(res));
188
+ throw new errors_1.ErrorWithResponse(res);
189
189
  }
190
190
  }
191
191
  async _getBlob(path, parameters, options) {
@@ -195,7 +195,7 @@ class CamOverlayAPI {
195
195
  return await this.parseBlobResponse(res);
196
196
  }
197
197
  else {
198
- throw new errors_1.GeneralResponseNotOKError(await (0, utils_1.responseStringify)(res));
198
+ throw new errors_1.ErrorWithResponse(res);
199
199
  }
200
200
  }
201
201
  async parseBlobResponse(response) {
@@ -0,0 +1,46 @@
1
+ import { ProxyClient } from './internal/ProxyClient';
2
+ import { IClient, TResponse } from './internal/types';
3
+ import { THttpRequestOptions, TProxyParams, TStorageType } from './types/common';
4
+ export declare class CamScripterAPI<Client extends IClient<TResponse, any>> {
5
+ private client;
6
+ constructor(client: Client);
7
+ static getProxyPath: () => string;
8
+ getClient(proxyParams?: TProxyParams): Client | ProxyClient<Client>;
9
+ checkCameraTime(options?: THttpRequestOptions): Promise<boolean>;
10
+ getNetworkCameraList(options?: THttpRequestOptions): Promise<{
11
+ name: string;
12
+ ip: string;
13
+ }[]>;
14
+ getStorageInfo(options?: THttpRequestOptions): Promise<[{
15
+ type: "FLASH";
16
+ capacity_mb: number;
17
+ }, {
18
+ type: "SD_DISK";
19
+ capacity_mb: number;
20
+ }] | [{
21
+ type: "FLASH";
22
+ capacity_mb: number;
23
+ }]>;
24
+ getPackageList(options?: THttpRequestOptions): Promise<{
25
+ storage: "FLASH" | "SD_DISK";
26
+ manifest: {
27
+ package_name: string;
28
+ package_menu_name: string;
29
+ package_version: string;
30
+ vendor: string;
31
+ ui_link: string;
32
+ required_camscripter_version?: string | undefined;
33
+ required_camscripter_rbi_version?: string | undefined;
34
+ };
35
+ }[]>;
36
+ installPackages(formData: Parameters<Client['post']>[0]['data'], storage: TStorageType, options?: THttpRequestOptions): Promise<void>;
37
+ uninstallPackage(packageId: string, options?: THttpRequestOptions): Promise<void>;
38
+ importSettings(packageId: string, formData: Parameters<Client['post']>[0]['data'], options?: THttpRequestOptions): Promise<void>;
39
+ exportSettings(packageId: string, formData: Parameters<Client['post']>[0]['data'], options?: THttpRequestOptions): Promise<void>;
40
+ getNodejsStatus(options?: THttpRequestOptions): Promise<{
41
+ node_state: "OK" | "NOT_INSTALLED" | "NOT_FOUND";
42
+ }>;
43
+ installNodejs(storage: TStorageType, options?: THttpRequestOptions): Promise<void>;
44
+ private _getJson;
45
+ private _post;
46
+ }
@@ -3,7 +3,6 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.CamScripterAPI = void 0;
4
4
  const errors_1 = require("./errors/errors");
5
5
  const ProxyClient_1 = require("./internal/ProxyClient");
6
- const utils_1 = require("./internal/utils");
7
6
  const CamScripterAPI_1 = require("./types/CamScripterAPI");
8
7
  const common_1 = require("./types/common");
9
8
  const BASE_PATH = '/local/camscripter';
@@ -64,7 +63,7 @@ class CamScripterAPI {
64
63
  return await res.json();
65
64
  }
66
65
  else {
67
- throw new errors_1.GeneralResponseNotOKError(await (0, utils_1.responseStringify)(res));
66
+ throw new errors_1.ErrorWithResponse(res);
68
67
  }
69
68
  }
70
69
  async _post(path, data, parameters, options, headers) {
@@ -74,7 +73,7 @@ class CamScripterAPI {
74
73
  return await res.json();
75
74
  }
76
75
  else {
77
- throw new errors_1.GeneralResponseNotOKError(await (0, utils_1.responseStringify)(res));
76
+ throw new errors_1.ErrorWithResponse(res);
78
77
  }
79
78
  }
80
79
  }
@@ -0,0 +1,64 @@
1
+ import { ProxyClient } from './internal/ProxyClient';
2
+ import { IClient, TResponse } from './internal/types';
3
+ import { TCameraStream, TStream } from './types/CamStreamerAPI';
4
+ import { THttpRequestOptions, TProxyParams } from './types/common';
5
+ export declare class CamStreamerAPI<Client extends IClient<TResponse, any>> {
6
+ private client;
7
+ constructor(client: Client);
8
+ getClient(proxyParams?: TProxyParams): Client | ProxyClient<Client>;
9
+ wsAuthorization(options?: THttpRequestOptions): Promise<string>;
10
+ getUtcTime(options?: THttpRequestOptions): Promise<number>;
11
+ getStreamList(options?: THttpRequestOptions): Promise<Record<number, {
12
+ enabled: 0 | 1;
13
+ schedule: string;
14
+ active: 0 | 1;
15
+ audioSource: string;
16
+ avSyncMsec: number;
17
+ internalVapixParameters: string;
18
+ userVapixParameters: string;
19
+ outputParameters: string;
20
+ outputType: "video" | "none" | "images";
21
+ mediaServerUrl: string;
22
+ inputType: "RTSP_URL" | "CSw" | "CRS";
23
+ inputUrl: string;
24
+ forceStereo: 0 | 1;
25
+ streamDelay: number | null;
26
+ statusLed: number;
27
+ statusPort: string;
28
+ callApi: number;
29
+ trigger: string;
30
+ prepareAhead: number;
31
+ startTime: number | null;
32
+ stopTime: number | null;
33
+ }>>;
34
+ getStream(streamId: number, options?: THttpRequestOptions): Promise<{
35
+ enabled: 0 | 1;
36
+ schedule: string;
37
+ active: 0 | 1;
38
+ audioSource: string;
39
+ avSyncMsec: number;
40
+ internalVapixParameters: string;
41
+ userVapixParameters: string;
42
+ outputParameters: string;
43
+ outputType: "video" | "none" | "images";
44
+ mediaServerUrl: string;
45
+ inputType: "RTSP_URL" | "CSw" | "CRS";
46
+ inputUrl: string;
47
+ forceStereo: 0 | 1;
48
+ streamDelay: number | null;
49
+ statusLed: number;
50
+ statusPort: string;
51
+ callApi: number;
52
+ trigger: string;
53
+ prepareAhead: number;
54
+ startTime: number | null;
55
+ stopTime: number | null;
56
+ }>;
57
+ getStreamParameter(streamId: number, paramName: string, options?: THttpRequestOptions): Promise<string>;
58
+ setStream(streamId: number, params: Partial<TStream>, options?: THttpRequestOptions): Promise<void>;
59
+ setStreamParameter(streamId: number, paramName: string, value: string, options?: THttpRequestOptions): Promise<void>;
60
+ isStreaming(streamId: number, options?: THttpRequestOptions): Promise<boolean>;
61
+ deleteStream(streamId: number, options?: THttpRequestOptions): Promise<boolean>;
62
+ private _getJson;
63
+ }
64
+ export declare const parseCameraStreamResponse: (cameraStreamData: TCameraStream) => TStream;
@@ -3,7 +3,6 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.parseCameraStreamResponse = exports.CamStreamerAPI = void 0;
4
4
  const zod_1 = require("zod");
5
5
  const ProxyClient_1 = require("./internal/ProxyClient");
6
- const utils_1 = require("./internal/utils");
7
6
  const CamStreamerAPI_1 = require("./types/CamStreamerAPI");
8
7
  const errors_1 = require("./errors/errors");
9
8
  const BASE_PATH = '/local/camstreamer';
@@ -76,7 +75,7 @@ class CamStreamerAPI {
76
75
  return await res.json();
77
76
  }
78
77
  else {
79
- throw new errors_1.GeneralResponseNotOKError(await (0, utils_1.responseStringify)(res));
78
+ throw new errors_1.ErrorWithResponse(res);
80
79
  }
81
80
  }
82
81
  }
@@ -0,0 +1,167 @@
1
+ import { IClient, TResponse } from './internal/types';
2
+ import { TStreamSaveList, TTrackerSaveList, TClipSaveList, TPlaylistSaveList, TCameraOptions, TGlobalAudioSettings, TSecondaryAudioSettings } from './types/CamSwitcherAPI';
3
+ import { TAudioChannel, THttpRequestOptions, TProxyParams, TStorageType } from './types/common';
4
+ import { ProxyClient } from './internal/ProxyClient';
5
+ export declare class CamSwitcherAPI<Client extends IClient<TResponse, any>> {
6
+ private client;
7
+ private CustomFormData;
8
+ private vapixAgent;
9
+ constructor(client: Client, CustomFormData?: {
10
+ new (form?: HTMLFormElement | undefined, submitter?: HTMLElement | null | undefined): FormData;
11
+ prototype: FormData;
12
+ });
13
+ static getProxyPath: () => string;
14
+ static getWsEventsPath: () => string;
15
+ static getClipPreviewPath: (clipId: string, storage: TStorageType) => string;
16
+ getClient(proxyParams?: TProxyParams): Client | ProxyClient<Client>;
17
+ checkCameraTime(options?: THttpRequestOptions): Promise<boolean>;
18
+ getNetworkCameraList(options?: THttpRequestOptions): Promise<{
19
+ name: string;
20
+ ip: string;
21
+ }[]>;
22
+ generateSilence(sampleRate: number, channels: TAudioChannel, options?: THttpRequestOptions): Promise<void>;
23
+ getMaxFps(source: number, options?: THttpRequestOptions): Promise<number>;
24
+ getStorageInfo(options?: THttpRequestOptions): Promise<{
25
+ storage: "FLASH" | "SD_DISK";
26
+ writable: boolean;
27
+ size: number;
28
+ available: number;
29
+ }[]>;
30
+ wsAuthorization(options?: THttpRequestOptions): Promise<string>;
31
+ getOutputInfo(options?: THttpRequestOptions): Promise<{
32
+ rtspUrl: string;
33
+ ws: string;
34
+ wsInitialMessage: string;
35
+ }>;
36
+ getAudioPushInfo(options?: THttpRequestOptions): Promise<{
37
+ ws: string;
38
+ wsInitialMessage: string;
39
+ }>;
40
+ getStreamSaveList(options?: THttpRequestOptions): Promise<Record<string, {
41
+ ip?: string | undefined;
42
+ niceName?: string | undefined;
43
+ mdnsName?: string | undefined;
44
+ port?: number | undefined;
45
+ enabled?: boolean | undefined;
46
+ auth?: string | undefined;
47
+ query?: string | undefined;
48
+ channel?: "audio" | "video" | "av" | undefined;
49
+ keyboard?: Record<string, string | null> | undefined;
50
+ sortIndexOverview?: number | undefined;
51
+ viewNumber?: number | undefined;
52
+ }>>;
53
+ getClipSaveList(options?: THttpRequestOptions): Promise<Record<string, {
54
+ niceName?: string | undefined;
55
+ channel?: "audio" | "video" | "av" | undefined;
56
+ keyboard?: Record<string, string | null> | undefined;
57
+ sortIndexOverview?: number | undefined;
58
+ }>>;
59
+ getPlaylistSaveList(options?: THttpRequestOptions): Promise<Record<string, {
60
+ niceName?: string | undefined;
61
+ channel?: "audio" | "video" | "av" | undefined;
62
+ keyboard?: Record<string, string | null> | undefined;
63
+ sortIndexOverview?: number | undefined;
64
+ isFavourite?: boolean | undefined;
65
+ sortIndexFavourite?: number | undefined;
66
+ play_type?: "PLAY_ALL" | "PLAY_ALL_LOOP" | "PLAY_ALL_SHUFFLED" | "PLAY_ALL_LOOP_SHUFFLED" | "PLAY_ONE_RANDOM" | undefined;
67
+ default?: boolean | undefined;
68
+ stream_list?: {
69
+ repeat: number;
70
+ video: {
71
+ storage?: "FLASH" | "SD_DISK" | undefined;
72
+ stream_name?: string | undefined;
73
+ clip_name?: string | undefined;
74
+ tracker_name?: string | undefined;
75
+ };
76
+ id: string;
77
+ isTimeoutCustom: boolean;
78
+ ptz_preset_pos_name: string;
79
+ timeout: number;
80
+ audio?: {
81
+ storage?: "FLASH" | "SD_DISK" | undefined;
82
+ stream_name?: string | undefined;
83
+ clip_name?: string | undefined;
84
+ tracker_name?: string | undefined;
85
+ } | undefined;
86
+ }[] | undefined;
87
+ }>>;
88
+ getTrackerSaveList(options?: THttpRequestOptions): Promise<Record<string, {
89
+ name?: string | undefined;
90
+ channel?: "audio" | "video" | "av" | undefined;
91
+ keyboard?: Record<string, string | null> | undefined;
92
+ sortIndexOverview?: number | undefined;
93
+ viewNumber?: number | undefined;
94
+ id?: string | undefined;
95
+ previewId?: string | undefined;
96
+ duration?: number | undefined;
97
+ width?: number | undefined;
98
+ height?: number | undefined;
99
+ fps?: number | undefined;
100
+ motion_history_frames?: number | undefined;
101
+ include_zone?: number[][] | undefined;
102
+ include_node_ids?: string[] | undefined;
103
+ camera_list?: {
104
+ name: string;
105
+ id: string;
106
+ overview: boolean;
107
+ zone: number[];
108
+ playlist_name: string;
109
+ ptz_preset_pos_no: number;
110
+ }[] | undefined;
111
+ camera_view_number?: number | undefined;
112
+ }>>;
113
+ setStreamSaveList(data: TStreamSaveList, options?: THttpRequestOptions): Promise<void>;
114
+ setClipSaveList(data: TClipSaveList, options?: THttpRequestOptions): Promise<void>;
115
+ setPlaylistSaveList(data: TPlaylistSaveList, options?: THttpRequestOptions): Promise<void>;
116
+ setTrackerSaveList(data: TTrackerSaveList, options?: THttpRequestOptions): Promise<void>;
117
+ playlistSwitch(playlistName: string, options?: THttpRequestOptions): Promise<void>;
118
+ playlistQueuePush(playlistName: string, options?: THttpRequestOptions): Promise<void>;
119
+ playlistQueueClear(options?: THttpRequestOptions): Promise<void>;
120
+ playlistQueueList(options?: THttpRequestOptions): Promise<string[]>;
121
+ playlistQueuePlayNext(options?: THttpRequestOptions): Promise<void>;
122
+ addNewClip(file: any, clipType: 'video' | 'audio', storage: TStorageType, clipId: string, fileName?: string, options?: THttpRequestOptions): Promise<void>;
123
+ removeClip(clipId: string, storage: TStorageType, options?: THttpRequestOptions): Promise<void>;
124
+ getClipList(options?: THttpRequestOptions): Promise<Record<string, {
125
+ storage: "FLASH" | "SD_DISK";
126
+ stream_list: ({
127
+ type: "video";
128
+ width: number;
129
+ height: number;
130
+ fps: number;
131
+ sample_rate: number;
132
+ h264_profile: "high" | "main" | "baseline";
133
+ h264_level: "4.1";
134
+ gop: number;
135
+ bitrate: number;
136
+ } | {
137
+ type: "audio";
138
+ sample_rate: number;
139
+ channel_count: 1 | 2;
140
+ })[];
141
+ duration: number;
142
+ }>>;
143
+ setCamSwitchOptions(data: TCameraOptions, cameraFWVersion: string, options?: THttpRequestOptions): Promise<void>;
144
+ setGlobalAudioSettings(settings: TGlobalAudioSettings, options?: THttpRequestOptions): Promise<void>;
145
+ setSecondaryAudioSettings(settings: TSecondaryAudioSettings, options?: THttpRequestOptions): Promise<void>;
146
+ setDefaultPlaylist(playlistId: string, options?: THttpRequestOptions): Promise<void>;
147
+ setPermanentRtspUrlToken(token: string, options?: THttpRequestOptions): Promise<void>;
148
+ getCamSwitchOptions(options?: THttpRequestOptions): Promise<any>;
149
+ getGlobalAudioSettings(options?: THttpRequestOptions): Promise<{
150
+ type: "fromSource" | "source";
151
+ source: string;
152
+ storage?: string | undefined;
153
+ }>;
154
+ getSecondaryAudioSettings(options?: THttpRequestOptions): Promise<{
155
+ type: "CLIP" | "STREAM" | "NONE";
156
+ storage: "FLASH" | "SD_DISK";
157
+ secondaryAudioLevel: number;
158
+ masterAudioLevel: number;
159
+ streamName?: string | undefined;
160
+ clipName?: string | undefined;
161
+ }>;
162
+ getPermanentRtspUrlToken(options?: THttpRequestOptions): Promise<string>;
163
+ private _getJson;
164
+ private _post;
165
+ private setParamFromCameraJSON;
166
+ private getParamFromCameraAndJSONParse;
167
+ }
@@ -263,7 +263,7 @@ class CamSwitcherAPI {
263
263
  return await res.json();
264
264
  }
265
265
  else {
266
- throw new errors_1.GeneralResponseNotOKError(await (0, utils_1.responseStringify)(res));
266
+ throw new errors_1.ErrorWithResponse(res);
267
267
  }
268
268
  }
269
269
  async _post(path, data, parameters, options, headers) {
@@ -273,7 +273,7 @@ class CamSwitcherAPI {
273
273
  return await res.json();
274
274
  }
275
275
  else {
276
- throw new errors_1.GeneralResponseNotOKError(await (0, utils_1.responseStringify)(res));
276
+ throw new errors_1.ErrorWithResponse(res);
277
277
  }
278
278
  }
279
279
  setParamFromCameraJSON(paramName, data, options) {
@@ -0,0 +1,229 @@
1
+ import { IClient, TBlobResponse, TParameters, TResponse } from './internal/types';
2
+ import { ICAO, TApiUser, TBlackList, TCameraSettings, TExportDataType, TGetIcaoByOption, TImportDataType, TPriorityList, TTrackingMode, TWhiteList, TZones } from './types/PlaneTrackerAPI';
3
+ import { THttpRequestOptions, TProxyParams } from './types/common';
4
+ import { ProxyClient } from './internal/ProxyClient';
5
+ export declare class PlaneTrackerAPI<Client extends IClient<TResponse, any>> {
6
+ private client;
7
+ private apiUser;
8
+ constructor(client: Client, apiUser: TApiUser);
9
+ static getProxyPath: () => string;
10
+ static getWsEventsPath: () => string;
11
+ getClient(proxyParams?: TProxyParams): Client | ProxyClient<Client>;
12
+ checkCameraTime(options?: THttpRequestOptions): Promise<boolean>;
13
+ serverRunCheck(options?: THttpRequestOptions): Promise<TResponse>;
14
+ getLiveViewAlias(rtspUrl: string, options?: THttpRequestOptions): Promise<{
15
+ ws: string;
16
+ ws_initial_message: string;
17
+ alias: string;
18
+ }>;
19
+ resetPtzCalibration(options?: THttpRequestOptions): Promise<void>;
20
+ resetFocusCalibration(options?: THttpRequestOptions): Promise<void>;
21
+ fetchCameraSettings(options?: THttpRequestOptions): Promise<{
22
+ camera: {
23
+ ip: string;
24
+ port: number;
25
+ protocol: "https" | "http" | "https_insecure";
26
+ user: string;
27
+ pass: string;
28
+ };
29
+ units: "metric" | "imperial";
30
+ adsbSource: {
31
+ ip: string;
32
+ port: number;
33
+ };
34
+ cameraCalibrationProcessConfig: {
35
+ nightSkyCalibrationEnabled: boolean;
36
+ scheduleNightSkyCalibrationTimestamp: number;
37
+ focusCalibrationPoints: string;
38
+ };
39
+ cameraConfig: {
40
+ defaultCaptureSizeMeters: number;
41
+ captureSizeExtensionMeters: number;
42
+ maxZoomLevel?: number | undefined;
43
+ };
44
+ stream: {
45
+ width: number;
46
+ height: number;
47
+ };
48
+ imageConfig: {
49
+ dayAperture: number;
50
+ nightAperture: number;
51
+ maxGain: number;
52
+ };
53
+ airportConfig: {
54
+ icao: string;
55
+ centerLat: number;
56
+ centerLon: number;
57
+ radius: number;
58
+ };
59
+ trackingConfig: {
60
+ prioritizeEmergency: boolean;
61
+ trackingZoneWeightIncrease: number;
62
+ guardTourEnabled: boolean;
63
+ guardTourId: number;
64
+ };
65
+ widget: {
66
+ enabled: boolean;
67
+ scale: number;
68
+ coord: "top_left" | "top_right" | "bottom_left" | "bottom_right";
69
+ posX: number;
70
+ posY: number;
71
+ };
72
+ airportWidget: {
73
+ enabled: boolean;
74
+ scale: number;
75
+ coord: "top_left" | "top_right" | "bottom_left" | "bottom_right";
76
+ posX: number;
77
+ posY: number;
78
+ };
79
+ fr24FlightInfoSource: {
80
+ enabled: boolean;
81
+ priority: number;
82
+ apiToken: string;
83
+ validateFlights: boolean;
84
+ };
85
+ radarcapeFlightInfoSource: {
86
+ ip: string;
87
+ port: number;
88
+ enabled: boolean;
89
+ priority: number;
90
+ };
91
+ identificationLabel: {
92
+ firstRow: "blank" | "registration" | "call_sign" | "flight_number" | "icao";
93
+ secondRow: "blank" | "registration" | "call_sign" | "flight_number" | "icao";
94
+ thirdRow: "blank" | "registration" | "call_sign" | "flight_number" | "icao";
95
+ fourthRow: "blank" | "registration" | "call_sign" | "flight_number" | "icao";
96
+ opacity: number;
97
+ };
98
+ acs: {
99
+ ip: string;
100
+ port: number;
101
+ enabled: boolean;
102
+ protocol: "https" | "http" | "https_insecure";
103
+ user: string;
104
+ pass: string;
105
+ sourceKey: string;
106
+ };
107
+ genetec: {
108
+ ip: string;
109
+ port: number;
110
+ enabled: boolean;
111
+ cameraList: string[];
112
+ appId: string;
113
+ protocol: "https" | "http" | "https_insecure";
114
+ user: string;
115
+ pass: string;
116
+ baseUri: string;
117
+ };
118
+ overlayText?: {
119
+ displayIcao?: boolean | undefined;
120
+ displayRegistration?: boolean | undefined;
121
+ displayFlightNumber?: boolean | undefined;
122
+ displayAltitude?: boolean | undefined;
123
+ displayVelocity?: boolean | undefined;
124
+ displayDistance?: boolean | undefined;
125
+ displayFOV?: boolean | undefined;
126
+ displayPTError?: boolean | undefined;
127
+ displayPTZSpeed?: boolean | undefined;
128
+ displayVelocityData?: boolean | undefined;
129
+ displaySignalQuality?: boolean | undefined;
130
+ displayAutoTrackingInfo?: boolean | undefined;
131
+ displayGPSCoords?: boolean | undefined;
132
+ displayVapixQuery?: boolean | undefined;
133
+ displayFocus?: boolean | undefined;
134
+ displayAperture?: boolean | undefined;
135
+ displaySunDistance?: boolean | undefined;
136
+ displayTickTime?: boolean | undefined;
137
+ displayAircraftInfo?: boolean | undefined;
138
+ } | undefined;
139
+ }>;
140
+ setCameraSettings(settings: TCameraSettings, options?: THttpRequestOptions): Promise<TResponse>;
141
+ fetchServerSettings(options?: THttpRequestOptions): Promise<{
142
+ cameraCalibration: {
143
+ posLat: number;
144
+ posLon: number;
145
+ geoidHN: number;
146
+ altitudeAmsl: number;
147
+ rotationEast: number;
148
+ rotationNorth: number;
149
+ rotationUp: number;
150
+ tiltTransformationCoefA: number;
151
+ tiltCameraKnownPoint: number;
152
+ tiltRealKnownPoint: number;
153
+ };
154
+ }>;
155
+ exportAppSettings(dataType: TExportDataType, options?: THttpRequestOptions): Promise<TBlobResponse<Client>>;
156
+ importAppSettings(dataType: TImportDataType, formData: Parameters<Client['post']>[0]['data'], options?: THttpRequestOptions): Promise<void>;
157
+ fetchFlightInfo(icao: ICAO, options?: THttpRequestOptions): Promise<{
158
+ destinationAirport: {
159
+ icao?: string | undefined;
160
+ iata?: string | undefined;
161
+ city?: string | undefined;
162
+ };
163
+ registration?: string | undefined;
164
+ callsign?: string | undefined;
165
+ flightNumber?: string | undefined;
166
+ aircraftType?: string | undefined;
167
+ airlines?: string | undefined;
168
+ originAirport?: {
169
+ icao?: string | undefined;
170
+ iata?: string | undefined;
171
+ city?: string | undefined;
172
+ } | undefined;
173
+ flightImages?: {
174
+ src?: string | undefined;
175
+ photographer?: string | undefined;
176
+ }[] | undefined;
177
+ }>;
178
+ getTrackingMode(options?: THttpRequestOptions): Promise<{
179
+ mode: "MANUAL" | "AUTOMATIC";
180
+ }>;
181
+ setTrackingMode(mode: TTrackingMode['mode'], options?: THttpRequestOptions): Promise<void>;
182
+ startTrackingPlane(icao: ICAO, options?: THttpRequestOptions): Promise<void>;
183
+ stopTrackingPlane(options?: THttpRequestOptions): Promise<void>;
184
+ getIcao(by: TGetIcaoByOption, value: string, options?: THttpRequestOptions): Promise<string>;
185
+ getPriorityList(options?: THttpRequestOptions): Promise<string[]>;
186
+ setPriorityList(priorityList: TPriorityList['priorityList'], options?: THttpRequestOptions): Promise<TResponse>;
187
+ getWhiteList(options?: THttpRequestOptions): Promise<string[]>;
188
+ setWhiteList(whiteList: TWhiteList['whiteList'], options?: THttpRequestOptions): Promise<TResponse>;
189
+ getBlackList(options?: THttpRequestOptions): Promise<string[]>;
190
+ setBlackList(blackList: TBlackList['blackList'], options?: THttpRequestOptions): Promise<TResponse>;
191
+ fetchMapInfo(options?: THttpRequestOptions): Promise<{
192
+ minZoom: number;
193
+ maxZoom: number;
194
+ mapTypes: ("roadmap" | "satellite")[];
195
+ tileSize: number;
196
+ }>;
197
+ getZones(options?: THttpRequestOptions): Promise<{
198
+ zones: {
199
+ enabled: boolean;
200
+ area: [{
201
+ lat: number;
202
+ lon: number;
203
+ }, ...{
204
+ lat: number;
205
+ lon: number;
206
+ }[]];
207
+ flightDirection: "all" | "arrival" | "departure";
208
+ weight: number;
209
+ name?: string | undefined;
210
+ minAltitudeAmsl?: number | undefined;
211
+ maxAltitudeAmsl?: number | undefined;
212
+ minSpeedKmph?: number | undefined;
213
+ maxSpeedKmph?: number | undefined;
214
+ }[];
215
+ }>;
216
+ setZones(zones: TZones, options?: THttpRequestOptions): Promise<void>;
217
+ goToCoordinates(lat: number, lon: number, alt?: number, options?: THttpRequestOptions): Promise<void>;
218
+ checkGenetecConnection(params: TParameters, options?: THttpRequestOptions): Promise<TResponse>;
219
+ getGenetecCameraList(params: TParameters, options?: THttpRequestOptions): Promise<{
220
+ value: string;
221
+ index: number;
222
+ label: string;
223
+ }[]>;
224
+ private _getJson;
225
+ private _getBlob;
226
+ private parseBlobResponse;
227
+ private _postJsonEncoded;
228
+ private _postUrlEncoded;
229
+ }