@djangocfg/api 1.2.23 → 1.2.25
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.
- package/dist/index.cjs +2770 -23332
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +1908 -19148
- package/dist/index.d.ts +1908 -19148
- package/dist/index.mjs +2705 -23279
- package/dist/index.mjs.map +1 -1
- package/package.json +2 -2
- package/src/cfg/contexts/index.ts +0 -11
- package/src/cfg/generated/_utils/fetchers/cfg__centrifugo.ts +3 -2
- package/src/cfg/generated/_utils/fetchers/cfg__centrifugo__centrifugo_auth.ts +48 -0
- package/src/cfg/generated/_utils/fetchers/cfg__centrifugo__centrifugo_monitoring.ts +5 -5
- package/src/cfg/generated/_utils/fetchers/cfg__centrifugo__centrifugo_testing.ts +0 -16
- package/src/cfg/generated/_utils/fetchers/cfg__grpc__grpc_api_keys.ts +78 -0
- package/src/cfg/generated/_utils/fetchers/cfg__grpc__grpc_monitoring.ts +5 -20
- package/src/cfg/generated/_utils/fetchers/cfg__grpc__grpc_proto_files.ts +91 -0
- package/src/cfg/generated/_utils/fetchers/cfg__grpc__grpc_services.ts +5 -4
- package/src/cfg/generated/_utils/fetchers/cfg__rq__rq_jobs.ts +10 -8
- package/src/cfg/generated/_utils/fetchers/cfg__rq__rq_registries.ts +24 -22
- package/src/cfg/generated/_utils/fetchers/cfg__rq__rq_schedules.ts +5 -4
- package/src/cfg/generated/_utils/fetchers/index.ts +3 -0
- package/src/cfg/generated/_utils/hooks/cfg__accounts.ts +0 -1
- package/src/cfg/generated/_utils/hooks/cfg__accounts__auth.ts +0 -1
- package/src/cfg/generated/_utils/hooks/cfg__centrifugo.ts +3 -3
- package/src/cfg/generated/_utils/hooks/cfg__centrifugo__centrifugo_admin_api.ts +0 -1
- package/src/cfg/generated/_utils/hooks/cfg__centrifugo__centrifugo_auth.ts +35 -0
- package/src/cfg/generated/_utils/hooks/cfg__centrifugo__centrifugo_monitoring.ts +5 -6
- package/src/cfg/generated/_utils/hooks/cfg__centrifugo__centrifugo_testing.ts +0 -21
- package/src/cfg/generated/_utils/hooks/cfg__dashboard__dashboard_activity.ts +0 -1
- package/src/cfg/generated/_utils/hooks/cfg__dashboard__dashboard_api_zones.ts +0 -1
- package/src/cfg/generated/_utils/hooks/cfg__dashboard__dashboard_charts.ts +0 -1
- package/src/cfg/generated/_utils/hooks/cfg__dashboard__dashboard_config.ts +0 -1
- package/src/cfg/generated/_utils/hooks/cfg__dashboard__dashboard_overview.ts +0 -1
- package/src/cfg/generated/_utils/hooks/cfg__dashboard__dashboard_statistics.ts +0 -1
- package/src/cfg/generated/_utils/hooks/cfg__dashboard__dashboard_system.ts +0 -1
- package/src/cfg/generated/_utils/hooks/cfg__endpoints.ts +0 -1
- package/src/cfg/generated/_utils/hooks/cfg__grpc__grpc_api_keys.ts +65 -0
- package/src/cfg/generated/_utils/hooks/cfg__grpc__grpc_charts.ts +0 -1
- package/src/cfg/generated/_utils/hooks/cfg__grpc__grpc_configuration.ts +0 -1
- package/src/cfg/generated/_utils/hooks/cfg__grpc__grpc_monitoring.ts +5 -21
- package/src/cfg/generated/_utils/hooks/cfg__grpc__grpc_proto_files.ts +83 -0
- package/src/cfg/generated/_utils/hooks/cfg__grpc__grpc_services.ts +3 -3
- package/src/cfg/generated/_utils/hooks/cfg__health.ts +0 -1
- package/src/cfg/generated/_utils/hooks/cfg__leads__lead_submission.ts +0 -1
- package/src/cfg/generated/_utils/hooks/cfg__newsletter.ts +0 -1
- package/src/cfg/generated/_utils/hooks/cfg__newsletter__bulk_email.ts +0 -1
- package/src/cfg/generated/_utils/hooks/cfg__newsletter__logs.ts +0 -1
- package/src/cfg/generated/_utils/hooks/cfg__newsletter__newsletters.ts +0 -1
- package/src/cfg/generated/_utils/hooks/cfg__newsletter__testing.ts +0 -1
- package/src/cfg/generated/_utils/hooks/cfg__rq__rq_jobs.ts +8 -6
- package/src/cfg/generated/_utils/hooks/cfg__rq__rq_monitoring.ts +0 -1
- package/src/cfg/generated/_utils/hooks/cfg__rq__rq_registries.ts +16 -14
- package/src/cfg/generated/_utils/hooks/cfg__rq__rq_schedules.ts +3 -2
- package/src/cfg/generated/_utils/hooks/cfg__rq__rq_workers.ts +0 -1
- package/src/cfg/generated/_utils/hooks/index.ts +3 -0
- package/src/cfg/generated/_utils/schemas/ApiKey.schema.ts +32 -0
- package/src/cfg/generated/_utils/schemas/ApiKeyStats.schema.ts +23 -0
- package/src/cfg/generated/_utils/schemas/CentrifugoToken.schema.ts +22 -0
- package/src/cfg/generated/_utils/schemas/Command.schema.ts +13 -0
- package/src/cfg/generated/_utils/schemas/ConnectionTokenResponse.schema.ts +3 -2
- package/src/cfg/generated/_utils/schemas/DashboardCharts.schema.ts +10 -10
- package/src/cfg/generated/_utils/schemas/GRPCCallRequestRequest.schema.ts +2 -2
- package/src/cfg/generated/_utils/schemas/GRPCConfig.schema.ts +6 -6
- package/src/cfg/generated/_utils/schemas/{GRPCExampleSerializer.schema.ts → GRPCExample.schema.ts} +3 -3
- package/src/cfg/generated/_utils/schemas/GRPCExamplesList.schema.ts +2 -2
- package/src/cfg/generated/_utils/schemas/{GRPCFeaturesSerializer.schema.ts → GRPCFeatures.schema.ts} +4 -4
- package/src/cfg/generated/_utils/schemas/{GRPCFrameworkConfigSerializer.schema.ts → GRPCFrameworkConfig.schema.ts} +3 -3
- package/src/cfg/generated/_utils/schemas/{GRPCInterceptorInfoSerializer.schema.ts → GRPCInterceptorInfo.schema.ts} +3 -3
- package/src/cfg/generated/_utils/schemas/GRPCOverviewStats.schema.ts +3 -1
- package/src/cfg/generated/_utils/schemas/GRPCRegisteredService.schema.ts +24 -0
- package/src/cfg/generated/_utils/schemas/{GRPCServerConfigSerializer.schema.ts → GRPCServerConfig.schema.ts} +4 -4
- package/src/cfg/generated/_utils/schemas/GRPCServerInfo.schema.ts +6 -6
- package/src/cfg/generated/_utils/schemas/GRPCServerStatus.schema.ts +34 -0
- package/src/cfg/generated/_utils/schemas/{GRPCServiceInfoSerializer.schema.ts → GRPCServiceInfo.schema.ts} +3 -3
- package/src/cfg/generated/_utils/schemas/{GRPCStatsSerializer.schema.ts → GRPCStats.schema.ts} +3 -3
- package/src/cfg/generated/_utils/schemas/JobListRequest.schema.ts +28 -0
- package/src/cfg/generated/_utils/schemas/{MethodInfoSerializer.schema.ts → MethodInfo.schema.ts} +3 -3
- package/src/cfg/generated/_utils/schemas/MethodList.schema.ts +2 -2
- package/src/cfg/generated/_utils/schemas/{MethodStatsSerializer.schema.ts → MethodStats.schema.ts} +3 -3
- package/src/cfg/generated/_utils/schemas/{MethodSummarySerializer.schema.ts → MethodSummary.schema.ts} +5 -5
- package/src/cfg/generated/_utils/schemas/PaginatedApiKeyList.schema.ts +24 -0
- package/src/cfg/generated/_utils/schemas/PaginatedJobListList.schema.ts +24 -0
- package/src/cfg/generated/_utils/schemas/PaginatedPublishList.schema.ts +24 -0
- package/src/cfg/generated/_utils/schemas/PaginatedRecentRequestList.schema.ts +24 -0
- package/src/cfg/generated/_utils/schemas/PaginatedScheduledJobList.schema.ts +24 -0
- package/src/cfg/generated/_utils/schemas/PaginatedServiceSummaryList.schema.ts +24 -0
- package/src/cfg/generated/_utils/schemas/ProtoFileDetail.schema.ts +27 -0
- package/src/cfg/generated/_utils/schemas/ProtoFileList.schema.ts +23 -0
- package/src/cfg/generated/_utils/schemas/ProtoGenerateError.schema.ts +20 -0
- package/src/cfg/generated/_utils/schemas/ProtoGenerateRequestRequest.schema.ts +20 -0
- package/src/cfg/generated/_utils/schemas/ProtoGenerateResponse.schema.ts +24 -0
- package/src/cfg/generated/_utils/schemas/Publish.schema.ts +29 -0
- package/src/cfg/generated/_utils/schemas/{RecentErrorSerializer.schema.ts → RecentError.schema.ts} +3 -3
- package/src/cfg/generated/_utils/schemas/RecentRequest.schema.ts +5 -0
- package/src/cfg/generated/_utils/schemas/ServiceDetail.schema.ts +6 -6
- package/src/cfg/generated/_utils/schemas/ServiceMethods.schema.ts +2 -2
- package/src/cfg/generated/_utils/schemas/{ServiceStatsSerializer.schema.ts → ServiceStats.schema.ts} +3 -3
- package/src/cfg/generated/_utils/schemas/ServiceSummary.schema.ts +26 -0
- package/src/cfg/generated/_utils/schemas/User.schema.ts +2 -0
- package/src/cfg/generated/_utils/schemas/index.ts +31 -21
- package/src/cfg/generated/cfg__accounts/models.ts +17 -0
- package/src/cfg/generated/cfg__accounts__user_profile/models.ts +17 -0
- package/src/cfg/generated/cfg__centrifugo/client.ts +1 -1
- package/src/cfg/generated/cfg__centrifugo/models.ts +19 -0
- package/src/cfg/generated/cfg__centrifugo__centrifugo_auth/client.ts +26 -0
- package/src/cfg/generated/cfg__centrifugo__centrifugo_auth/index.ts +2 -0
- package/src/cfg/generated/cfg__centrifugo__centrifugo_auth/models.ts +16 -0
- package/src/cfg/generated/cfg__centrifugo__centrifugo_monitoring/client.ts +6 -5
- package/src/cfg/generated/cfg__centrifugo__centrifugo_monitoring/models.ts +37 -11
- package/src/cfg/generated/cfg__centrifugo__centrifugo_testing/client.ts +0 -10
- package/src/cfg/generated/cfg__centrifugo__centrifugo_testing/models.ts +0 -26
- package/src/cfg/generated/cfg__dashboard__dashboard_commands/models.ts +10 -1
- package/src/cfg/generated/cfg__grpc__grpc_api_keys/client.ts +56 -0
- package/src/cfg/generated/cfg__grpc__grpc_api_keys/index.ts +2 -0
- package/src/cfg/generated/cfg__grpc__grpc_api_keys/models.ts +79 -0
- package/src/cfg/generated/cfg__grpc__grpc_charts/models.ts +0 -96
- package/src/cfg/generated/cfg__grpc__grpc_configuration/models.ts +12 -12
- package/src/cfg/generated/cfg__grpc__grpc_monitoring/client.ts +4 -25
- package/src/cfg/generated/cfg__grpc__grpc_monitoring/models.ts +111 -49
- package/src/cfg/generated/cfg__grpc__grpc_proto_files/client.ts +54 -0
- package/src/cfg/generated/cfg__grpc__grpc_proto_files/index.ts +2 -0
- package/src/cfg/generated/cfg__grpc__grpc_proto_files/models.ts +35 -0
- package/src/cfg/generated/cfg__grpc__grpc_services/client.ts +6 -5
- package/src/cfg/generated/cfg__grpc__grpc_services/models.ts +57 -8
- package/src/cfg/generated/cfg__grpc__grpc_testing/models.ts +2 -2
- package/src/cfg/generated/cfg__rq__rq_jobs/client.ts +8 -8
- package/src/cfg/generated/cfg__rq__rq_jobs/models.ts +65 -0
- package/src/cfg/generated/cfg__rq__rq_registries/client.ts +37 -34
- package/src/cfg/generated/cfg__rq__rq_registries/models.ts +65 -0
- package/src/cfg/generated/cfg__rq__rq_schedules/client.ts +4 -4
- package/src/cfg/generated/cfg__rq__rq_schedules/models.ts +25 -0
- package/src/cfg/generated/client.ts +9 -0
- package/src/cfg/generated/index.ts +27 -8
- package/src/cfg/generated/{schema.ts → schema.json} +19166 -18258
- package/src/index.ts +7 -2
- package/src/types/auth.ts +40 -0
- package/src/types/index.ts +7 -0
- package/src/cfg/contexts/AccountsContext.tsx +0 -205
- package/src/cfg/generated/_utils/schemas/ConnectionTokenRequestRequest.schema.ts +0 -20
- package/src/cfg/generated/_utils/schemas/ErrorDistributionChartSerializer.schema.ts +0 -24
- package/src/cfg/generated/_utils/schemas/MonitoringServiceStatsSerializer.schema.ts +0 -24
- package/src/cfg/generated/_utils/schemas/RecentPublishes.schema.ts +0 -23
- package/src/cfg/generated/_utils/schemas/RequestVolumeChartSerializer.schema.ts +0 -25
- package/src/cfg/generated/_utils/schemas/ResponseTimeChartSerializer.schema.ts +0 -25
- package/src/cfg/generated/_utils/schemas/ServerUptimeChartSerializer.schema.ts +0 -25
- package/src/cfg/generated/_utils/schemas/ServiceActivityChartSerializer.schema.ts +0 -24
- package/src/cfg/generated/_utils/schemas/ServiceList.schema.ts +0 -21
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import * as Models from "./models";
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* API endpoints for Centrifugo Auth.
|
|
6
|
+
*/
|
|
7
|
+
export class CfgCentrifugoAuth {
|
|
8
|
+
private client: any;
|
|
9
|
+
|
|
10
|
+
constructor(client: any) {
|
|
11
|
+
this.client = client;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* Get Centrifugo connection token
|
|
16
|
+
*
|
|
17
|
+
* Generate JWT token for WebSocket connection to Centrifugo. Token
|
|
18
|
+
* includes user's allowed channels based on their permissions. Requires
|
|
19
|
+
* authentication.
|
|
20
|
+
*/
|
|
21
|
+
async tokenRetrieve(): Promise<Models.ConnectionTokenResponse> {
|
|
22
|
+
const response = await this.client.request('GET', "/cfg/centrifugo/auth/token/");
|
|
23
|
+
return response;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Response model for Centrifugo connection token.
|
|
3
|
+
*
|
|
4
|
+
* Response model (includes read-only fields).
|
|
5
|
+
*/
|
|
6
|
+
export interface ConnectionTokenResponse {
|
|
7
|
+
/** JWT token for Centrifugo connection */
|
|
8
|
+
token: string;
|
|
9
|
+
/** Centrifugo WebSocket URL */
|
|
10
|
+
centrifugo_url: string;
|
|
11
|
+
/** Token expiration time (ISO 8601) */
|
|
12
|
+
expires_at: string;
|
|
13
|
+
/** List of allowed channels */
|
|
14
|
+
channels: Array<string>;
|
|
15
|
+
}
|
|
16
|
+
|
|
@@ -42,22 +42,23 @@ export class CfgCentrifugoMonitoring {
|
|
|
42
42
|
return response;
|
|
43
43
|
}
|
|
44
44
|
|
|
45
|
-
async
|
|
46
|
-
async
|
|
45
|
+
async centrifugoMonitorPublishesList(channel?: string, page?: number, page_size?: number, status?: string): Promise<Models.PaginatedPublishList>;
|
|
46
|
+
async centrifugoMonitorPublishesList(params?: { channel?: string; page?: number; page_size?: number; status?: string }): Promise<Models.PaginatedPublishList>;
|
|
47
47
|
|
|
48
48
|
/**
|
|
49
49
|
* Get recent publishes
|
|
50
50
|
*
|
|
51
|
-
* Returns a list of recent Centrifugo publishes with their
|
|
51
|
+
* Returns a paginated list of recent Centrifugo publishes with their
|
|
52
|
+
* details. Uses standard DRF pagination.
|
|
52
53
|
*/
|
|
53
|
-
async
|
|
54
|
+
async centrifugoMonitorPublishesList(...args: any[]): Promise<Models.PaginatedPublishList> {
|
|
54
55
|
const isParamsObject = args.length === 1 && typeof args[0] === 'object' && args[0] !== null && !Array.isArray(args[0]);
|
|
55
56
|
|
|
56
57
|
let params;
|
|
57
58
|
if (isParamsObject) {
|
|
58
59
|
params = args[0];
|
|
59
60
|
} else {
|
|
60
|
-
params = { channel: args[0],
|
|
61
|
+
params = { channel: args[0], page: args[1], page_size: args[2], status: args[3] };
|
|
61
62
|
}
|
|
62
63
|
const response = await this.client.request('GET', "/cfg/centrifugo/monitor/publishes/", { params });
|
|
63
64
|
return response;
|
|
@@ -39,21 +39,28 @@ export interface CentrifugoOverviewStats {
|
|
|
39
39
|
}
|
|
40
40
|
|
|
41
41
|
/**
|
|
42
|
-
* Recent publishes list.
|
|
43
42
|
*
|
|
44
43
|
* Response model (includes read-only fields).
|
|
45
44
|
*/
|
|
46
|
-
export interface
|
|
47
|
-
/**
|
|
48
|
-
publishes: Array<Record<string, any>>;
|
|
49
|
-
/** Number of publishes returned */
|
|
45
|
+
export interface PaginatedPublishList {
|
|
46
|
+
/** Total number of items across all pages */
|
|
50
47
|
count: number;
|
|
51
|
-
/**
|
|
52
|
-
|
|
53
|
-
/**
|
|
54
|
-
|
|
55
|
-
/**
|
|
56
|
-
|
|
48
|
+
/** Current page number (1-based) */
|
|
49
|
+
page: number;
|
|
50
|
+
/** Total number of pages */
|
|
51
|
+
pages: number;
|
|
52
|
+
/** Number of items per page */
|
|
53
|
+
page_size: number;
|
|
54
|
+
/** Whether there is a next page */
|
|
55
|
+
has_next: boolean;
|
|
56
|
+
/** Whether there is a previous page */
|
|
57
|
+
has_previous: boolean;
|
|
58
|
+
/** Next page number (null if no next page) */
|
|
59
|
+
next_page?: number | null;
|
|
60
|
+
/** Previous page number (null if no previous page) */
|
|
61
|
+
previous_page?: number | null;
|
|
62
|
+
/** Array of items for current page */
|
|
63
|
+
results: Array<Publish>;
|
|
57
64
|
}
|
|
58
65
|
|
|
59
66
|
/**
|
|
@@ -68,6 +75,25 @@ export interface ChannelList {
|
|
|
68
75
|
total_channels: number;
|
|
69
76
|
}
|
|
70
77
|
|
|
78
|
+
/**
|
|
79
|
+
* Single publish item for DRF pagination.
|
|
80
|
+
*
|
|
81
|
+
* Response model (includes read-only fields).
|
|
82
|
+
*/
|
|
83
|
+
export interface Publish {
|
|
84
|
+
message_id: string;
|
|
85
|
+
channel: string;
|
|
86
|
+
status: string;
|
|
87
|
+
wait_for_ack: boolean;
|
|
88
|
+
acks_received: number;
|
|
89
|
+
acks_expected: number;
|
|
90
|
+
duration_ms: number | null;
|
|
91
|
+
created_at: string;
|
|
92
|
+
completed_at: string | null;
|
|
93
|
+
error_code: string | null;
|
|
94
|
+
error_message: string | null;
|
|
95
|
+
}
|
|
96
|
+
|
|
71
97
|
/**
|
|
72
98
|
* Statistics per channel.
|
|
73
99
|
*
|
|
@@ -11,16 +11,6 @@ export class CfgCentrifugoTesting {
|
|
|
11
11
|
this.client = client;
|
|
12
12
|
}
|
|
13
13
|
|
|
14
|
-
/**
|
|
15
|
-
* Generate connection token
|
|
16
|
-
*
|
|
17
|
-
* Generate JWT token for WebSocket connection to Centrifugo.
|
|
18
|
-
*/
|
|
19
|
-
async connectionTokenCreate(data: Models.ConnectionTokenRequestRequest): Promise<Models.ConnectionTokenResponse> {
|
|
20
|
-
const response = await this.client.request('POST', "/cfg/centrifugo/testing/connection-token/", { body: data });
|
|
21
|
-
return response;
|
|
22
|
-
}
|
|
23
|
-
|
|
24
14
|
/**
|
|
25
15
|
* Publish test message
|
|
26
16
|
*
|
|
@@ -1,29 +1,3 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Request model for connection token generation.
|
|
3
|
-
*
|
|
4
|
-
* Request model (no read-only fields).
|
|
5
|
-
*/
|
|
6
|
-
export interface ConnectionTokenRequestRequest {
|
|
7
|
-
/** User ID for the connection */
|
|
8
|
-
user_id: string;
|
|
9
|
-
/** List of channels to authorize */
|
|
10
|
-
channels?: Array<string>;
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
/**
|
|
14
|
-
* Response model for connection token.
|
|
15
|
-
*
|
|
16
|
-
* Response model (includes read-only fields).
|
|
17
|
-
*/
|
|
18
|
-
export interface ConnectionTokenResponse {
|
|
19
|
-
/** JWT token for WebSocket connection */
|
|
20
|
-
token: string;
|
|
21
|
-
/** Centrifugo WebSocket URL */
|
|
22
|
-
centrifugo_url: string;
|
|
23
|
-
/** Token expiration time (ISO 8601) */
|
|
24
|
-
expires_at: string;
|
|
25
|
-
}
|
|
26
|
-
|
|
27
1
|
/**
|
|
28
2
|
* Request model for test message publishing.
|
|
29
3
|
*
|
|
@@ -42,7 +42,10 @@ export interface CommandsSummary {
|
|
|
42
42
|
}
|
|
43
43
|
|
|
44
44
|
/**
|
|
45
|
-
* Django management command serializer.
|
|
45
|
+
* Django management command serializer. Includes security metadata from base
|
|
46
|
+
* classes (SafeCommand, InteractiveCommand, etc.): - web_executable: Can be
|
|
47
|
+
* executed via web interface - requires_input: Requires interactive user input
|
|
48
|
+
* - is_destructive: Modifies or deletes data
|
|
46
49
|
*
|
|
47
50
|
* Response model (includes read-only fields).
|
|
48
51
|
*/
|
|
@@ -54,5 +57,11 @@ export interface Command {
|
|
|
54
57
|
is_custom: boolean;
|
|
55
58
|
is_allowed?: boolean;
|
|
56
59
|
risk_level?: string;
|
|
60
|
+
/** Can be executed via web interface */
|
|
61
|
+
web_executable?: boolean | null;
|
|
62
|
+
/** Requires interactive user input */
|
|
63
|
+
requires_input?: boolean | null;
|
|
64
|
+
/** Modifies or deletes data */
|
|
65
|
+
is_destructive?: boolean | null;
|
|
57
66
|
}
|
|
58
67
|
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import * as Models from "./models";
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* API endpoints for Grpc Api Keys.
|
|
6
|
+
*/
|
|
7
|
+
export class CfgGrpcApiKeys {
|
|
8
|
+
private client: any;
|
|
9
|
+
|
|
10
|
+
constructor(client: any) {
|
|
11
|
+
this.client = client;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
async list(is_active?: boolean, key_type?: string, page?: number, page_size?: number, user_id?: number): Promise<Models.PaginatedApiKeyList>;
|
|
15
|
+
async list(params?: { is_active?: boolean; key_type?: string; page?: number; page_size?: number; user_id?: number }): Promise<Models.PaginatedApiKeyList>;
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* List API keys
|
|
19
|
+
*
|
|
20
|
+
* Returns a list of all API keys with their details. Uses standard DRF
|
|
21
|
+
* pagination.
|
|
22
|
+
*/
|
|
23
|
+
async list(...args: any[]): Promise<Models.PaginatedApiKeyList> {
|
|
24
|
+
const isParamsObject = args.length === 1 && typeof args[0] === 'object' && args[0] !== null && !Array.isArray(args[0]);
|
|
25
|
+
|
|
26
|
+
let params;
|
|
27
|
+
if (isParamsObject) {
|
|
28
|
+
params = args[0];
|
|
29
|
+
} else {
|
|
30
|
+
params = { is_active: args[0], key_type: args[1], page: args[2], page_size: args[3], user_id: args[4] };
|
|
31
|
+
}
|
|
32
|
+
const response = await this.client.request('GET', "/cfg/grpc/api-keys/", { params });
|
|
33
|
+
return response;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
/**
|
|
37
|
+
* Get API key details
|
|
38
|
+
*
|
|
39
|
+
* Returns detailed information about a specific API key.
|
|
40
|
+
*/
|
|
41
|
+
async retrieve(id: number): Promise<Models.ApiKey> {
|
|
42
|
+
const response = await this.client.request('GET', `/cfg/grpc/api-keys/${id}/`);
|
|
43
|
+
return response;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
/**
|
|
47
|
+
* Get API keys statistics
|
|
48
|
+
*
|
|
49
|
+
* Returns overall statistics about API keys usage.
|
|
50
|
+
*/
|
|
51
|
+
async statsRetrieve(): Promise<Models.ApiKeyStats> {
|
|
52
|
+
const response = await this.client.request('GET', "/cfg/grpc/api-keys/stats/");
|
|
53
|
+
return response;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
/**
|
|
2
|
+
*
|
|
3
|
+
* Response model (includes read-only fields).
|
|
4
|
+
*/
|
|
5
|
+
export interface PaginatedApiKeyList {
|
|
6
|
+
/** Total number of items across all pages */
|
|
7
|
+
count: number;
|
|
8
|
+
/** Current page number (1-based) */
|
|
9
|
+
page: number;
|
|
10
|
+
/** Total number of pages */
|
|
11
|
+
pages: number;
|
|
12
|
+
/** Number of items per page */
|
|
13
|
+
page_size: number;
|
|
14
|
+
/** Whether there is a next page */
|
|
15
|
+
has_next: boolean;
|
|
16
|
+
/** Whether there is a previous page */
|
|
17
|
+
has_previous: boolean;
|
|
18
|
+
/** Next page number (null if no next page) */
|
|
19
|
+
next_page?: number | null;
|
|
20
|
+
/** Previous page number (null if no previous page) */
|
|
21
|
+
previous_page?: number | null;
|
|
22
|
+
/** Array of items for current page */
|
|
23
|
+
results: Array<ApiKey>;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
/**
|
|
27
|
+
* API Key information (read-only).
|
|
28
|
+
*
|
|
29
|
+
* Response model (includes read-only fields).
|
|
30
|
+
*/
|
|
31
|
+
export interface ApiKey {
|
|
32
|
+
/** Database ID */
|
|
33
|
+
id: number;
|
|
34
|
+
/** Key name/description */
|
|
35
|
+
name: string;
|
|
36
|
+
/** Type of API key */
|
|
37
|
+
key_type: string;
|
|
38
|
+
/** Masked API key (first 4 and last 4 chars) */
|
|
39
|
+
masked_key: string;
|
|
40
|
+
/** Whether key is active */
|
|
41
|
+
is_active: boolean;
|
|
42
|
+
/** Whether key is valid (active and not expired) */
|
|
43
|
+
is_valid: boolean;
|
|
44
|
+
/** User ID */
|
|
45
|
+
user_id: number;
|
|
46
|
+
/** Username */
|
|
47
|
+
username: string;
|
|
48
|
+
/** User email */
|
|
49
|
+
user_email: string;
|
|
50
|
+
/** Total requests made with this key */
|
|
51
|
+
request_count: number;
|
|
52
|
+
/** When key was last used */
|
|
53
|
+
last_used_at: string | null;
|
|
54
|
+
/** When key expires (null = never) */
|
|
55
|
+
expires_at: string | null;
|
|
56
|
+
/** When key was created */
|
|
57
|
+
created_at: string;
|
|
58
|
+
/** User who created this key */
|
|
59
|
+
created_by: string | null;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
/**
|
|
63
|
+
* API Key usage statistics.
|
|
64
|
+
*
|
|
65
|
+
* Response model (includes read-only fields).
|
|
66
|
+
*/
|
|
67
|
+
export interface ApiKeyStats {
|
|
68
|
+
/** Total API keys */
|
|
69
|
+
total_keys: number;
|
|
70
|
+
/** Active API keys */
|
|
71
|
+
active_keys: number;
|
|
72
|
+
/** Expired API keys */
|
|
73
|
+
expired_keys: number;
|
|
74
|
+
/** Total requests across all keys */
|
|
75
|
+
total_requests: number;
|
|
76
|
+
/** Count of keys by type */
|
|
77
|
+
keys_by_type: Record<string, any>;
|
|
78
|
+
}
|
|
79
|
+
|
|
@@ -131,102 +131,6 @@ export interface ServiceActivityChart {
|
|
|
131
131
|
most_active_service?: string | null;
|
|
132
132
|
}
|
|
133
133
|
|
|
134
|
-
/**
|
|
135
|
-
* Server uptime over time chart data.
|
|
136
|
-
*
|
|
137
|
-
* Response model (includes read-only fields).
|
|
138
|
-
*/
|
|
139
|
-
export interface ServerUptimeChartSerializer {
|
|
140
|
-
/** Chart title */
|
|
141
|
-
title?: string;
|
|
142
|
-
/** Uptime data points */
|
|
143
|
-
data_points?: Array<ServerUptimeDataPoint>;
|
|
144
|
-
/** Period in hours */
|
|
145
|
-
period_hours: number;
|
|
146
|
-
/** Data granularity */
|
|
147
|
-
granularity: string;
|
|
148
|
-
/** Total unique servers in period */
|
|
149
|
-
total_servers: number;
|
|
150
|
-
/** Currently running servers */
|
|
151
|
-
currently_running: number;
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
/**
|
|
155
|
-
* Request volume over time chart data.
|
|
156
|
-
*
|
|
157
|
-
* Response model (includes read-only fields).
|
|
158
|
-
*/
|
|
159
|
-
export interface RequestVolumeChartSerializer {
|
|
160
|
-
/** Chart title */
|
|
161
|
-
title?: string;
|
|
162
|
-
/** Volume data points */
|
|
163
|
-
data_points?: Array<RequestVolumeDataPoint>;
|
|
164
|
-
/** Period in hours */
|
|
165
|
-
period_hours: number;
|
|
166
|
-
/** Data granularity */
|
|
167
|
-
granularity: string;
|
|
168
|
-
/** Total requests in period */
|
|
169
|
-
total_requests: number;
|
|
170
|
-
/** Average success rate */
|
|
171
|
-
avg_success_rate: number;
|
|
172
|
-
}
|
|
173
|
-
|
|
174
|
-
/**
|
|
175
|
-
* Response time over time chart data.
|
|
176
|
-
*
|
|
177
|
-
* Response model (includes read-only fields).
|
|
178
|
-
*/
|
|
179
|
-
export interface ResponseTimeChartSerializer {
|
|
180
|
-
/** Chart title */
|
|
181
|
-
title?: string;
|
|
182
|
-
/** Response time data points */
|
|
183
|
-
data_points?: Array<ResponseTimeDataPoint>;
|
|
184
|
-
/** Period in hours */
|
|
185
|
-
period_hours: number;
|
|
186
|
-
/** Data granularity */
|
|
187
|
-
granularity: string;
|
|
188
|
-
/** Overall average duration */
|
|
189
|
-
overall_avg_ms: number;
|
|
190
|
-
/** Overall P95 duration */
|
|
191
|
-
overall_p95_ms: number;
|
|
192
|
-
}
|
|
193
|
-
|
|
194
|
-
/**
|
|
195
|
-
* Service activity comparison chart data.
|
|
196
|
-
*
|
|
197
|
-
* Response model (includes read-only fields).
|
|
198
|
-
*/
|
|
199
|
-
export interface ServiceActivityChartSerializer {
|
|
200
|
-
/** Chart title */
|
|
201
|
-
title?: string;
|
|
202
|
-
/** Service activity data */
|
|
203
|
-
services?: Array<ServiceActivityDataPoint>;
|
|
204
|
-
/** Period in hours */
|
|
205
|
-
period_hours: number;
|
|
206
|
-
/** Total number of services */
|
|
207
|
-
total_services: number;
|
|
208
|
-
/** Most active service name */
|
|
209
|
-
most_active_service?: string | null;
|
|
210
|
-
}
|
|
211
|
-
|
|
212
|
-
/**
|
|
213
|
-
* Error distribution chart data.
|
|
214
|
-
*
|
|
215
|
-
* Response model (includes read-only fields).
|
|
216
|
-
*/
|
|
217
|
-
export interface ErrorDistributionChartSerializer {
|
|
218
|
-
/** Chart title */
|
|
219
|
-
title?: string;
|
|
220
|
-
/** Error distribution data */
|
|
221
|
-
error_types?: Array<ErrorDistributionDataPoint>;
|
|
222
|
-
/** Period in hours */
|
|
223
|
-
period_hours: number;
|
|
224
|
-
/** Total number of errors */
|
|
225
|
-
total_errors: number;
|
|
226
|
-
/** Most common error code */
|
|
227
|
-
most_common_error?: string | null;
|
|
228
|
-
}
|
|
229
|
-
|
|
230
134
|
/**
|
|
231
135
|
* Error distribution data point.
|
|
232
136
|
*
|
|
@@ -28,9 +28,9 @@ export interface GRPCServerInfo {
|
|
|
28
28
|
/** Server uptime in seconds */
|
|
29
29
|
uptime_seconds?: number | null;
|
|
30
30
|
/** Registered services */
|
|
31
|
-
services?: Array<
|
|
31
|
+
services?: Array<GRPCServiceInfo>;
|
|
32
32
|
/** Active interceptors */
|
|
33
|
-
interceptors?: Array<
|
|
33
|
+
interceptors?: Array<GRPCInterceptorInfo>;
|
|
34
34
|
stats: Record<string, any>;
|
|
35
35
|
}
|
|
36
36
|
|
|
@@ -39,15 +39,15 @@ export interface GRPCServerInfo {
|
|
|
39
39
|
*
|
|
40
40
|
* Response model (includes read-only fields).
|
|
41
41
|
*/
|
|
42
|
-
export interface
|
|
42
|
+
export interface GRPCServerConfig {
|
|
43
43
|
/** Server host address */
|
|
44
44
|
host: string;
|
|
45
45
|
/** Server port */
|
|
46
46
|
port: number;
|
|
47
47
|
/** Whether gRPC server is enabled */
|
|
48
48
|
enabled: boolean;
|
|
49
|
-
/** Maximum
|
|
50
|
-
|
|
49
|
+
/** Maximum concurrent streams (async server) */
|
|
50
|
+
max_concurrent_streams?: number | null;
|
|
51
51
|
/** Maximum concurrent RPCs */
|
|
52
52
|
max_concurrent_rpcs?: number | null;
|
|
53
53
|
}
|
|
@@ -57,7 +57,7 @@ export interface GRPCServerConfigSerializer {
|
|
|
57
57
|
*
|
|
58
58
|
* Response model (includes read-only fields).
|
|
59
59
|
*/
|
|
60
|
-
export interface
|
|
60
|
+
export interface GRPCFrameworkConfig {
|
|
61
61
|
/** Whether framework is enabled */
|
|
62
62
|
enabled: boolean;
|
|
63
63
|
/** Auto-discover services */
|
|
@@ -73,9 +73,9 @@ export interface GRPCFrameworkConfigSerializer {
|
|
|
73
73
|
*
|
|
74
74
|
* Response model (includes read-only fields).
|
|
75
75
|
*/
|
|
76
|
-
export interface
|
|
77
|
-
/**
|
|
78
|
-
|
|
76
|
+
export interface GRPCFeatures {
|
|
77
|
+
/** API key authentication enabled */
|
|
78
|
+
api_key_auth: boolean;
|
|
79
79
|
/** Request logging enabled */
|
|
80
80
|
request_logging: boolean;
|
|
81
81
|
/** Metrics collection enabled */
|
|
@@ -89,7 +89,7 @@ export interface GRPCFeaturesSerializer {
|
|
|
89
89
|
*
|
|
90
90
|
* Response model (includes read-only fields).
|
|
91
91
|
*/
|
|
92
|
-
export interface
|
|
92
|
+
export interface GRPCServiceInfo {
|
|
93
93
|
/** Service name */
|
|
94
94
|
name: string;
|
|
95
95
|
/** Service methods */
|
|
@@ -105,7 +105,7 @@ export interface GRPCServiceInfoSerializer {
|
|
|
105
105
|
*
|
|
106
106
|
* Response model (includes read-only fields).
|
|
107
107
|
*/
|
|
108
|
-
export interface
|
|
108
|
+
export interface GRPCInterceptorInfo {
|
|
109
109
|
/** Interceptor name */
|
|
110
110
|
name: string;
|
|
111
111
|
/** Whether interceptor is enabled */
|
|
@@ -117,7 +117,7 @@ export interface GRPCInterceptorInfoSerializer {
|
|
|
117
117
|
*
|
|
118
118
|
* Response model (includes read-only fields).
|
|
119
119
|
*/
|
|
120
|
-
export interface
|
|
120
|
+
export interface GRPCStats {
|
|
121
121
|
/** Total number of requests */
|
|
122
122
|
total_requests: number;
|
|
123
123
|
/** Success rate percentage */
|
|
@@ -63,8 +63,8 @@ export class CfgGrpcMonitoring {
|
|
|
63
63
|
return response;
|
|
64
64
|
}
|
|
65
65
|
|
|
66
|
-
async
|
|
67
|
-
async
|
|
66
|
+
async grpcMonitorRequestsList(method?: string, page?: number, page_size?: number, service?: string, status?: string): Promise<Models.PaginatedRecentRequestList>;
|
|
67
|
+
async grpcMonitorRequestsList(params?: { method?: string; page?: number; page_size?: number; service?: string; status?: string }): Promise<Models.PaginatedRecentRequestList>;
|
|
68
68
|
|
|
69
69
|
/**
|
|
70
70
|
* Get recent requests
|
|
@@ -72,40 +72,19 @@ export class CfgGrpcMonitoring {
|
|
|
72
72
|
* Returns a list of recent gRPC requests with their details. Uses standard
|
|
73
73
|
* DRF pagination.
|
|
74
74
|
*/
|
|
75
|
-
async
|
|
75
|
+
async grpcMonitorRequestsList(...args: any[]): Promise<Models.PaginatedRecentRequestList> {
|
|
76
76
|
const isParamsObject = args.length === 1 && typeof args[0] === 'object' && args[0] !== null && !Array.isArray(args[0]);
|
|
77
77
|
|
|
78
78
|
let params;
|
|
79
79
|
if (isParamsObject) {
|
|
80
80
|
params = args[0];
|
|
81
81
|
} else {
|
|
82
|
-
params = { method: args[0],
|
|
82
|
+
params = { method: args[0], page: args[1], page_size: args[2], service: args[3], status: args[4] };
|
|
83
83
|
}
|
|
84
84
|
const response = await this.client.request('GET', "/cfg/grpc/monitor/requests/", { params });
|
|
85
85
|
return response;
|
|
86
86
|
}
|
|
87
87
|
|
|
88
|
-
async grpcMonitorServicesRetrieve(hours?: number): Promise<Models.ServiceList[]>;
|
|
89
|
-
async grpcMonitorServicesRetrieve(params?: { hours?: number }): Promise<Models.ServiceList[]>;
|
|
90
|
-
|
|
91
|
-
/**
|
|
92
|
-
* Get service statistics
|
|
93
|
-
*
|
|
94
|
-
* Returns statistics grouped by service.
|
|
95
|
-
*/
|
|
96
|
-
async grpcMonitorServicesRetrieve(...args: any[]): Promise<Models.ServiceList[]> {
|
|
97
|
-
const isParamsObject = args.length === 1 && typeof args[0] === 'object' && args[0] !== null && !Array.isArray(args[0]);
|
|
98
|
-
|
|
99
|
-
let params;
|
|
100
|
-
if (isParamsObject) {
|
|
101
|
-
params = args[0];
|
|
102
|
-
} else {
|
|
103
|
-
params = { hours: args[0] };
|
|
104
|
-
}
|
|
105
|
-
const response = await this.client.request('GET', "/cfg/grpc/monitor/services/", { params });
|
|
106
|
-
return response;
|
|
107
|
-
}
|
|
108
|
-
|
|
109
88
|
async grpcMonitorTimelineRetrieve(hours?: number, interval?: string): Promise<any>;
|
|
110
89
|
async grpcMonitorTimelineRetrieve(params?: { hours?: number; interval?: string }): Promise<any>;
|
|
111
90
|
|