@stream-io/node-sdk 0.7.34 → 0.7.35

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.
@@ -1,5 +1,7 @@
1
1
  import { ApiClient, StreamResponse } from '../../gen-imports';
2
2
  import {
3
+ AppealRequest,
4
+ AppealResponse,
3
5
  BanRequest,
4
6
  BanResponse,
5
7
  BulkImageModerationRequest,
@@ -13,11 +15,14 @@ import {
13
15
  DeleteModerationTemplateResponse,
14
16
  FlagRequest,
15
17
  FlagResponse,
18
+ GetAppealResponse,
16
19
  GetConfigResponse,
17
20
  GetModerationRuleResponse,
18
21
  GetReviewQueueItemResponse,
19
22
  MuteRequest,
20
23
  MuteResponse,
24
+ QueryAppealsRequest,
25
+ QueryAppealsResponse,
21
26
  QueryFeedModerationTemplatesResponse,
22
27
  QueryModerationConfigsRequest,
23
28
  QueryModerationConfigsResponse,
@@ -47,6 +52,79 @@ import { decoders } from '../model-decoders/decoders';
47
52
  export class ModerationApi {
48
53
  constructor(public readonly apiClient: ApiClient) {}
49
54
 
55
+ async appeal(
56
+ request: AppealRequest,
57
+ ): Promise<StreamResponse<AppealResponse>> {
58
+ const body = {
59
+ appeal_reason: request?.appeal_reason,
60
+ entity_id: request?.entity_id,
61
+ entity_type: request?.entity_type,
62
+ user_id: request?.user_id,
63
+ attachments: request?.attachments,
64
+ user: request?.user,
65
+ };
66
+
67
+ const response = await this.apiClient.sendRequest<
68
+ StreamResponse<AppealResponse>
69
+ >(
70
+ 'POST',
71
+ '/api/v2/moderation/appeal',
72
+ undefined,
73
+ undefined,
74
+ body,
75
+ 'application/json',
76
+ );
77
+
78
+ decoders.AppealResponse?.(response.body);
79
+
80
+ return { ...response.body, metadata: response.metadata };
81
+ }
82
+
83
+ async getAppeal(request: {
84
+ id: string;
85
+ }): Promise<StreamResponse<GetAppealResponse>> {
86
+ const pathParams = {
87
+ id: request?.id,
88
+ };
89
+
90
+ const response = await this.apiClient.sendRequest<
91
+ StreamResponse<GetAppealResponse>
92
+ >('GET', '/api/v2/moderation/appeal/{id}', pathParams, undefined);
93
+
94
+ decoders.GetAppealResponse?.(response.body);
95
+
96
+ return { ...response.body, metadata: response.metadata };
97
+ }
98
+
99
+ async queryAppeals(
100
+ request?: QueryAppealsRequest,
101
+ ): Promise<StreamResponse<QueryAppealsResponse>> {
102
+ const body = {
103
+ limit: request?.limit,
104
+ next: request?.next,
105
+ prev: request?.prev,
106
+ user_id: request?.user_id,
107
+ sort: request?.sort,
108
+ filter: request?.filter,
109
+ user: request?.user,
110
+ };
111
+
112
+ const response = await this.apiClient.sendRequest<
113
+ StreamResponse<QueryAppealsResponse>
114
+ >(
115
+ 'POST',
116
+ '/api/v2/moderation/appeals',
117
+ undefined,
118
+ undefined,
119
+ body,
120
+ 'application/json',
121
+ );
122
+
123
+ decoders.QueryAppealsResponse?.(response.body);
124
+
125
+ return { ...response.body, metadata: response.metadata };
126
+ }
127
+
50
128
  async ban(request: BanRequest): Promise<StreamResponse<BanResponse>> {
51
129
  const body = {
52
130
  target_user_id: request?.target_user_id,
@@ -581,6 +659,7 @@ export class ModerationApi {
581
659
  ): Promise<StreamResponse<SubmitActionResponse>> {
582
660
  const body = {
583
661
  action_type: request?.action_type,
662
+ appeal_id: request?.appeal_id,
584
663
  item_id: request?.item_id,
585
664
  user_id: request?.user_id,
586
665
  ban: request?.ban,
@@ -592,8 +671,11 @@ export class ModerationApi {
592
671
  delete_reaction: request?.delete_reaction,
593
672
  delete_user: request?.delete_user,
594
673
  mark_reviewed: request?.mark_reviewed,
674
+ reject_appeal: request?.reject_appeal,
675
+ restore: request?.restore,
595
676
  shadow_block: request?.shadow_block,
596
677
  unban: request?.unban,
678
+ unblock: request?.unblock,
597
679
  user: request?.user,
598
680
  };
599
681
 
@@ -23,6 +23,7 @@ import {
23
23
  MuteUsersResponse,
24
24
  PinRequest,
25
25
  PinResponse,
26
+ QueryCallParticipantSessionsResponse,
26
27
  QueryCallParticipantsRequest,
27
28
  QueryCallParticipantsResponse,
28
29
  RingCallRequest,
@@ -51,6 +52,7 @@ import {
51
52
  StopLiveResponse,
52
53
  StopRTMPBroadcastsRequest,
53
54
  StopRTMPBroadcastsResponse,
55
+ StopRecordingRequest,
54
56
  StopRecordingResponse,
55
57
  StopTranscriptionRequest,
56
58
  StopTranscriptionResponse,
@@ -247,6 +249,20 @@ export class CallApi {
247
249
  });
248
250
  }
249
251
 
252
+ queryCallParticipantSessions(request: {
253
+ session: string;
254
+ limit?: number;
255
+ prev?: string;
256
+ next?: string;
257
+ filter_conditions?: Record<string, any>;
258
+ }): Promise<StreamResponse<QueryCallParticipantSessionsResponse>> {
259
+ return this.videoApi.queryCallParticipantSessions({
260
+ id: this.id,
261
+ type: this.type,
262
+ ...request,
263
+ });
264
+ }
265
+
250
266
  startHLSBroadcasting(): Promise<
251
267
  StreamResponse<StartHLSBroadcastingResponse>
252
268
  > {
@@ -317,8 +333,14 @@ export class CallApi {
317
333
  return this.videoApi.stopLive({ id: this.id, type: this.type, ...request });
318
334
  }
319
335
 
320
- stopRecording(): Promise<StreamResponse<StopRecordingResponse>> {
321
- return this.videoApi.stopRecording({ id: this.id, type: this.type });
336
+ stopRecording(
337
+ request?: StopRecordingRequest,
338
+ ): Promise<StreamResponse<StopRecordingResponse>> {
339
+ return this.videoApi.stopRecording({
340
+ id: this.id,
341
+ type: this.type,
342
+ ...request,
343
+ });
322
344
  }
323
345
 
324
346
  stopTranscription(
@@ -40,6 +40,7 @@ import {
40
40
  QueryAggregateCallStatsResponse,
41
41
  QueryCallMembersRequest,
42
42
  QueryCallMembersResponse,
43
+ QueryCallParticipantSessionsResponse,
43
44
  QueryCallParticipantsRequest,
44
45
  QueryCallParticipantsResponse,
45
46
  QueryCallSessionParticipantStatsResponse,
@@ -83,6 +84,7 @@ import {
83
84
  StopLiveResponse,
84
85
  StopRTMPBroadcastsRequest,
85
86
  StopRTMPBroadcastsResponse,
87
+ StopRecordingRequest,
86
88
  StopRecordingResponse,
87
89
  StopTranscriptionRequest,
88
90
  StopTranscriptionResponse,
@@ -454,7 +456,10 @@ export class VideoApi {
454
456
  const body = {
455
457
  recording_storage_name: request?.recording_storage_name,
456
458
  start_closed_caption: request?.start_closed_caption,
459
+ start_composite_recording: request?.start_composite_recording,
457
460
  start_hls: request?.start_hls,
461
+ start_individual_recording: request?.start_individual_recording,
462
+ start_raw_recording: request?.start_raw_recording,
458
463
  start_recording: request?.start_recording,
459
464
  start_transcription: request?.start_transcription,
460
465
  transcription_storage_name: request?.transcription_storage_name,
@@ -806,6 +811,41 @@ export class VideoApi {
806
811
  return { ...response.body, metadata: response.metadata };
807
812
  }
808
813
 
814
+ async queryCallParticipantSessions(request: {
815
+ type: string;
816
+ id: string;
817
+ session: string;
818
+ limit?: number;
819
+ prev?: string;
820
+ next?: string;
821
+ filter_conditions?: Record<string, any>;
822
+ }): Promise<StreamResponse<QueryCallParticipantSessionsResponse>> {
823
+ const queryParams = {
824
+ limit: request?.limit,
825
+ prev: request?.prev,
826
+ next: request?.next,
827
+ filter_conditions: request?.filter_conditions,
828
+ };
829
+ const pathParams = {
830
+ type: request?.type,
831
+ id: request?.id,
832
+ session: request?.session,
833
+ };
834
+
835
+ const response = await this.apiClient.sendRequest<
836
+ StreamResponse<QueryCallParticipantSessionsResponse>
837
+ >(
838
+ 'GET',
839
+ '/api/v2/video/call/{type}/{id}/session/{session}/participant_sessions',
840
+ pathParams,
841
+ queryParams,
842
+ );
843
+
844
+ decoders.QueryCallParticipantSessionsResponse?.(response.body);
845
+
846
+ return { ...response.body, metadata: response.metadata };
847
+ }
848
+
809
849
  async startHLSBroadcasting(request: {
810
850
  type: string;
811
851
  id: string;
@@ -1024,7 +1064,10 @@ export class VideoApi {
1024
1064
  };
1025
1065
  const body = {
1026
1066
  continue_closed_caption: request?.continue_closed_caption,
1067
+ continue_composite_recording: request?.continue_composite_recording,
1027
1068
  continue_hls: request?.continue_hls,
1069
+ continue_individual_recording: request?.continue_individual_recording,
1070
+ continue_raw_recording: request?.continue_raw_recording,
1028
1071
  continue_recording: request?.continue_recording,
1029
1072
  continue_rtmp_broadcasts: request?.continue_rtmp_broadcasts,
1030
1073
  continue_transcription: request?.continue_transcription,
@@ -1046,14 +1089,14 @@ export class VideoApi {
1046
1089
  return { ...response.body, metadata: response.metadata };
1047
1090
  }
1048
1091
 
1049
- async stopRecording(request: {
1050
- type: string;
1051
- id: string;
1052
- }): Promise<StreamResponse<StopRecordingResponse>> {
1092
+ async stopRecording(
1093
+ request: StopRecordingRequest & { type: string; id: string },
1094
+ ): Promise<StreamResponse<StopRecordingResponse>> {
1053
1095
  const pathParams = {
1054
1096
  type: request?.type,
1055
1097
  id: request?.id,
1056
1098
  };
1099
+ const body = {};
1057
1100
 
1058
1101
  const response = await this.apiClient.sendRequest<
1059
1102
  StreamResponse<StopRecordingResponse>
@@ -1062,6 +1105,8 @@ export class VideoApi {
1062
1105
  '/api/v2/video/call/{type}/{id}/stop_recording',
1063
1106
  pathParams,
1064
1107
  undefined,
1108
+ body,
1109
+ 'application/json',
1065
1110
  );
1066
1111
 
1067
1112
  decoders.StopRecordingResponse?.(response.body);
@@ -1545,38 +1590,12 @@ export class VideoApi {
1545
1590
  return { ...response.body, metadata: response.metadata };
1546
1591
  }
1547
1592
 
1548
- async resolveSipInbound(
1549
- request: ResolveSipInboundRequest,
1550
- ): Promise<StreamResponse<ResolveSipInboundResponse>> {
1551
- const body = {
1552
- sip_caller_number: request?.sip_caller_number,
1553
- sip_trunk_number: request?.sip_trunk_number,
1554
- challenge: request?.challenge,
1555
- sip_headers: request?.sip_headers,
1556
- };
1557
-
1558
- const response = await this.apiClient.sendRequest<
1559
- StreamResponse<ResolveSipInboundResponse>
1560
- >(
1561
- 'POST',
1562
- '/api/v2/video/sip/resolve',
1563
- undefined,
1564
- undefined,
1565
- body,
1566
- 'application/json',
1567
- );
1568
-
1569
- decoders.ResolveSipInboundResponse?.(response.body);
1570
-
1571
- return { ...response.body, metadata: response.metadata };
1572
- }
1573
-
1574
1593
  async listSIPInboundRoutingRule(): Promise<
1575
1594
  StreamResponse<ListSIPInboundRoutingRuleResponse>
1576
1595
  > {
1577
1596
  const response = await this.apiClient.sendRequest<
1578
1597
  StreamResponse<ListSIPInboundRoutingRuleResponse>
1579
- >('GET', '/api/v2/video/sip/routing_rules', undefined, undefined);
1598
+ >('GET', '/api/v2/video/sip/inbound_routing_rules', undefined, undefined);
1580
1599
 
1581
1600
  decoders.ListSIPInboundRoutingRuleResponse?.(response.body);
1582
1601
 
@@ -1602,7 +1621,7 @@ export class VideoApi {
1602
1621
  StreamResponse<SIPInboundRoutingRuleResponse>
1603
1622
  >(
1604
1623
  'POST',
1605
- '/api/v2/video/sip/routing_rules',
1624
+ '/api/v2/video/sip/inbound_routing_rules',
1606
1625
  undefined,
1607
1626
  undefined,
1608
1627
  body,
@@ -1623,7 +1642,12 @@ export class VideoApi {
1623
1642
 
1624
1643
  const response = await this.apiClient.sendRequest<
1625
1644
  StreamResponse<DeleteSIPInboundRoutingRuleResponse>
1626
- >('DELETE', '/api/v2/video/sip/routing_rules/{id}', pathParams, undefined);
1645
+ >(
1646
+ 'DELETE',
1647
+ '/api/v2/video/sip/inbound_routing_rules/{id}',
1648
+ pathParams,
1649
+ undefined,
1650
+ );
1627
1651
 
1628
1652
  decoders.DeleteSIPInboundRoutingRuleResponse?.(response.body);
1629
1653
 
@@ -1652,7 +1676,7 @@ export class VideoApi {
1652
1676
  StreamResponse<UpdateSIPInboundRoutingRuleResponse>
1653
1677
  >(
1654
1678
  'PUT',
1655
- '/api/v2/video/sip/routing_rules/{id}',
1679
+ '/api/v2/video/sip/inbound_routing_rules/{id}',
1656
1680
  pathParams,
1657
1681
  undefined,
1658
1682
  body,
@@ -1667,7 +1691,7 @@ export class VideoApi {
1667
1691
  async listSIPTrunks(): Promise<StreamResponse<ListSIPTrunksResponse>> {
1668
1692
  const response = await this.apiClient.sendRequest<
1669
1693
  StreamResponse<ListSIPTrunksResponse>
1670
- >('GET', '/api/v2/video/sip/trunks', undefined, undefined);
1694
+ >('GET', '/api/v2/video/sip/inbound_trunks', undefined, undefined);
1671
1695
 
1672
1696
  decoders.ListSIPTrunksResponse?.(response.body);
1673
1697
 
@@ -1686,7 +1710,7 @@ export class VideoApi {
1686
1710
  StreamResponse<CreateSIPTrunkResponse>
1687
1711
  >(
1688
1712
  'POST',
1689
- '/api/v2/video/sip/trunks',
1713
+ '/api/v2/video/sip/inbound_trunks',
1690
1714
  undefined,
1691
1715
  undefined,
1692
1716
  body,
@@ -1707,7 +1731,7 @@ export class VideoApi {
1707
1731
 
1708
1732
  const response = await this.apiClient.sendRequest<
1709
1733
  StreamResponse<DeleteSIPTrunkResponse>
1710
- >('DELETE', '/api/v2/video/sip/trunks/{id}', pathParams, undefined);
1734
+ >('DELETE', '/api/v2/video/sip/inbound_trunks/{id}', pathParams, undefined);
1711
1735
 
1712
1736
  decoders.DeleteSIPTrunkResponse?.(response.body);
1713
1737
 
@@ -1729,7 +1753,7 @@ export class VideoApi {
1729
1753
  StreamResponse<UpdateSIPTrunkResponse>
1730
1754
  >(
1731
1755
  'PUT',
1732
- '/api/v2/video/sip/trunks/{id}',
1756
+ '/api/v2/video/sip/inbound_trunks/{id}',
1733
1757
  pathParams,
1734
1758
  undefined,
1735
1759
  body,
@@ -1741,6 +1765,33 @@ export class VideoApi {
1741
1765
  return { ...response.body, metadata: response.metadata };
1742
1766
  }
1743
1767
 
1768
+ async resolveSipInbound(
1769
+ request: ResolveSipInboundRequest,
1770
+ ): Promise<StreamResponse<ResolveSipInboundResponse>> {
1771
+ const body = {
1772
+ sip_caller_number: request?.sip_caller_number,
1773
+ sip_trunk_number: request?.sip_trunk_number,
1774
+ challenge: request?.challenge,
1775
+ routing_number: request?.routing_number,
1776
+ sip_headers: request?.sip_headers,
1777
+ };
1778
+
1779
+ const response = await this.apiClient.sendRequest<
1780
+ StreamResponse<ResolveSipInboundResponse>
1781
+ >(
1782
+ 'POST',
1783
+ '/api/v2/video/sip/resolve',
1784
+ undefined,
1785
+ undefined,
1786
+ body,
1787
+ 'application/json',
1788
+ );
1789
+
1790
+ decoders.ResolveSipInboundResponse?.(response.body);
1791
+
1792
+ return { ...response.body, metadata: response.metadata };
1793
+ }
1794
+
1744
1795
  async queryAggregateCallStats(
1745
1796
  request?: QueryAggregateCallStatsRequest,
1746
1797
  ): Promise<StreamResponse<QueryAggregateCallStatsResponse>> {