@alauda-fe/common 1.4.24-beta.2 → 1.4.25-beta.0
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/array-form-table/form/component.d.ts +1 -1
- package/core/abstract/base-nested-form-control.d.ts +1 -1
- package/core/pipes/minimum-format.pipe.d.ts +3 -3
- package/core/types/k8s/crd.d.ts +0 -2
- package/core/types/resource-definitions.d.ts +358 -4
- package/esm2022/core/pipes/minimum-format.pipe.mjs +7 -6
- package/esm2022/core/types/k8s/crd.mjs +1 -1
- package/esm2022/core/types/resource-definitions.mjs +230 -53
- package/esm2022/core/utils/common.mjs +2 -2
- package/package.json +1 -1
|
@@ -83,7 +83,7 @@ export declare class ArrayFormTableComponent implements OnDestroy {
|
|
|
83
83
|
addDisabled: boolean | '';
|
|
84
84
|
actionColumnDivider: boolean | '';
|
|
85
85
|
showZeroState: boolean;
|
|
86
|
-
get formDirective():
|
|
86
|
+
get formDirective(): NgForm | FormGroupDirective;
|
|
87
87
|
/**
|
|
88
88
|
* 自定义是否展示错误内容
|
|
89
89
|
* 例如 control 是 FormGroup,只有在内部子 control 错误时才需要展示错误内容
|
|
@@ -21,7 +21,7 @@ export declare class BaseNestedFormControl<V, M = V> implements AfterViewInit, O
|
|
|
21
21
|
protected asyncValidator: boolean;
|
|
22
22
|
protected cdr: ChangeDetectorRef;
|
|
23
23
|
protected destroy$$: Subject<void>;
|
|
24
|
-
protected hostForm:
|
|
24
|
+
protected hostForm: NgForm | FormGroupDirective;
|
|
25
25
|
constructor();
|
|
26
26
|
ngAfterViewInit(): void;
|
|
27
27
|
ngOnDestroy(): void;
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import { DecimalPipe } from '@angular/common';
|
|
2
1
|
import { PipeTransform } from '@angular/core';
|
|
2
|
+
import { TranslateService } from '../../translate/public-api';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export declare class MinimumFormatPipe implements PipeTransform {
|
|
5
|
-
private
|
|
6
|
-
constructor(
|
|
5
|
+
private decimal;
|
|
6
|
+
constructor(translate: TranslateService);
|
|
7
7
|
transform(value: number | string, decimalPlaces?: number): string;
|
|
8
8
|
static ɵfac: i0.ɵɵFactoryDeclaration<MinimumFormatPipe, never>;
|
|
9
9
|
static ɵpipe: i0.ɵɵPipeDeclaration<MinimumFormatPipe, "aclMinimumFormat", true>;
|
package/core/types/k8s/crd.d.ts
CHANGED
|
@@ -1,11 +1,27 @@
|
|
|
1
1
|
import { TypeMeta } from './k8s/public-api';
|
|
2
|
+
export declare const CRD_API_GROUP = "crd.alauda.io";
|
|
3
|
+
export declare const AIOPS_API_GROUP = "aiops.alauda.io";
|
|
4
|
+
export declare const AUTH_API_GROUP = "auth.alauda.io";
|
|
5
|
+
export declare const COREOS_OPERATOR_API_GROUP = "operators.coreos.com";
|
|
6
|
+
export declare const APP_API_GROUP = "app.alauda.io";
|
|
7
|
+
export declare const STORAGE_API_GROUP = "storage.k8s.io";
|
|
8
|
+
export declare const TKE_PLATFORM_API_GROUP = "platform.tkestack.io";
|
|
9
|
+
export declare const CLUSTER_API_GROUP = "cluster.alauda.io";
|
|
2
10
|
export declare const AIT_API_GROUP = "ait.alauda.io";
|
|
3
|
-
export declare const
|
|
4
|
-
export declare const
|
|
11
|
+
export declare const MONITORING_API_GROUP = "monitoring.coreos.com";
|
|
12
|
+
export declare const OAM_API_GROUP = "core.oam.dev";
|
|
13
|
+
export declare const ARGOCD_API_GROUP = "argoproj.io";
|
|
5
14
|
export declare const MACHINE_API_GROUP = "machine.alauda.io";
|
|
6
|
-
export declare const
|
|
15
|
+
export declare const VOLUME_SNAPSHOT_API_GROUP = "snapshot.storage.k8s.io";
|
|
7
16
|
export declare const K8S_CORE_API_GROUP = "core.kubernetes.io";
|
|
8
17
|
export declare const K8S_APP_API_GROUP = "app.k8s.io";
|
|
18
|
+
export declare const PRODUCT_API_GROUP = "product.alauda.io";
|
|
19
|
+
export declare const INFRASTRUCTURE_API_GROUP = "infrastructure.alauda.io";
|
|
20
|
+
export declare const VELERO_API_GROUP = "velero.io";
|
|
21
|
+
export declare const RESOURCE_API_GROUP = "resource.alauda.io";
|
|
22
|
+
export declare const ETCD_BACKUP_API_GROUP = "etcdbackup.alauda.io";
|
|
23
|
+
export declare const CLUSTER_X_K8S_API_GROUP = "infrastructure.cluster.x-k8s.io";
|
|
24
|
+
export declare const OPERATOR_API_GROUP = "operator.alauda.io";
|
|
9
25
|
export declare const COMMON_RESOURCE_DEFINITIONS: {
|
|
10
26
|
readonly ALAUDA_LOADBALANCER2: {
|
|
11
27
|
readonly apiGroup: string;
|
|
@@ -456,11 +472,180 @@ export declare const COMMON_RESOURCE_DEFINITIONS: {
|
|
|
456
472
|
readonly apiGroup: string;
|
|
457
473
|
readonly type: string;
|
|
458
474
|
};
|
|
475
|
+
readonly LOG_POLICY: {
|
|
476
|
+
readonly apiGroup: string;
|
|
477
|
+
readonly apiVersion: string;
|
|
478
|
+
readonly type: string;
|
|
479
|
+
};
|
|
459
480
|
readonly FUNCTION_TEST: {
|
|
460
481
|
readonly type: string;
|
|
461
482
|
readonly apiGroup: string;
|
|
462
483
|
readonly apiVersion: string;
|
|
463
484
|
};
|
|
485
|
+
readonly PROJECT_BINDING: {
|
|
486
|
+
readonly type: string;
|
|
487
|
+
readonly apiGroup: string;
|
|
488
|
+
};
|
|
489
|
+
readonly PROBE: {
|
|
490
|
+
readonly type: string;
|
|
491
|
+
readonly apiVersion: string;
|
|
492
|
+
readonly apiGroup: string;
|
|
493
|
+
};
|
|
494
|
+
readonly REPORT: {
|
|
495
|
+
readonly type: string;
|
|
496
|
+
readonly apiGroup: string;
|
|
497
|
+
readonly apiVersion: string;
|
|
498
|
+
};
|
|
499
|
+
readonly NAMESPACE_RESOURCE_RATIO: {
|
|
500
|
+
readonly type: string;
|
|
501
|
+
readonly apiGroup: string;
|
|
502
|
+
};
|
|
503
|
+
readonly CUSTOM_RESOURCE_DEFINITION: {
|
|
504
|
+
readonly type: string;
|
|
505
|
+
readonly apiGroup: string;
|
|
506
|
+
readonly apiVersion: string;
|
|
507
|
+
};
|
|
508
|
+
readonly LICENSE: {
|
|
509
|
+
readonly type: string;
|
|
510
|
+
};
|
|
511
|
+
readonly RECORD: {
|
|
512
|
+
readonly type: string;
|
|
513
|
+
readonly apiGroup: string;
|
|
514
|
+
readonly apiVersion: string;
|
|
515
|
+
};
|
|
516
|
+
readonly CSI_NODE: {
|
|
517
|
+
readonly apiGroup: string;
|
|
518
|
+
readonly type: string;
|
|
519
|
+
};
|
|
520
|
+
readonly TSF: {
|
|
521
|
+
readonly type: string;
|
|
522
|
+
readonly apiGroup: string;
|
|
523
|
+
readonly apiVersion: string;
|
|
524
|
+
};
|
|
525
|
+
readonly TDSQL: {
|
|
526
|
+
readonly type: string;
|
|
527
|
+
readonly apiVersion: string;
|
|
528
|
+
readonly apiGroup: string;
|
|
529
|
+
};
|
|
530
|
+
readonly PORTAL: {
|
|
531
|
+
readonly type: string;
|
|
532
|
+
readonly apiGroup: string;
|
|
533
|
+
};
|
|
534
|
+
readonly NAMESPACE_IMPORT: {
|
|
535
|
+
readonly type: string;
|
|
536
|
+
readonly apiGroup: string;
|
|
537
|
+
};
|
|
538
|
+
readonly CLUSTER_ADDON_TYPE: {
|
|
539
|
+
readonly apiGroup: string;
|
|
540
|
+
readonly type: string;
|
|
541
|
+
};
|
|
542
|
+
readonly CLUSTER_CREDENTIAL: {
|
|
543
|
+
readonly apiGroup: string;
|
|
544
|
+
readonly type: string;
|
|
545
|
+
};
|
|
546
|
+
readonly CODING: {
|
|
547
|
+
readonly type: string;
|
|
548
|
+
readonly apiGroup: string;
|
|
549
|
+
readonly apiVersion: string;
|
|
550
|
+
};
|
|
551
|
+
readonly TI_MATRIX: {
|
|
552
|
+
readonly type: string;
|
|
553
|
+
readonly apiVersion: string;
|
|
554
|
+
readonly apiGroup: string;
|
|
555
|
+
};
|
|
556
|
+
readonly SYSTEM_CONFIG: {
|
|
557
|
+
readonly apiGroup: string;
|
|
558
|
+
readonly apiVersion: string;
|
|
559
|
+
readonly type: string;
|
|
560
|
+
};
|
|
561
|
+
readonly CERTIFICATE: {
|
|
562
|
+
readonly type: string;
|
|
563
|
+
readonly apiGroup: string;
|
|
564
|
+
};
|
|
565
|
+
readonly SECURITY_RULE: {
|
|
566
|
+
readonly type: string;
|
|
567
|
+
readonly apiGroup: string;
|
|
568
|
+
readonly apiVersion: string;
|
|
569
|
+
};
|
|
570
|
+
readonly REGION: {
|
|
571
|
+
readonly apiGroup: string;
|
|
572
|
+
readonly apiVersion: string;
|
|
573
|
+
readonly type: string;
|
|
574
|
+
};
|
|
575
|
+
readonly TOPOLVM_CLUSTER_V2: {
|
|
576
|
+
readonly type: string;
|
|
577
|
+
readonly apiGroup: string;
|
|
578
|
+
readonly apiVersion: string;
|
|
579
|
+
};
|
|
580
|
+
readonly BUCKET: {
|
|
581
|
+
readonly apiGroup: string;
|
|
582
|
+
readonly apiVersion: string;
|
|
583
|
+
readonly type: string;
|
|
584
|
+
};
|
|
585
|
+
readonly SCHEDULE: {
|
|
586
|
+
readonly apiGroup: string;
|
|
587
|
+
readonly type: string;
|
|
588
|
+
};
|
|
589
|
+
readonly BACKUP_STORAGE_LOCATION: {
|
|
590
|
+
readonly apiGroup: string;
|
|
591
|
+
readonly type: string;
|
|
592
|
+
};
|
|
593
|
+
readonly BACKUP_STORAGE_LOCATION_REPO: {
|
|
594
|
+
readonly apiGroup: string;
|
|
595
|
+
readonly type: string;
|
|
596
|
+
};
|
|
597
|
+
readonly BACKUP: {
|
|
598
|
+
readonly apiGroup: string;
|
|
599
|
+
readonly type: string;
|
|
600
|
+
};
|
|
601
|
+
readonly DELETE_BACKUP_REQUEST: {
|
|
602
|
+
readonly apiGroup: string;
|
|
603
|
+
readonly type: string;
|
|
604
|
+
};
|
|
605
|
+
readonly ETCD_BACKUP_RECORD: {
|
|
606
|
+
readonly apiGroup: string;
|
|
607
|
+
readonly apiVersion: string;
|
|
608
|
+
readonly type: string;
|
|
609
|
+
};
|
|
610
|
+
readonly RESTORE: {
|
|
611
|
+
readonly apiGroup: string;
|
|
612
|
+
readonly apiVersion: string;
|
|
613
|
+
readonly type: string;
|
|
614
|
+
};
|
|
615
|
+
readonly RAW_DEVICE: {
|
|
616
|
+
readonly apiGroup: string;
|
|
617
|
+
readonly type: string;
|
|
618
|
+
};
|
|
619
|
+
readonly APP_RELEASES: {
|
|
620
|
+
readonly apiGroup: string;
|
|
621
|
+
readonly apiVersion: string;
|
|
622
|
+
readonly type: string;
|
|
623
|
+
};
|
|
624
|
+
readonly NOTIFICATION_TEMPLATE: {
|
|
625
|
+
readonly apiGroup: string;
|
|
626
|
+
readonly apiVersion: string;
|
|
627
|
+
readonly type: string;
|
|
628
|
+
};
|
|
629
|
+
readonly NOTIFICATION_GROUP: {
|
|
630
|
+
readonly apiGroup: string;
|
|
631
|
+
readonly apiVersion: string;
|
|
632
|
+
readonly type: string;
|
|
633
|
+
};
|
|
634
|
+
readonly NOTIFICATION: {
|
|
635
|
+
readonly apiGroup: string;
|
|
636
|
+
readonly apiVersion: string;
|
|
637
|
+
readonly type: string;
|
|
638
|
+
};
|
|
639
|
+
readonly TUNNEL_CLUSTER: {
|
|
640
|
+
readonly type: string;
|
|
641
|
+
readonly apiVersion: string;
|
|
642
|
+
readonly apiGroup: string;
|
|
643
|
+
};
|
|
644
|
+
readonly K8S_CLUSTER: {
|
|
645
|
+
readonly type: string;
|
|
646
|
+
readonly apiGroup: string;
|
|
647
|
+
readonly apiVersion: string;
|
|
648
|
+
};
|
|
464
649
|
};
|
|
465
650
|
export declare const RESOURCE_TYPES: {
|
|
466
651
|
readonly ALAUDA_LOADBALANCER2: "ALAUDA_LOADBALANCER2";
|
|
@@ -564,9 +749,46 @@ export declare const RESOURCE_TYPES: {
|
|
|
564
749
|
readonly MODULE_HEALTH: "MODULE_HEALTH";
|
|
565
750
|
readonly MODULE_HEALTH_RECORD: "MODULE_HEALTH_RECORD";
|
|
566
751
|
readonly AUDIT: "AUDIT";
|
|
752
|
+
readonly LOG_POLICY: "LOG_POLICY";
|
|
567
753
|
readonly FUNCTION_TEST: "FUNCTION_TEST";
|
|
754
|
+
readonly PROJECT_BINDING: "PROJECT_BINDING";
|
|
755
|
+
readonly PROBE: "PROBE";
|
|
756
|
+
readonly REPORT: "REPORT";
|
|
757
|
+
readonly NAMESPACE_RESOURCE_RATIO: "NAMESPACE_RESOURCE_RATIO";
|
|
758
|
+
readonly CUSTOM_RESOURCE_DEFINITION: "CUSTOM_RESOURCE_DEFINITION";
|
|
759
|
+
readonly LICENSE: "LICENSE";
|
|
760
|
+
readonly RECORD: "RECORD";
|
|
761
|
+
readonly CSI_NODE: "CSI_NODE";
|
|
762
|
+
readonly TSF: "TSF";
|
|
763
|
+
readonly TDSQL: "TDSQL";
|
|
764
|
+
readonly PORTAL: "PORTAL";
|
|
765
|
+
readonly NAMESPACE_IMPORT: "NAMESPACE_IMPORT";
|
|
766
|
+
readonly CLUSTER_ADDON_TYPE: "CLUSTER_ADDON_TYPE";
|
|
767
|
+
readonly CLUSTER_CREDENTIAL: "CLUSTER_CREDENTIAL";
|
|
768
|
+
readonly CODING: "CODING";
|
|
769
|
+
readonly TI_MATRIX: "TI_MATRIX";
|
|
770
|
+
readonly SYSTEM_CONFIG: "SYSTEM_CONFIG";
|
|
771
|
+
readonly CERTIFICATE: "CERTIFICATE";
|
|
772
|
+
readonly SECURITY_RULE: "SECURITY_RULE";
|
|
773
|
+
readonly REGION: "REGION";
|
|
774
|
+
readonly TOPOLVM_CLUSTER_V2: "TOPOLVM_CLUSTER_V2";
|
|
775
|
+
readonly BUCKET: "BUCKET";
|
|
776
|
+
readonly SCHEDULE: "SCHEDULE";
|
|
777
|
+
readonly BACKUP_STORAGE_LOCATION: "BACKUP_STORAGE_LOCATION";
|
|
778
|
+
readonly BACKUP_STORAGE_LOCATION_REPO: "BACKUP_STORAGE_LOCATION_REPO";
|
|
779
|
+
readonly BACKUP: "BACKUP";
|
|
780
|
+
readonly DELETE_BACKUP_REQUEST: "DELETE_BACKUP_REQUEST";
|
|
781
|
+
readonly ETCD_BACKUP_RECORD: "ETCD_BACKUP_RECORD";
|
|
782
|
+
readonly RESTORE: "RESTORE";
|
|
783
|
+
readonly RAW_DEVICE: "RAW_DEVICE";
|
|
784
|
+
readonly APP_RELEASES: "APP_RELEASES";
|
|
785
|
+
readonly NOTIFICATION_TEMPLATE: "NOTIFICATION_TEMPLATE";
|
|
786
|
+
readonly NOTIFICATION_GROUP: "NOTIFICATION_GROUP";
|
|
787
|
+
readonly NOTIFICATION: "NOTIFICATION";
|
|
788
|
+
readonly TUNNEL_CLUSTER: "TUNNEL_CLUSTER";
|
|
789
|
+
readonly K8S_CLUSTER: "K8S_CLUSTER";
|
|
568
790
|
};
|
|
569
|
-
export declare const getYamlApiVersion: (definition: "ALAUDA_LOADBALANCER2" | "ALB2" | "HELM_REQUEST" | "HELM_REQUEST_V1" | "DEPLOYMENT" | "DAEMONSET" | "STATEFULSET" | "FRONTEND" | "RULE" | "POD" | "PODS_EXEC" | "PODS_ROOT_EXEC" | "CONFIG_MAP" | "ALERT_TEMPLATE" | "APPLICATION" | "APPLICATION_HISTORY" | "CLUSTER" | "CLUSTER_VIEW" | "DAEMON_SET" | "STATEFUL_SET" | "DOMAIN" | "FEATURE" | "ALAUDA_FEATURE_GATE" | "CLUSTER_ALAUDA_FEATURE_GATE" | "HORIZONTAL_POD_AUTOSCALER" | "LOG" | "PROJECT" | "PROMETHEUS_RULE" | "ALERT_HISTORY" | "SELF_SUBJECT_ACCESS_REVIEW" | "VIEW" | "SERVICE" | "LIMIT_RANGE" | "SECRET" | "CRON_JOB" | "ADVANCED_CRON_JOB" | "JOB" | "INGRESS" | "PERSISTENT_VOLUME_CLAIM" | "NAMESPACE" | "NODE" | "NODE_METRICS" | "PV" | "CRD" | "CHART_REPO" | "CHART" | "NETWORK_POLICY" | "SERVICE_ACCOUNT" | "REPLICA_SET" | "POD_SECURITY_POLICY" | "NAMESPACE_OVERVIEW" | "CSP" | "RESOURCE_QUOTA" | "CLUSTER_NETWORK_POLICY" | "PROJECT_QUOTA" | "TKE_CLUSTER" | "TKE_MACHINE" | "MACHINE" | "NODE_GROUP" | "CLUSTERSERVICEVERSION" | "TENANT" | "SUBSCRIPTION" | "PACKAGE_MANIFEST" | "BUCKET_CLASS" | "PRODUCT_CONFIG" | "STORAGE_CLASS" | "VOLUME_SNAPSHOT_CLASS" | "PRODUCT_BASE" | "MODULE_INFO" | "MODULE_CONFIG" | "MODULE_PLUGIN" | "PRODUCT_ENTRY" | "PRODUCT_DOCS_ENTRY" | "SERVICEMESH_GROUP" | "CLUSTER_MODULE" | "USER_SECURITY_POLICY" | "CONNECTOR" | "ACCESS_TOKEN_INFO" | "FUNCTION_RESOURCE" | "USER_BINDING" | "USER" | "GROUP" | "PROJECT_MEMBER" | "ROLE_TEMPLATE" | "BATCH_ACTION" | "EVENT" | "SERVICE_MONITOR" | "OAM_APPLICATION" | "ARGOCD_APPLICATION_SET" | "ARGOCD_APPLICATION" | "OPERATOR_VIEW" | "MODULE_PLUGIN_VIEW" | "RESOURCE_PATCH" | "COMPONENT_PROBER" | "INSPECTION" | "INSPECTION_DETAILS" | "INSPECTION_ITEMS" | "MESSAGE" | "MODULE_HEALTH" | "MODULE_HEALTH_RECORD" | "AUDIT" | "FUNCTION_TEST" | {
|
|
791
|
+
export declare const getYamlApiVersion: (definition: "ALAUDA_LOADBALANCER2" | "ALB2" | "HELM_REQUEST" | "HELM_REQUEST_V1" | "DEPLOYMENT" | "DAEMONSET" | "STATEFULSET" | "FRONTEND" | "RULE" | "POD" | "PODS_EXEC" | "PODS_ROOT_EXEC" | "CONFIG_MAP" | "ALERT_TEMPLATE" | "APPLICATION" | "APPLICATION_HISTORY" | "CLUSTER" | "CLUSTER_VIEW" | "DAEMON_SET" | "STATEFUL_SET" | "DOMAIN" | "FEATURE" | "ALAUDA_FEATURE_GATE" | "CLUSTER_ALAUDA_FEATURE_GATE" | "HORIZONTAL_POD_AUTOSCALER" | "LOG" | "PROJECT" | "PROMETHEUS_RULE" | "ALERT_HISTORY" | "SELF_SUBJECT_ACCESS_REVIEW" | "VIEW" | "SERVICE" | "LIMIT_RANGE" | "SECRET" | "CRON_JOB" | "ADVANCED_CRON_JOB" | "JOB" | "INGRESS" | "PERSISTENT_VOLUME_CLAIM" | "NAMESPACE" | "NODE" | "NODE_METRICS" | "PV" | "CRD" | "CHART_REPO" | "CHART" | "NETWORK_POLICY" | "SERVICE_ACCOUNT" | "REPLICA_SET" | "POD_SECURITY_POLICY" | "NAMESPACE_OVERVIEW" | "CSP" | "RESOURCE_QUOTA" | "CLUSTER_NETWORK_POLICY" | "PROJECT_QUOTA" | "TKE_CLUSTER" | "TKE_MACHINE" | "MACHINE" | "NODE_GROUP" | "CLUSTERSERVICEVERSION" | "TENANT" | "SUBSCRIPTION" | "PACKAGE_MANIFEST" | "BUCKET_CLASS" | "PRODUCT_CONFIG" | "STORAGE_CLASS" | "VOLUME_SNAPSHOT_CLASS" | "PRODUCT_BASE" | "MODULE_INFO" | "MODULE_CONFIG" | "MODULE_PLUGIN" | "PRODUCT_ENTRY" | "PRODUCT_DOCS_ENTRY" | "SERVICEMESH_GROUP" | "CLUSTER_MODULE" | "USER_SECURITY_POLICY" | "CONNECTOR" | "ACCESS_TOKEN_INFO" | "FUNCTION_RESOURCE" | "USER_BINDING" | "USER" | "GROUP" | "PROJECT_MEMBER" | "ROLE_TEMPLATE" | "BATCH_ACTION" | "EVENT" | "SERVICE_MONITOR" | "OAM_APPLICATION" | "ARGOCD_APPLICATION_SET" | "ARGOCD_APPLICATION" | "OPERATOR_VIEW" | "MODULE_PLUGIN_VIEW" | "RESOURCE_PATCH" | "COMPONENT_PROBER" | "INSPECTION" | "INSPECTION_DETAILS" | "INSPECTION_ITEMS" | "MESSAGE" | "MODULE_HEALTH" | "MODULE_HEALTH_RECORD" | "AUDIT" | "LOG_POLICY" | "FUNCTION_TEST" | "PROJECT_BINDING" | "PROBE" | "REPORT" | "NAMESPACE_RESOURCE_RATIO" | "CUSTOM_RESOURCE_DEFINITION" | "LICENSE" | "RECORD" | "CSI_NODE" | "TSF" | "TDSQL" | "PORTAL" | "NAMESPACE_IMPORT" | "CLUSTER_ADDON_TYPE" | "CLUSTER_CREDENTIAL" | "CODING" | "TI_MATRIX" | "SYSTEM_CONFIG" | "CERTIFICATE" | "SECURITY_RULE" | "REGION" | "TOPOLVM_CLUSTER_V2" | "BUCKET" | "SCHEDULE" | "BACKUP_STORAGE_LOCATION" | "BACKUP_STORAGE_LOCATION_REPO" | "BACKUP" | "DELETE_BACKUP_REQUEST" | "ETCD_BACKUP_RECORD" | "RESTORE" | "RAW_DEVICE" | "APP_RELEASES" | "NOTIFICATION_TEMPLATE" | "NOTIFICATION_GROUP" | "NOTIFICATION" | "TUNNEL_CLUSTER" | "K8S_CLUSTER" | {
|
|
570
792
|
apiGroup: string;
|
|
571
793
|
type: string;
|
|
572
794
|
} | {
|
|
@@ -914,6 +1136,138 @@ export declare const getYamlApiVersion: (definition: "ALAUDA_LOADBALANCER2" | "A
|
|
|
914
1136
|
} | {
|
|
915
1137
|
apiGroup: string;
|
|
916
1138
|
type: string;
|
|
1139
|
+
} | {
|
|
1140
|
+
apiGroup: string;
|
|
1141
|
+
apiVersion: string;
|
|
1142
|
+
type: string;
|
|
1143
|
+
} | {
|
|
1144
|
+
type: string;
|
|
1145
|
+
apiGroup: string;
|
|
1146
|
+
apiVersion: string;
|
|
1147
|
+
} | {
|
|
1148
|
+
type: string;
|
|
1149
|
+
apiGroup: string;
|
|
1150
|
+
} | {
|
|
1151
|
+
type: string;
|
|
1152
|
+
apiVersion: string;
|
|
1153
|
+
apiGroup: string;
|
|
1154
|
+
} | {
|
|
1155
|
+
type: string;
|
|
1156
|
+
apiGroup: string;
|
|
1157
|
+
apiVersion: string;
|
|
1158
|
+
} | {
|
|
1159
|
+
type: string;
|
|
1160
|
+
apiGroup: string;
|
|
1161
|
+
} | {
|
|
1162
|
+
type: string;
|
|
1163
|
+
apiGroup: string;
|
|
1164
|
+
apiVersion: string;
|
|
1165
|
+
} | {
|
|
1166
|
+
type: string;
|
|
1167
|
+
} | {
|
|
1168
|
+
type: string;
|
|
1169
|
+
apiGroup: string;
|
|
1170
|
+
apiVersion: string;
|
|
1171
|
+
} | {
|
|
1172
|
+
apiGroup: string;
|
|
1173
|
+
type: string;
|
|
1174
|
+
} | {
|
|
1175
|
+
type: string;
|
|
1176
|
+
apiGroup: string;
|
|
1177
|
+
apiVersion: string;
|
|
1178
|
+
} | {
|
|
1179
|
+
type: string;
|
|
1180
|
+
apiVersion: string;
|
|
1181
|
+
apiGroup: string;
|
|
1182
|
+
} | {
|
|
1183
|
+
type: string;
|
|
1184
|
+
apiGroup: string;
|
|
1185
|
+
} | {
|
|
1186
|
+
type: string;
|
|
1187
|
+
apiGroup: string;
|
|
1188
|
+
} | {
|
|
1189
|
+
apiGroup: string;
|
|
1190
|
+
type: string;
|
|
1191
|
+
} | {
|
|
1192
|
+
apiGroup: string;
|
|
1193
|
+
type: string;
|
|
1194
|
+
} | {
|
|
1195
|
+
type: string;
|
|
1196
|
+
apiGroup: string;
|
|
1197
|
+
apiVersion: string;
|
|
1198
|
+
} | {
|
|
1199
|
+
type: string;
|
|
1200
|
+
apiVersion: string;
|
|
1201
|
+
apiGroup: string;
|
|
1202
|
+
} | {
|
|
1203
|
+
apiGroup: string;
|
|
1204
|
+
apiVersion: string;
|
|
1205
|
+
type: string;
|
|
1206
|
+
} | {
|
|
1207
|
+
type: string;
|
|
1208
|
+
apiGroup: string;
|
|
1209
|
+
} | {
|
|
1210
|
+
type: string;
|
|
1211
|
+
apiGroup: string;
|
|
1212
|
+
apiVersion: string;
|
|
1213
|
+
} | {
|
|
1214
|
+
apiGroup: string;
|
|
1215
|
+
apiVersion: string;
|
|
1216
|
+
type: string;
|
|
1217
|
+
} | {
|
|
1218
|
+
type: string;
|
|
1219
|
+
apiGroup: string;
|
|
1220
|
+
apiVersion: string;
|
|
1221
|
+
} | {
|
|
1222
|
+
apiGroup: string;
|
|
1223
|
+
apiVersion: string;
|
|
1224
|
+
type: string;
|
|
1225
|
+
} | {
|
|
1226
|
+
apiGroup: string;
|
|
1227
|
+
type: string;
|
|
1228
|
+
} | {
|
|
1229
|
+
apiGroup: string;
|
|
1230
|
+
type: string;
|
|
1231
|
+
} | {
|
|
1232
|
+
apiGroup: string;
|
|
1233
|
+
type: string;
|
|
1234
|
+
} | {
|
|
1235
|
+
apiGroup: string;
|
|
1236
|
+
type: string;
|
|
1237
|
+
} | {
|
|
1238
|
+
apiGroup: string;
|
|
1239
|
+
type: string;
|
|
1240
|
+
} | {
|
|
1241
|
+
apiGroup: string;
|
|
1242
|
+
apiVersion: string;
|
|
1243
|
+
type: string;
|
|
1244
|
+
} | {
|
|
1245
|
+
apiGroup: string;
|
|
1246
|
+
apiVersion: string;
|
|
1247
|
+
type: string;
|
|
1248
|
+
} | {
|
|
1249
|
+
apiGroup: string;
|
|
1250
|
+
type: string;
|
|
1251
|
+
} | {
|
|
1252
|
+
apiGroup: string;
|
|
1253
|
+
apiVersion: string;
|
|
1254
|
+
type: string;
|
|
1255
|
+
} | {
|
|
1256
|
+
apiGroup: string;
|
|
1257
|
+
apiVersion: string;
|
|
1258
|
+
type: string;
|
|
1259
|
+
} | {
|
|
1260
|
+
apiGroup: string;
|
|
1261
|
+
apiVersion: string;
|
|
1262
|
+
type: string;
|
|
1263
|
+
} | {
|
|
1264
|
+
apiGroup: string;
|
|
1265
|
+
apiVersion: string;
|
|
1266
|
+
type: string;
|
|
1267
|
+
} | {
|
|
1268
|
+
type: string;
|
|
1269
|
+
apiVersion: string;
|
|
1270
|
+
apiGroup: string;
|
|
917
1271
|
} | {
|
|
918
1272
|
type: string;
|
|
919
1273
|
apiGroup: string;
|
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
import { DecimalPipe } from '@angular/common';
|
|
2
2
|
import { Pipe } from '@angular/core';
|
|
3
|
+
import { TranslateService } from '../../translate/public-api';
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "
|
|
5
|
+
import * as i1 from "../../translate/public-api";
|
|
5
6
|
export class MinimumFormatPipe {
|
|
6
|
-
constructor(
|
|
7
|
-
this.decimal =
|
|
7
|
+
constructor(translate) {
|
|
8
|
+
this.decimal = new DecimalPipe(translate.locale);
|
|
8
9
|
}
|
|
9
10
|
transform(value, decimalPlaces = 0) {
|
|
10
11
|
const decimalFormat = `1.${decimalPlaces}-${decimalPlaces || 2}`;
|
|
@@ -12,7 +13,7 @@ export class MinimumFormatPipe {
|
|
|
12
13
|
? '<0.01'
|
|
13
14
|
: this.decimal.transform(value, decimalFormat)?.replace(/,/g, '');
|
|
14
15
|
}
|
|
15
|
-
static { this.ɵfac = function MinimumFormatPipe_Factory(t) { return new (t || MinimumFormatPipe)(i0.ɵɵdirectiveInject(i1.
|
|
16
|
+
static { this.ɵfac = function MinimumFormatPipe_Factory(t) { return new (t || MinimumFormatPipe)(i0.ɵɵdirectiveInject(i1.TranslateService, 16)); }; }
|
|
16
17
|
static { this.ɵpipe = /*@__PURE__*/ i0.ɵɵdefinePipe({ name: "aclMinimumFormat", type: MinimumFormatPipe, pure: true, standalone: true }); }
|
|
17
18
|
}
|
|
18
19
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(MinimumFormatPipe, [{
|
|
@@ -21,5 +22,5 @@ export class MinimumFormatPipe {
|
|
|
21
22
|
name: 'aclMinimumFormat',
|
|
22
23
|
standalone: true,
|
|
23
24
|
}]
|
|
24
|
-
}], () => [{ type: i1.
|
|
25
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
}], () => [{ type: i1.TranslateService }], null); })();
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWluaW11bS1mb3JtYXQucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tbW9uL3NyYy9jb3JlL3BpcGVzL21pbmltdW0tZm9ybWF0LnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQzlDLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDO0FBRXBELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDRCQUE0QixDQUFDOzs7QUFNOUQsTUFBTSxPQUFPLGlCQUFpQjtJQUc1QixZQUFZLFNBQTJCO1FBQ3JDLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxXQUFXLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ25ELENBQUM7SUFFRCxTQUFTLENBQUMsS0FBc0IsRUFBRSxhQUFhLEdBQUcsQ0FBQztRQUNqRCxNQUFNLGFBQWEsR0FBRyxLQUFLLGFBQWEsSUFBSSxhQUFhLElBQUksQ0FBQyxFQUFFLENBQUM7UUFDakUsT0FBTyxDQUFDLEtBQUssR0FBRyxDQUFDLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSTtZQUNoQyxDQUFDLENBQUMsT0FBTztZQUNULENBQUMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxLQUFLLEVBQUUsYUFBYSxDQUFDLEVBQUUsT0FBTyxDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsQ0FBQztJQUN0RSxDQUFDO2tGQVpVLGlCQUFpQjswRkFBakIsaUJBQWlCOztpRkFBakIsaUJBQWlCO2NBSjdCLElBQUk7ZUFBQztnQkFDSixJQUFJLEVBQUUsa0JBQWtCO2dCQUN4QixVQUFVLEVBQUUsSUFBSTthQUNqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERlY2ltYWxQaXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgVHJhbnNsYXRlU2VydmljZSB9IGZyb20gJy4uLy4uL3RyYW5zbGF0ZS9wdWJsaWMtYXBpJztcblxuQFBpcGUoe1xuICBuYW1lOiAnYWNsTWluaW11bUZvcm1hdCcsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIE1pbmltdW1Gb3JtYXRQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XG4gIHByaXZhdGUgZGVjaW1hbDogRGVjaW1hbFBpcGU7XG5cbiAgY29uc3RydWN0b3IodHJhbnNsYXRlOiBUcmFuc2xhdGVTZXJ2aWNlKSB7XG4gICAgdGhpcy5kZWNpbWFsID0gbmV3IERlY2ltYWxQaXBlKHRyYW5zbGF0ZS5sb2NhbGUpO1xuICB9XG5cbiAgdHJhbnNmb3JtKHZhbHVlOiBudW1iZXIgfCBzdHJpbmcsIGRlY2ltYWxQbGFjZXMgPSAwKSB7XG4gICAgY29uc3QgZGVjaW1hbEZvcm1hdCA9IGAxLiR7ZGVjaW1hbFBsYWNlc30tJHtkZWNpbWFsUGxhY2VzIHx8IDJ9YDtcbiAgICByZXR1cm4gK3ZhbHVlID4gMCAmJiArdmFsdWUgPCAwLjAxXG4gICAgICA/ICc8MC4wMSdcbiAgICAgIDogdGhpcy5kZWNpbWFsLnRyYW5zZm9ybSh2YWx1ZSwgZGVjaW1hbEZvcm1hdCk/LnJlcGxhY2UoLywvZywgJycpO1xuICB9XG59XG4iXX0=
|
|
@@ -72,4 +72,4 @@ export var ChartUploadStatusEnum;
|
|
|
72
72
|
ChartUploadStatusEnum["UPLOAD_FAILED"] = "upload_failed";
|
|
73
73
|
ChartUploadStatusEnum["UPLOADING"] = "uploading";
|
|
74
74
|
})(ChartUploadStatusEnum || (ChartUploadStatusEnum = {}));
|
|
75
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"crd.js","sourceRoot":"","sources":["../../../../../../../libs/common/src/core/types/k8s/crd.ts"],"names":[],"mappings":"AAkFA,MAAM,CAAN,IAAY,mBAIX;AAJD,WAAY,mBAAmB;IAC7B,iDAA0B,CAAA;IAC1B,0CAAmB,CAAA;IACnB,4CAAqB,CAAA;AACvB,CAAC,EAJW,mBAAmB,KAAnB,mBAAmB,QAI9B;AAED,MAAM,CAAN,IAAY,kBAUX;AAVD,WAAY,kBAAkB;IAC5B,kDAA4B,CAAA;IAC5B,yCAAmB,CAAA;IACnB,2CAAqB,CAAA;IACrB,6CAAuB,CAAA;IACvB,oDAA8B,CAAA;IAC9B,6CAAuB,CAAA;IACvB,sDAAgC,CAAA;IAChC,6CAAuB,CAAA;IACvB,yCAAmB,CAAA;AACrB,CAAC,EAVW,kBAAkB,KAAlB,kBAAkB,QAU7B;AA+CD,MAAM,CAAC,MAAM,UAAU,GAAG;IACxB,IAAI,EAAE,MAAM;IACZ,kBAAkB,EAAE,mBAAmB;IACvC,MAAM,EAAE,QAAQ;IAChB,YAAY,EAAE,aAAa;IAC3B,aAAa,EAAE,cAAc;CACrB,CAAC;AAobX,MAAM,CAAN,IAAY,yBAMX;AAND,WAAY,yBAAyB;IACnC,gDAAmB,CAAA;IACnB,gDAAmB,CAAA;IACnB,gDAAmB,CAAA;IACnB,8CAAiB,CAAA;IACjB,4CAAe,CAAA;AACjB,CAAC,EANW,yBAAyB,KAAzB,yBAAyB,QAMpC;AAWD,MAAM,CAAN,IAAY,oBAKX;AALD,WAAY,oBAAoB;IAC9B,yCAAiB,CAAA;IACjB,yCAAiB,CAAA;IACjB,2CAAmB,CAAA;IACnB,qDAA6B,CAAA;AAC/B,CAAC,EALW,oBAAoB,KAApB,oBAAoB,QAK/B;AAgED,MAAM,CAAN,IAAY,SAKX;AALD,WAAY,SAAS;IACnB,8BAAiB,CAAA;IACjB,8BAAiB,CAAA;IACjB,gCAAmB,CAAA;IACnB,gCAAmB,CAAA;AACrB,CAAC,EALW,SAAS,KAAT,SAAS,QAKpB;AA4ED,MAAM,CAAN,IAAY,sBAOX;AAPD,WAAY,sBAAsB;IAChC,2DAAiC,CAAA;IACjC,uDAA6B,CAAA;IAC7B,4DAAkC,CAAA;IAClC,6DAAmC,CAAA;IACnC,+DAAqC,CAAA;IACrC,iEAAuC,CAAA;AACzC,CAAC,EAPW,sBAAsB,KAAtB,sBAAsB,QAOjC;AAuFD,MAAM,CAAN,IAAY,aAIX;AAJD,WAAY,aAAa;IACvB,gCAAe,CAAA;IACf,4BAAW,CAAA;IACX,uCAAsB,CAAA;AACxB,CAAC,EAJW,aAAa,KAAb,aAAa,QAIxB;AAkBD,MAAM,CAAN,IAAY,kBAIX;AAJD,WAAY,kBAAkB;IAC5B,uCAAiB,CAAA;IACjB,uCAAiB,CAAA;IACjB,yCAAmB,CAAA;AACrB,CAAC,EAJW,kBAAkB,KAAlB,kBAAkB,QAI7B;AAkBD,MAAM,CAAN,IAAY,qBAIX;AAJD,WAAY,qBAAqB;IAC/B,8DAAqC,CAAA;IACrC,wDAA+B,CAAA;IAC/B,gDAAuB,CAAA;AACzB,CAAC,EAJW,qBAAqB,KAArB,qBAAqB,QAIhC","sourcesContent":["import { ValueOf } from 'ts-essentials';\n\nimport { StringMap } from '../commons';\n\nimport {\n  Condition,\n  KubernetesResource,\n  KubernetesResourceList,\n  ObjectMeta,\n} from './core';\nimport {\n  ConfigMapKeyRef,\n  Node,\n  NodeStatus,\n  NodeTaint,\n  Secret,\n  SecretKeyRef,\n} from './raw';\n\nexport interface ClusterSpec {\n  authInfo?: {\n    controller: {\n      kind: string;\n      namespace: string;\n      name: string;\n    };\n  };\n  kubernetesApiEndpoints?: {\n    caBundle?: string;\n    serverEndpoints: Array<{\n      clientCIDR: string;\n      serverAddress: string;\n    }>;\n  };\n}\n\nexport type ClusterStatusReason =\n  | 'Timeout'\n  | 'Forbidden'\n  | 'Unauthorized'\n  | 'SomeComponentsUnhealthy'\n  | 'SomeNodesNotReady';\n\nexport interface ClusterStatusCondition extends Condition {\n  lastTransitionTime: string;\n  type:\n    | 'NotReachable'\n    | 'NotAccessible'\n    | 'ComponentNotHealthy'\n    | 'NodeNotReady';\n  status: 'True' | 'False';\n  reason: ClusterStatusReason;\n}\n\nexport interface ClusterStatus {\n  version: string;\n  conditions: ClusterStatusCondition[];\n}\n\n// clusters.clusterregistry.k8s.io 的类型定义\nexport interface Cluster extends KubernetesResource {\n  metadata?: ObjectMeta & {\n    finalizers?: string[];\n  };\n  spec?: ClusterSpec;\n  status?: ClusterStatus;\n  details?: {\n    group: string;\n    kind: string;\n    name: string;\n    uid: string;\n  };\n}\n\n// Alauda Product\nexport interface AlaudaProductStatus extends Condition {\n  deployStatus?: AlaudaDeployStatus;\n  runningStatus?: AlaudaRunningStatus;\n  message: string;\n  deployTime?: string;\n}\n\nexport enum AlaudaRunningStatus {\n  NOT_RUNNING = 'NotRunning',\n  HEALTHY = 'Healthy',\n  ABNORMAL = 'Abnormal',\n}\n\nexport enum AlaudaDeployStatus {\n  NOT_DEPLOYED = 'NotDeployed',\n  SUCCESS = 'success',\n  ABNORMAL = 'Abnormal',\n  DEPLOYING = 'Deploying',\n  DEPLOY_FAILED = 'DeployFailed',\n  UPGRADING = 'Upgrading',\n  UPGRADE_FAILED = 'UpgradeFailed',\n  COMPLETED = 'Completed',\n  PENDING = 'Pending',\n}\nexport interface ProductBase extends KubernetesResource {\n  spec: ProductBaseSpec;\n  status?: ProductBaseStatus;\n}\n\nexport interface ProductStatusCondition {\n  status?: 'True' | 'False' | 'Unknown';\n  reason?: string;\n  message?: string;\n  type: 'Ready' | 'Initialized' | 'Reclaimed' | 'Succeed';\n  lastTransitionTime?: string;\n  lastHeartbeatTime?: string;\n}\n\nexport interface ProductBaseStatus {\n  globalID: string;\n  cloud: {\n    phase: 'ONLine' | 'ConnectFailed' | 'Connecting' | 'OFFLine';\n    message: string;\n    connectURL: string;\n  };\n  version: string;\n  phase?:\n    | 'Pending'\n    | 'Provisioning'\n    | 'Provisioned'\n    | 'Deleting'\n    | 'Failed'\n    | 'Running'\n    | 'Installing' // tdsql\n    | 'Upgrading';\n  productEntrypoint?: string;\n  deletable?: boolean;\n  conditions?: ProductStatusCondition[];\n  prometheusAddress?: string;\n  elasticSearchAddress?: string;\n  kafkaAddress?: string;\n  containerPlatform?: AlaudaProductStatus;\n  devops?: AlaudaProductStatus;\n  serviceMesh?: AlaudaProductStatus;\n  dataServices?: AlaudaProductStatus;\n  base?: AlaudaProductStatus;\n  progress?: number;\n  replicas?: number;\n}\n\nexport const ProductKey = {\n  BASE: 'base',\n  CONTAINER_PLATFORM: 'containerPlatform',\n  DEVOPS: 'devops',\n  SERVICE_MESH: 'serviceMesh',\n  DATA_SERVICES: 'dataServices',\n} as const;\n\nexport type ProductKey = ValueOf<typeof ProductKey>;\n\ntype GenProduct<T extends ProductKey> = Record<T, { install: boolean }>;\n\nexport interface Tls {\n  secretRef: {\n    name: string;\n  };\n}\n\nexport interface ProductBaseSpec extends GenProduct<ProductKey> {\n  alternativeURLs: string[];\n  chartMuseum: {\n    url: string;\n  };\n  packageEdition: string;\n  valuesOverride?: {\n    dex: StringMap;\n  };\n  chartVersions: [{ name: string; version: string }];\n  defaultAdmin: {\n    account: string;\n    email: string;\n    password: string;\n  };\n  defaultRedirectPath: string;\n  deployType: string;\n  elasticsearch: {\n    install: boolean;\n    nodes: string[];\n    username: string;\n  };\n  http: {\n    forceRedirectHttps?: boolean;\n    httpPort?: number;\n    httpsPort?: number;\n    tls?: Tls;\n  };\n  ingress: {\n    controller: { install: boolean; nodes: string[] };\n    host: string;\n    ingressClassName: string;\n  };\n  kafka: {\n    auth: boolean;\n    install: boolean;\n    nodes: string[];\n    username: string;\n  };\n  logAgent: {\n    enable: boolean;\n  };\n  logCenter: {\n    enable: boolean;\n  };\n  platformURL: string;\n  prometheus: {\n    install: boolean;\n    replicas: number;\n    storage: { capacity: number; nodes: string[]; path: string; type: string };\n  };\n  registry: {\n    external?: string;\n    address: string;\n    username: string;\n    secretRef?: string;\n  };\n  replicas: number;\n  version: string;\n  cloud: {\n    connect: boolean;\n    connectType: string;\n  };\n}\n\nexport interface ProjectSpec {\n  clusters: ProjectCluster[];\n  status?: {\n    phase: string;\n  };\n  clusterDeletePolicy?: 'Delete' | 'Retain';\n}\n\nexport interface ProjectCluster {\n  name: string;\n  quota: Record<string, string>;\n  type?: '' | 'FedMember';\n}\n\nexport interface Project extends KubernetesResource {\n  spec: ProjectSpec;\n  status?: {\n    phase: string;\n  };\n}\n\nexport interface ServiceMeshGroup extends KubernetesResource {\n  spec: {\n    k8sVersion: string;\n    withoutIstio?: boolean;\n    istioVersion: string;\n    primary: string;\n    selector: {\n      [key: string]: string;\n    };\n    clusters: string[];\n    meshCommonConfig?: MeshCommonConfig;\n    clusterConfigs?: {\n      [clusterName: string]: ClusterConfig;\n    };\n  };\n  status: {\n    status: string;\n    Message: string;\n    clusterCount: number;\n    latestUpdateTime: string;\n    NonReadyClusterCount: number;\n  };\n}\n\nexport interface MeshCommonConfig {\n  elasticsearch: {\n    isDefault: boolean;\n    password?: string;\n    url: string;\n    username?: string;\n  };\n  monitorType: string;\n  prometheusBasicAuth: {\n    password: string;\n    username: string;\n  };\n  isDefaultMonitor: boolean;\n  prometheusURL: string;\n  traceSampling: number;\n}\n\nexport interface ClusterConfig {\n  istioSidecar: {\n    cpuValue: string;\n    memoryValue: string;\n  };\n  kafka?: {\n    authentication: string;\n    enabled: boolean;\n    password: string;\n    url: string;\n    username: string;\n  };\n  redis?: RedisConfig;\n  traceSampling: number;\n}\n\nexport interface RedisConfig {\n  enabled: boolean;\n  kind: 'single' | 'cluster' | 'sentinel';\n  address: string;\n  password: string;\n  masterName?: string;\n}\n\n// TKE\nexport interface TKEClusterSpec {\n  displayName: string;\n  serviceCIDR?: string;\n  dockerExtraArgs?: StringMap;\n  kubeletExtraArgs?: StringMap;\n  controllerManagerExtraArgs?: StringMap;\n  schedulerExtraArgs?: StringMap;\n  publicAlternativeNames?: string[];\n  clusterCIDR?: string;\n  networkDevice?: string;\n  properties?: {\n    maxClusterServiceNum?: number;\n    maxNodePodNum?: number;\n    oversoldRatio?: {\n      cpu: string;\n      memory: string;\n    };\n  };\n  features?: {\n    enableMasterSchedule?: boolean;\n    ipv6DualStack?: boolean;\n    files?: Array<{\n      src?: string;\n      dst?: string;\n    }>;\n    ha?: {\n      thirdParty?: {\n        vip?: string;\n        vport?: number;\n      };\n      tke?: {\n        vrid?: unknown;\n      };\n    };\n  };\n  type: 'Baremetal' | 'Imported';\n  version?: string;\n  machines?: TKEMachineSpec[];\n  dnsDomain?: string;\n  apiServerExtraArgs?: StringMap;\n  clusterCredentialRef?: {\n    name: string;\n  };\n}\n\nexport interface TKECluster extends KubernetesResource {\n  spec?: TKEClusterSpec;\n  status?: {\n    version?: string;\n    phase?: string;\n    conditions?: Condition[];\n    addresses?: Array<{\n      host: string;\n      path?: '';\n      type: 'Advertise' | 'Public';\n      port: number;\n    }>;\n    serviceCIDR?: string;\n    nodeCIDRMaskSize?: number;\n    dnsIP?: string;\n  };\n  gatewayNode?: Node;\n}\n\nexport interface TKEMachineSpec {\n  clusterName?: string;\n  role?: 'node' | 'master';\n  ip?: string;\n  ipv6?: string;\n  publicIP?: string;\n  displayName?: string;\n  networkDevice?: string;\n  port: number;\n  password?: string;\n  privateKey?: string;\n  passPhrase?: string;\n  username: string;\n  labels?: {\n    ['nvidia-device-enable']?: string;\n    ['node-role.kubernetes.io/cpaas-system']?: string;\n  };\n  type?: string;\n  proxy?: {\n    type: string;\n    address: string;\n    username: string;\n    password: string;\n  };\n  annotations?: StringMap;\n  taints?: NodeTaint[];\n}\n\nexport interface ClusterCredential extends KubernetesResource {\n  clusterName: string;\n  caCert: string;\n  token: string;\n}\n\nexport interface TKEMachine extends KubernetesResource {\n  spec?: TKEMachineSpec;\n  status?: NodeStatus;\n}\n\nexport interface Machine extends KubernetesResource {\n  spec?: MachineSpec;\n  status?: MachineStatus;\n}\n\nexport interface MachineSpec {\n  cluster: string;\n  provider: string;\n  providerSpec: unknown;\n}\n\nexport interface MachineStatus {\n  userDataSecret?: {\n    name?: string;\n  };\n  nodeRef?: {\n    name?: string;\n  };\n  lastUpdate: string;\n  errReason: string;\n  errMessage: string;\n  phase: string;\n  conditions: Condition[];\n}\n\nexport interface ClusterView extends KubernetesResource {\n  spec?: void;\n  status?: ClusterViewStatus;\n}\n\nexport interface ClusterViewStatus {\n  provisionType: 'SelfHosted' | 'ProviderHosted' | 'Imported' | 'Registered';\n  clusterType: string;\n  supportWindows: boolean;\n  registryAddress: string;\n  conditions: Condition[];\n  projects: Array<{ name: string; displayName: string }>;\n  controlPlaneEndpoints: {\n    default: string;\n    advertise: string;\n    public?: string;\n  };\n  nodesInfo: {\n    readyNodes: number;\n    notReadyNodes: number;\n    architectures: string[];\n    totalCPUCores: number;\n    totalMemories: number;\n    criVersions: string[];\n    extraResources?: { [key: string]: ClusterDeviceResource };\n  };\n  clusterNetwork: {\n    haLoadBalancerType?: 'Alive' | 'ThirdParty';\n    cniType: string;\n    protocolStack: 'IPv4' | 'IPv6' | 'Dual-Stack';\n    serviceCIDRs: string[];\n    podCIDRs: string[];\n    extraInfo: Record<string, string>;\n    vrid?: number;\n    maxNodes?: number;\n  };\n  managedBy?: {\n    pluginName: string;\n    entrypoint: string;\n  };\n  gpuPluginType?: 'Virtual' | 'Physical';\n  highAvailable: boolean;\n  needUpgrade: boolean;\n  upgradable: boolean;\n  version: string;\n  phase: string;\n  extraArgs: Record<string, Record<string, string>>;\n  publicAlternativeNames: string[];\n}\n\nexport interface ClusterDeviceResource {\n  value: number;\n  unit?: string;\n  descriptionEn?: string;\n  descriptionZh?: string;\n  labelEn?: string;\n  labelZh?: string;\n}\n\nexport interface ProviderNetworkSpec {\n  defaultInterface: string;\n  customInterfaces: Array<{\n    interface: string;\n    nodes: string[];\n  }>;\n  excludeNodes: string[];\n}\n\nexport interface ProviderNetwork extends KubernetesResource {\n  spec: ProviderNetworkSpec;\n  status?: {\n    ready: boolean;\n  };\n}\n\nexport type LocaleDisplay = Record<string, string>;\n\nexport interface ProductEntrySpec {\n  logo?: string;\n  displayName?: LocaleDisplay;\n  description?: LocaleDisplay;\n  catalog?: LocaleDisplay;\n  entrypoint?: string;\n  ssoEnabled?: boolean;\n  packType?: 'Integrated' | 'BuildIn' | 'AdminPage';\n  version?: string;\n}\n\nexport interface ProductEntryStatus {\n  hiddenOnPortal?: boolean;\n  hiddenOnMenu?: boolean;\n  orderOnPortal?: number;\n  orderOnMenu?: number;\n}\n\nexport interface ProductEntry extends KubernetesResource {\n  spec?: ProductEntrySpec;\n  status?: ProductEntryStatus;\n}\n\nexport interface ProductStatus {\n  type:\n    | 'NotDeployed'\n    | 'InDeployment'\n    | 'Running'\n    | 'DeploymentFailure'\n    | 'RunningAbnormal'\n    | 'Deleting'\n    | 'DeleteFailure'\n    | 'DeploymentSucceed'\n    | 'SystemError'\n    | 'Upgrading';\n  icon: string;\n  text: string;\n}\n\nexport interface HelmRequestCondition {\n  lastProbeTime?: string;\n  lastTransitionTime?: string;\n  message: string;\n  reason: string; // PermissionCheckFailed\n  status: 'True' | 'False';\n  type: string;\n}\n\n/**\n * @link https://gitlab-ce.alauda.cn/container-platform/captain/-/blob/master/docs/crd.md\n */\nexport interface HelmRequest extends KubernetesResource {\n  spec?: HelmRequestSpec;\n  status?: {\n    phase: HelmRequestPhaseEnum;\n    notes?: string;\n    lastSpecHash?: string;\n    reason?: string;\n    conditions?: HelmRequestCondition[];\n    targetClusterSyncResults?: HelmRequestClusterSyncResults;\n  };\n}\n\nexport interface HelmRequestClusterSyncResults {\n  [cluster: string]: HelmRequestClusterSyncResult;\n}\n\nexport enum CloudHelmRequestStateEnum {\n  Pending = 'Pending',\n  Running = 'Running',\n  Stopped = 'Stopped',\n  Failed = 'Failed',\n  Empty = 'Empty',\n}\n\nexport interface HelmRequestClusterSyncResult {\n  appStatus: CloudHelmRequestStateEnum;\n  endpoint: string;\n  lastUpdateAt: string;\n  name: string;\n  phase: HelmRequestPhaseEnum;\n  reason: string;\n}\n\nexport enum HelmRequestPhaseEnum {\n  Synced = 'Synced',\n  Failed = 'Failed',\n  Pending = 'Pending',\n  Uninstalling = 'Uninstalling',\n}\n\nexport interface HelmRequestSpec {\n  chart?: string;\n  values: Record<string, unknown>;\n  valuesFrom?: Array<{\n    configMapKeyRef?: ConfigMapKeyRef;\n    secretKeyRef?: SecretKeyRef;\n  }>;\n  clusterName?: string;\n  namespace?: string;\n  releaseName?: string;\n  version?: string;\n  projectName?: string;\n  source?: {\n    oci?: HelmRequestOci;\n    http?: HelmRequestHttp;\n  };\n  targetClusters?: {\n    clusterNames: {\n      names: string[];\n    };\n  };\n}\n\nexport interface HelmRequestOci {\n  repo: string;\n  secretRef: string;\n}\nexport interface HelmRequestHttp {\n  url: string;\n  secretRef: string;\n}\n\n// http://confluence.alaudatech.com/pages/viewpage.action?pageId=39338366#1-%E8%8E%B7%E5%8F%96%E7%94%A8%E6%88%B7%E4%BF%A1%E6%81%AF\nexport interface User extends KubernetesResource {\n  spec?: UserSpec;\n}\n\nexport interface UserSpec {\n  connector_name?: string;\n  connector_type?: string;\n  email?: string;\n  mail?: string;\n  groups?: string[];\n  is_admin?: boolean;\n  valid?: boolean;\n  username?: string;\n  old_password?: string;\n  password?: string;\n  last_login_time?: string;\n  login_failure_times?: number;\n  state?: UserState;\n  is_disabled?: boolean;\n  expired?: {\n    begin: string;\n    end: string;\n  };\n  mobile?: string;\n  webhookType?: WebhookType;\n  webhookUrl?: string;\n  ids?: Array<{ type: string; id: string }>;\n}\n\nexport enum UserState {\n  ACTIVE = 'active',\n  LOCKED = 'locked',\n  INVALID = 'invalid',\n  DELETED = 'deleted',\n}\n\nexport type WebhookType = 'Webhook' | 'DingTalk' | 'WeChat';\n\nexport interface UserList extends KubernetesResourceList<User> {\n  total: number;\n}\n\n/**\n * https://confluence.alauda.cn/pages/viewpage.action?pageId=176883470\n */\nexport interface UserBinding extends KubernetesResource {\n  spec?: UserBindingSpec;\n}\n\nexport interface UserBindingSpec {\n  subjects: Array<{\n    kind: 'User' | 'Group' | 'ServiceAccount';\n    name: string;\n  }>;\n  roleRef: string;\n  scope: string; // 支持类型platform, cluster, project, namespace\n  constraint: Array<{\n    project?: string;\n    cluster?: string;\n    namespace?: string;\n  }>;\n}\n\nexport interface UserGroup extends KubernetesResource {\n  spec: UserGroupSpec;\n}\n\nexport interface UserGroupSpec {\n  refConnector?: {\n    id: string;\n    type: string;\n  };\n  name?: string;\n  description?: string;\n  users?: Array<{ name: string; importTime: string }>;\n}\n\nexport interface RoleRule {\n  module: string;\n  functionResourceRef: string;\n  functionMetadataName?: string;\n  verbs: string[];\n}\n\nexport interface RoleCustomRule {\n  apiGroup: string;\n  resources: string[];\n  verbs: string[];\n}\n\nexport interface RoleTemplateSpec {\n  rules?: RoleRule[];\n  customRules?: RoleCustomRule[];\n}\n\nexport interface RoleTemplate extends KubernetesResource {\n  spec?: RoleTemplateSpec;\n}\n\nexport interface UserRoleNamespace {\n  namespace: string;\n  cluster: string;\n}\n\nexport interface UserRole extends KubernetesResource {\n  name?: string;\n  roles?: string[];\n  namespaces?: Record<string, UserRoleNamespace[]>;\n}\n\nexport enum UserSecurityPolicyRule {\n  PasswordPolicy = 'PasswordPolicy',\n  UserLock = 'UserLockedPolicy',\n  UserDisable = 'UserDisabledPolicy',\n  Notification = 'NotificationPolicy',\n  AccessControl = 'AccessControlPolicy',\n  TwoFA = 'TwoFactorAuthenticationPolicy',\n}\n\nexport interface UserPolicyRule {\n  name: UserSecurityPolicyRule;\n  items: Array<{\n    enable: boolean;\n    key: string;\n    value?: string;\n  }>;\n}\n\nexport interface UserPolicy extends KubernetesResource {\n  rules: UserPolicyRule[];\n}\n\nexport interface Idp extends KubernetesResource {\n  spec?: { config?: LdapConfig | OidcConfig };\n  id: string;\n  name: string;\n  type: string;\n  namespace?: string;\n  config?: string;\n  ldapSync?: {\n    sync: boolean;\n    roles: string;\n  };\n  idpValidation?: {\n    username: string;\n    password: string;\n  };\n}\n\n// https://godoc.org/github.com/coreos/dex/connector/ldap\nexport interface LdapConfig {\n  host?: string;\n  insecureNoSSL?: boolean;\n  insecureSkipVerify?: boolean;\n  startTLS?: boolean;\n  rootCA?: string;\n  rootCAData?: string;\n  bindDN?: string;\n  bindPW?: string;\n  clientSecretRef?: string;\n  ldapType?: string;\n  usernamePrompt?: string;\n  userSearch?: LdapUserSearch;\n  groupSearch?: LdapGroupSearch;\n}\n\nexport interface LdapUserSearch {\n  baseDN?: string;\n  filter?: string;\n  scope?: string;\n  username?: string;\n  idAttr?: string;\n  emailAttr?: string;\n  nameAttr?: string;\n}\n\nexport interface LdapGroupSearch {\n  baseDN?: string;\n  filter?: string;\n  scope?: string;\n  userAttr?: string;\n  groupAttr?: string;\n  nameAttr?: string;\n}\n\n// https://godoc.org/github.com/coreos/dex/connector/oidc\nexport interface OidcConfig {\n  issuer?: string;\n  clientID?: string;\n  clientSecret?: string;\n  clientSecretRef?: string;\n  redirectURI?: string;\n  logoutURL?: string;\n  scopes?: string[];\n}\n\nexport interface AccessTokenInfo extends KubernetesResource {\n  spec: {\n    timestamp: number;\n    expiration: number;\n    description: string;\n  };\n}\n\nexport enum ChartRepoType {\n  Chart = 'Chart',\n  Git = 'Git',\n  OCIChart = 'OCI Chart',\n}\n\nexport interface ChartRepoSpec {\n  secret?: {\n    name: string;\n  };\n  url: string;\n  type?: ChartRepoType;\n  source?: {\n    url: string;\n    path: string;\n  };\n}\n\nexport interface ChartRepoStatus {\n  phase: ChartRepoPhaseEnum;\n}\n\nexport enum ChartRepoPhaseEnum {\n  Synced = 'Synced',\n  Failed = 'Failed',\n  Pending = 'Pending',\n}\n\nexport interface ChartRepoCreate extends KubernetesResource {\n  spec: ChartRepoCreateSpec;\n}\n\nexport interface ChartRepoCreateSpec {\n  secret?: Secret;\n  chartRepo: ChartRepo;\n}\n\nexport interface Chart extends KubernetesResource {\n  spec: {\n    appName?: string; // refers to: http://confluence.alauda.cn/pages/viewpage.action?pageId=50836763#id-[WIP]API%E8%AE%BE%E8%AE%A1-Chart%E5%88%97%E8%A1%A8\n    versions?: ChartVersion[];\n  };\n}\n\nexport enum ChartUploadStatusEnum {\n  UPLOAD_SUCCEEDED = 'upload_succeeded',\n  UPLOAD_FAILED = 'upload_failed',\n  UPLOADING = 'uploading',\n}\n\nexport interface ChartVersion {\n  name: string;\n  apiVersion: string;\n  appVersion: string;\n  deprecated: boolean;\n  created: string;\n  description: string;\n  digest: string;\n  urls: string[];\n  sources: string[];\n  version: string;\n  icon: string;\n  home: string;\n  maintainers: Array<{\n    name: string;\n    email: string;\n  }>;\n  status: ChartUploadStatusEnum;\n  annotations: StringMap;\n}\n\n// ChartRepo & Chart & HelmRequest\n// http://confluence.alaudatech.com/pages/viewpage.action?pageId=50836763\nexport interface ChartRepo extends KubernetesResource {\n  spec: ChartRepoSpec;\n  status?: ChartRepoStatus;\n}\n"]}
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"crd.js","sourceRoot":"","sources":["../../../../../../../libs/common/src/core/types/k8s/crd.ts"],"names":[],"mappings":"AAkFA,MAAM,CAAN,IAAY,mBAIX;AAJD,WAAY,mBAAmB;IAC7B,iDAA0B,CAAA;IAC1B,0CAAmB,CAAA;IACnB,4CAAqB,CAAA;AACvB,CAAC,EAJW,mBAAmB,KAAnB,mBAAmB,QAI9B;AAED,MAAM,CAAN,IAAY,kBAUX;AAVD,WAAY,kBAAkB;IAC5B,kDAA4B,CAAA;IAC5B,yCAAmB,CAAA;IACnB,2CAAqB,CAAA;IACrB,6CAAuB,CAAA;IACvB,oDAA8B,CAAA;IAC9B,6CAAuB,CAAA;IACvB,sDAAgC,CAAA;IAChC,6CAAuB,CAAA;IACvB,yCAAmB,CAAA;AACrB,CAAC,EAVW,kBAAkB,KAAlB,kBAAkB,QAU7B;AA+CD,MAAM,CAAC,MAAM,UAAU,GAAG;IACxB,IAAI,EAAE,MAAM;IACZ,kBAAkB,EAAE,mBAAmB;IACvC,MAAM,EAAE,QAAQ;IAChB,YAAY,EAAE,aAAa;IAC3B,aAAa,EAAE,cAAc;CACrB,CAAC;AAobX,MAAM,CAAN,IAAY,yBAMX;AAND,WAAY,yBAAyB;IACnC,gDAAmB,CAAA;IACnB,gDAAmB,CAAA;IACnB,gDAAmB,CAAA;IACnB,8CAAiB,CAAA;IACjB,4CAAe,CAAA;AACjB,CAAC,EANW,yBAAyB,KAAzB,yBAAyB,QAMpC;AAWD,MAAM,CAAN,IAAY,oBAKX;AALD,WAAY,oBAAoB;IAC9B,yCAAiB,CAAA;IACjB,yCAAiB,CAAA;IACjB,2CAAmB,CAAA;IACnB,qDAA6B,CAAA;AAC/B,CAAC,EALW,oBAAoB,KAApB,oBAAoB,QAK/B;AAgED,MAAM,CAAN,IAAY,SAKX;AALD,WAAY,SAAS;IACnB,8BAAiB,CAAA;IACjB,8BAAiB,CAAA;IACjB,gCAAmB,CAAA;IACnB,gCAAmB,CAAA;AACrB,CAAC,EALW,SAAS,KAAT,SAAS,QAKpB;AA0ED,MAAM,CAAN,IAAY,sBAOX;AAPD,WAAY,sBAAsB;IAChC,2DAAiC,CAAA;IACjC,uDAA6B,CAAA;IAC7B,4DAAkC,CAAA;IAClC,6DAAmC,CAAA;IACnC,+DAAqC,CAAA;IACrC,iEAAuC,CAAA;AACzC,CAAC,EAPW,sBAAsB,KAAtB,sBAAsB,QAOjC;AAuFD,MAAM,CAAN,IAAY,aAIX;AAJD,WAAY,aAAa;IACvB,gCAAe,CAAA;IACf,4BAAW,CAAA;IACX,uCAAsB,CAAA;AACxB,CAAC,EAJW,aAAa,KAAb,aAAa,QAIxB;AAkBD,MAAM,CAAN,IAAY,kBAIX;AAJD,WAAY,kBAAkB;IAC5B,uCAAiB,CAAA;IACjB,uCAAiB,CAAA;IACjB,yCAAmB,CAAA;AACrB,CAAC,EAJW,kBAAkB,KAAlB,kBAAkB,QAI7B;AAkBD,MAAM,CAAN,IAAY,qBAIX;AAJD,WAAY,qBAAqB;IAC/B,8DAAqC,CAAA;IACrC,wDAA+B,CAAA;IAC/B,gDAAuB,CAAA;AACzB,CAAC,EAJW,qBAAqB,KAArB,qBAAqB,QAIhC","sourcesContent":["import { ValueOf } from 'ts-essentials';\n\nimport { StringMap } from '../commons';\n\nimport {\n  Condition,\n  KubernetesResource,\n  KubernetesResourceList,\n  ObjectMeta,\n} from './core';\nimport {\n  ConfigMapKeyRef,\n  Node,\n  NodeStatus,\n  NodeTaint,\n  Secret,\n  SecretKeyRef,\n} from './raw';\n\nexport interface ClusterSpec {\n  authInfo?: {\n    controller: {\n      kind: string;\n      namespace: string;\n      name: string;\n    };\n  };\n  kubernetesApiEndpoints?: {\n    caBundle?: string;\n    serverEndpoints: Array<{\n      clientCIDR: string;\n      serverAddress: string;\n    }>;\n  };\n}\n\nexport type ClusterStatusReason =\n  | 'Timeout'\n  | 'Forbidden'\n  | 'Unauthorized'\n  | 'SomeComponentsUnhealthy'\n  | 'SomeNodesNotReady';\n\nexport interface ClusterStatusCondition extends Condition {\n  lastTransitionTime: string;\n  type:\n    | 'NotReachable'\n    | 'NotAccessible'\n    | 'ComponentNotHealthy'\n    | 'NodeNotReady';\n  status: 'True' | 'False';\n  reason: ClusterStatusReason;\n}\n\nexport interface ClusterStatus {\n  version: string;\n  conditions: ClusterStatusCondition[];\n}\n\n// clusters.clusterregistry.k8s.io 的类型定义\nexport interface Cluster extends KubernetesResource {\n  metadata?: ObjectMeta & {\n    finalizers?: string[];\n  };\n  spec?: ClusterSpec;\n  status?: ClusterStatus;\n  details?: {\n    group: string;\n    kind: string;\n    name: string;\n    uid: string;\n  };\n}\n\n// Alauda Product\nexport interface AlaudaProductStatus extends Condition {\n  deployStatus?: AlaudaDeployStatus;\n  runningStatus?: AlaudaRunningStatus;\n  message: string;\n  deployTime?: string;\n}\n\nexport enum AlaudaRunningStatus {\n  NOT_RUNNING = 'NotRunning',\n  HEALTHY = 'Healthy',\n  ABNORMAL = 'Abnormal',\n}\n\nexport enum AlaudaDeployStatus {\n  NOT_DEPLOYED = 'NotDeployed',\n  SUCCESS = 'success',\n  ABNORMAL = 'Abnormal',\n  DEPLOYING = 'Deploying',\n  DEPLOY_FAILED = 'DeployFailed',\n  UPGRADING = 'Upgrading',\n  UPGRADE_FAILED = 'UpgradeFailed',\n  COMPLETED = 'Completed',\n  PENDING = 'Pending',\n}\nexport interface ProductBase extends KubernetesResource {\n  spec: ProductBaseSpec;\n  status?: ProductBaseStatus;\n}\n\nexport interface ProductStatusCondition {\n  status?: 'True' | 'False' | 'Unknown';\n  reason?: string;\n  message?: string;\n  type: 'Ready' | 'Initialized' | 'Reclaimed' | 'Succeed';\n  lastTransitionTime?: string;\n  lastHeartbeatTime?: string;\n}\n\nexport interface ProductBaseStatus {\n  globalID: string;\n  cloud: {\n    phase: 'ONLine' | 'ConnectFailed' | 'Connecting' | 'OFFLine';\n    message: string;\n    connectURL: string;\n  };\n  version: string;\n  phase?:\n    | 'Pending'\n    | 'Provisioning'\n    | 'Provisioned'\n    | 'Deleting'\n    | 'Failed'\n    | 'Running'\n    | 'Installing' // tdsql\n    | 'Upgrading';\n  productEntrypoint?: string;\n  deletable?: boolean;\n  conditions?: ProductStatusCondition[];\n  prometheusAddress?: string;\n  elasticSearchAddress?: string;\n  kafkaAddress?: string;\n  containerPlatform?: AlaudaProductStatus;\n  devops?: AlaudaProductStatus;\n  serviceMesh?: AlaudaProductStatus;\n  dataServices?: AlaudaProductStatus;\n  base?: AlaudaProductStatus;\n  progress?: number;\n  replicas?: number;\n}\n\nexport const ProductKey = {\n  BASE: 'base',\n  CONTAINER_PLATFORM: 'containerPlatform',\n  DEVOPS: 'devops',\n  SERVICE_MESH: 'serviceMesh',\n  DATA_SERVICES: 'dataServices',\n} as const;\n\nexport type ProductKey = ValueOf<typeof ProductKey>;\n\ntype GenProduct<T extends ProductKey> = Record<T, { install: boolean }>;\n\nexport interface Tls {\n  secretRef: {\n    name: string;\n  };\n}\n\nexport interface ProductBaseSpec extends GenProduct<ProductKey> {\n  alternativeURLs: string[];\n  chartMuseum: {\n    url: string;\n  };\n  packageEdition: string;\n  valuesOverride?: {\n    dex: StringMap;\n  };\n  chartVersions: [{ name: string; version: string }];\n  defaultAdmin: {\n    account: string;\n    email: string;\n    password: string;\n  };\n  defaultRedirectPath: string;\n  deployType: string;\n  elasticsearch: {\n    install: boolean;\n    nodes: string[];\n    username: string;\n  };\n  http: {\n    forceRedirectHttps?: boolean;\n    httpPort?: number;\n    httpsPort?: number;\n    tls?: Tls;\n  };\n  ingress: {\n    controller: { install: boolean; nodes: string[] };\n    host: string;\n    ingressClassName: string;\n  };\n  kafka: {\n    auth: boolean;\n    install: boolean;\n    nodes: string[];\n    username: string;\n  };\n  logAgent: {\n    enable: boolean;\n  };\n  logCenter: {\n    enable: boolean;\n  };\n  platformURL: string;\n  prometheus: {\n    install: boolean;\n    replicas: number;\n    storage: { capacity: number; nodes: string[]; path: string; type: string };\n  };\n  registry: {\n    external?: string;\n    address: string;\n    username: string;\n    secretRef?: string;\n  };\n  replicas: number;\n  version: string;\n  cloud: {\n    connect: boolean;\n    connectType: string;\n  };\n}\n\nexport interface ProjectSpec {\n  clusters: ProjectCluster[];\n  status?: {\n    phase: string;\n  };\n  clusterDeletePolicy?: 'Delete' | 'Retain';\n}\n\nexport interface ProjectCluster {\n  name: string;\n  quota: Record<string, string>;\n  type?: '' | 'FedMember';\n}\n\nexport interface Project extends KubernetesResource {\n  spec: ProjectSpec;\n  status?: {\n    phase: string;\n  };\n}\n\nexport interface ServiceMeshGroup extends KubernetesResource {\n  spec: {\n    k8sVersion: string;\n    withoutIstio?: boolean;\n    istioVersion: string;\n    primary: string;\n    selector: {\n      [key: string]: string;\n    };\n    clusters: string[];\n    meshCommonConfig?: MeshCommonConfig;\n    clusterConfigs?: {\n      [clusterName: string]: ClusterConfig;\n    };\n  };\n  status: {\n    status: string;\n    Message: string;\n    clusterCount: number;\n    latestUpdateTime: string;\n    NonReadyClusterCount: number;\n  };\n}\n\nexport interface MeshCommonConfig {\n  elasticsearch: {\n    isDefault: boolean;\n    password?: string;\n    url: string;\n    username?: string;\n  };\n  monitorType: string;\n  prometheusBasicAuth: {\n    password: string;\n    username: string;\n  };\n  isDefaultMonitor: boolean;\n  prometheusURL: string;\n  traceSampling: number;\n}\n\nexport interface ClusterConfig {\n  istioSidecar: {\n    cpuValue: string;\n    memoryValue: string;\n  };\n  kafka?: {\n    authentication: string;\n    enabled: boolean;\n    password: string;\n    url: string;\n    username: string;\n  };\n  redis?: RedisConfig;\n  traceSampling: number;\n}\n\nexport interface RedisConfig {\n  enabled: boolean;\n  kind: 'single' | 'cluster' | 'sentinel';\n  address: string;\n  password: string;\n  masterName?: string;\n}\n\n// TKE\nexport interface TKEClusterSpec {\n  displayName: string;\n  serviceCIDR?: string;\n  dockerExtraArgs?: StringMap;\n  kubeletExtraArgs?: StringMap;\n  controllerManagerExtraArgs?: StringMap;\n  schedulerExtraArgs?: StringMap;\n  publicAlternativeNames?: string[];\n  clusterCIDR?: string;\n  networkDevice?: string;\n  properties?: {\n    maxClusterServiceNum?: number;\n    maxNodePodNum?: number;\n    oversoldRatio?: {\n      cpu: string;\n      memory: string;\n    };\n  };\n  features?: {\n    enableMasterSchedule?: boolean;\n    ipv6DualStack?: boolean;\n    files?: Array<{\n      src?: string;\n      dst?: string;\n    }>;\n    ha?: {\n      thirdParty?: {\n        vip?: string;\n        vport?: number;\n      };\n      tke?: {\n        vrid?: unknown;\n      };\n    };\n  };\n  type: 'Baremetal' | 'Imported';\n  version?: string;\n  machines?: TKEMachineSpec[];\n  dnsDomain?: string;\n  apiServerExtraArgs?: StringMap;\n  clusterCredentialRef?: {\n    name: string;\n  };\n}\n\nexport interface TKECluster extends KubernetesResource {\n  spec?: TKEClusterSpec;\n  status?: {\n    version?: string;\n    phase?: string;\n    conditions?: Condition[];\n    addresses?: Array<{\n      host: string;\n      path?: '';\n      type: 'Advertise' | 'Public';\n      port: number;\n    }>;\n    serviceCIDR?: string;\n    nodeCIDRMaskSize?: number;\n    dnsIP?: string;\n  };\n  gatewayNode?: Node;\n}\n\nexport interface TKEMachineSpec {\n  clusterName?: string;\n  role?: 'node' | 'master';\n  ip?: string;\n  ipv6?: string;\n  publicIP?: string;\n  displayName?: string;\n  networkDevice?: string;\n  port: number;\n  password?: string;\n  privateKey?: string;\n  passPhrase?: string;\n  username: string;\n  labels?: {\n    ['nvidia-device-enable']?: string;\n    ['node-role.kubernetes.io/cpaas-system']?: string;\n  };\n  type?: string;\n  proxy?: {\n    type: string;\n    address: string;\n    username: string;\n    password: string;\n  };\n  annotations?: StringMap;\n  taints?: NodeTaint[];\n}\n\nexport interface ClusterCredential extends KubernetesResource {\n  clusterName: string;\n  caCert: string;\n  token: string;\n}\n\nexport interface TKEMachine extends KubernetesResource {\n  spec?: TKEMachineSpec;\n  status?: NodeStatus;\n}\n\nexport interface Machine extends KubernetesResource {\n  spec?: MachineSpec;\n  status?: MachineStatus;\n}\n\nexport interface MachineSpec {\n  cluster: string;\n  provider: string;\n  providerSpec: unknown;\n}\n\nexport interface MachineStatus {\n  userDataSecret?: {\n    name?: string;\n  };\n  nodeRef?: {\n    name?: string;\n  };\n  lastUpdate: string;\n  errReason: string;\n  errMessage: string;\n  phase: string;\n  conditions: Condition[];\n}\n\nexport interface ClusterView extends KubernetesResource {\n  spec?: void;\n  status?: ClusterViewStatus;\n}\n\nexport interface ClusterViewStatus {\n  provisionType: 'SelfHosted' | 'ProviderHosted' | 'Imported' | 'Registered';\n  clusterType: string;\n  supportWindows: boolean;\n  registryAddress: string;\n  conditions: Condition[];\n  projects: Array<{ name: string; displayName: string }>;\n  controlPlaneEndpoints: {\n    default: string;\n    advertise: string;\n    public?: string;\n  };\n  nodesInfo: {\n    readyNodes: number;\n    notReadyNodes: number;\n    architectures: string[];\n    totalCPUCores: number;\n    totalMemories: number;\n    criVersions: string[];\n    extraResources?: { [key: string]: ClusterDeviceResource };\n  };\n  clusterNetwork: {\n    haLoadBalancerType?: 'Alive' | 'ThirdParty';\n    cniType: string;\n    protocolStack: 'IPv4' | 'IPv6' | 'Dual-Stack';\n    serviceCIDRs: string[];\n    podCIDRs: string[];\n    extraInfo: Record<string, string>;\n    vrid?: number;\n    maxNodes?: number;\n  };\n  managedBy?: {\n    pluginName: string;\n    entrypoint: string;\n  };\n  gpuPluginType?: 'Virtual' | 'Physical';\n  highAvailable: boolean;\n  needUpgrade: boolean;\n  upgradable: boolean;\n  version: string;\n  phase: string;\n  extraArgs: Record<string, Record<string, string>>;\n  publicAlternativeNames: string[];\n}\n\nexport interface ClusterDeviceResource {\n  value: number;\n  unit?: string;\n  descriptionEn?: string;\n  descriptionZh?: string;\n  labelEn?: string;\n  labelZh?: string;\n}\n\nexport interface ProviderNetworkSpec {\n  defaultInterface: string;\n  customInterfaces: Array<{\n    interface: string;\n    nodes: string[];\n  }>;\n  excludeNodes: string[];\n}\n\nexport interface ProviderNetwork extends KubernetesResource {\n  spec: ProviderNetworkSpec;\n  status?: {\n    ready: boolean;\n  };\n}\n\nexport type LocaleDisplay = Record<string, string>;\n\nexport interface ProductEntrySpec {\n  logo?: string;\n  displayName?: LocaleDisplay;\n  description?: LocaleDisplay;\n  catalog?: LocaleDisplay;\n  entrypoint?: string;\n  ssoEnabled?: boolean;\n  packType?: 'Integrated' | 'BuildIn' | 'AdminPage';\n  version?: string;\n}\n\nexport interface ProductEntryStatus {\n  hiddenOnPortal?: boolean;\n  hiddenOnMenu?: boolean;\n  orderOnPortal?: number;\n  orderOnMenu?: number;\n}\n\nexport interface ProductEntry extends KubernetesResource {\n  spec?: ProductEntrySpec;\n  status?: ProductEntryStatus;\n}\n\nexport interface ProductStatus {\n  type:\n    | 'NotDeployed'\n    | 'InDeployment'\n    | 'Running'\n    | 'DeploymentFailure'\n    | 'RunningAbnormal'\n    | 'Deleting'\n    | 'DeleteFailure'\n    | 'DeploymentSucceed'\n    | 'SystemError'\n    | 'Upgrading';\n  icon: string;\n  text: string;\n}\n\nexport interface HelmRequestCondition {\n  lastProbeTime?: string;\n  lastTransitionTime?: string;\n  message: string;\n  reason: string; // PermissionCheckFailed\n  status: 'True' | 'False';\n  type: string;\n}\n\n/**\n * @link https://gitlab-ce.alauda.cn/container-platform/captain/-/blob/master/docs/crd.md\n */\nexport interface HelmRequest extends KubernetesResource {\n  spec?: HelmRequestSpec;\n  status?: {\n    phase: HelmRequestPhaseEnum;\n    notes?: string;\n    lastSpecHash?: string;\n    reason?: string;\n    conditions?: HelmRequestCondition[];\n    targetClusterSyncResults?: HelmRequestClusterSyncResults;\n  };\n}\n\nexport interface HelmRequestClusterSyncResults {\n  [cluster: string]: HelmRequestClusterSyncResult;\n}\n\nexport enum CloudHelmRequestStateEnum {\n  Pending = 'Pending',\n  Running = 'Running',\n  Stopped = 'Stopped',\n  Failed = 'Failed',\n  Empty = 'Empty',\n}\n\nexport interface HelmRequestClusterSyncResult {\n  appStatus: CloudHelmRequestStateEnum;\n  endpoint: string;\n  lastUpdateAt: string;\n  name: string;\n  phase: HelmRequestPhaseEnum;\n  reason: string;\n}\n\nexport enum HelmRequestPhaseEnum {\n  Synced = 'Synced',\n  Failed = 'Failed',\n  Pending = 'Pending',\n  Uninstalling = 'Uninstalling',\n}\n\nexport interface HelmRequestSpec {\n  chart?: string;\n  values: Record<string, unknown>;\n  valuesFrom?: Array<{\n    configMapKeyRef?: ConfigMapKeyRef;\n    secretKeyRef?: SecretKeyRef;\n  }>;\n  clusterName?: string;\n  namespace?: string;\n  releaseName?: string;\n  version?: string;\n  projectName?: string;\n  source?: {\n    oci?: HelmRequestOci;\n    http?: HelmRequestHttp;\n  };\n  targetClusters?: {\n    clusterNames: {\n      names: string[];\n    };\n  };\n}\n\nexport interface HelmRequestOci {\n  repo: string;\n  secretRef: string;\n}\nexport interface HelmRequestHttp {\n  url: string;\n  secretRef: string;\n}\n\n// http://confluence.alaudatech.com/pages/viewpage.action?pageId=39338366#1-%E8%8E%B7%E5%8F%96%E7%94%A8%E6%88%B7%E4%BF%A1%E6%81%AF\nexport interface User extends KubernetesResource {\n  spec?: UserSpec;\n}\n\nexport interface UserSpec {\n  connector_name?: string;\n  connector_type?: string;\n  email?: string;\n  mail?: string;\n  groups?: string[];\n  is_admin?: boolean;\n  valid?: boolean;\n  username?: string;\n  old_password?: string;\n  password?: string;\n  last_login_time?: string;\n  login_failure_times?: number;\n  state?: UserState;\n  is_disabled?: boolean;\n  expired?: {\n    begin: string;\n    end: string;\n  };\n  mobile?: string;\n  webhookType?: WebhookType;\n  webhookUrl?: string;\n  ids?: Array<{ type: string; id: string }>;\n}\n\nexport enum UserState {\n  ACTIVE = 'active',\n  LOCKED = 'locked',\n  INVALID = 'invalid',\n  DELETED = 'deleted',\n}\n\nexport type WebhookType = 'Webhook' | 'DingTalk' | 'WeChat';\n\nexport interface UserList extends KubernetesResourceList<User> {\n  total: number;\n}\n\n/**\n * https://confluence.alauda.cn/pages/viewpage.action?pageId=176883470\n */\nexport interface UserBinding extends KubernetesResource {\n  spec?: UserBindingSpec;\n}\n\nexport interface UserBindingSpec {\n  subjects: Array<{\n    kind: 'User' | 'Group' | 'ServiceAccount';\n    name: string;\n  }>;\n  roleRef: string;\n  scope: string; // 支持类型platform, cluster, project, namespace\n  constraint: Array<{\n    project?: string;\n    cluster?: string;\n    namespace?: string;\n  }>;\n}\n\nexport interface UserGroup extends KubernetesResource {\n  spec: UserGroupSpec;\n}\n\nexport interface UserGroupSpec {\n  refConnector?: {\n    id: string;\n    type: string;\n  };\n  name?: string;\n  description?: string;\n  users?: Array<{ name: string; importTime: string }>;\n}\n\nexport interface RoleRule {\n  functionResourceRef: string;\n  verbs: string[];\n}\n\nexport interface RoleCustomRule {\n  apiGroup: string;\n  resources: string[];\n  verbs: string[];\n}\n\nexport interface RoleTemplateSpec {\n  rules?: RoleRule[];\n  customRules?: RoleCustomRule[];\n}\n\nexport interface RoleTemplate extends KubernetesResource {\n  spec?: RoleTemplateSpec;\n}\n\nexport interface UserRoleNamespace {\n  namespace: string;\n  cluster: string;\n}\n\nexport interface UserRole extends KubernetesResource {\n  name?: string;\n  roles?: string[];\n  namespaces?: Record<string, UserRoleNamespace[]>;\n}\n\nexport enum UserSecurityPolicyRule {\n  PasswordPolicy = 'PasswordPolicy',\n  UserLock = 'UserLockedPolicy',\n  UserDisable = 'UserDisabledPolicy',\n  Notification = 'NotificationPolicy',\n  AccessControl = 'AccessControlPolicy',\n  TwoFA = 'TwoFactorAuthenticationPolicy',\n}\n\nexport interface UserPolicyRule {\n  name: UserSecurityPolicyRule;\n  items: Array<{\n    enable: boolean;\n    key: string;\n    value?: string;\n  }>;\n}\n\nexport interface UserPolicy extends KubernetesResource {\n  rules: UserPolicyRule[];\n}\n\nexport interface Idp extends KubernetesResource {\n  spec?: { config?: LdapConfig | OidcConfig };\n  id: string;\n  name: string;\n  type: string;\n  namespace?: string;\n  config?: string;\n  ldapSync?: {\n    sync: boolean;\n    roles: string;\n  };\n  idpValidation?: {\n    username: string;\n    password: string;\n  };\n}\n\n// https://godoc.org/github.com/coreos/dex/connector/ldap\nexport interface LdapConfig {\n  host?: string;\n  insecureNoSSL?: boolean;\n  insecureSkipVerify?: boolean;\n  startTLS?: boolean;\n  rootCA?: string;\n  rootCAData?: string;\n  bindDN?: string;\n  bindPW?: string;\n  clientSecretRef?: string;\n  ldapType?: string;\n  usernamePrompt?: string;\n  userSearch?: LdapUserSearch;\n  groupSearch?: LdapGroupSearch;\n}\n\nexport interface LdapUserSearch {\n  baseDN?: string;\n  filter?: string;\n  scope?: string;\n  username?: string;\n  idAttr?: string;\n  emailAttr?: string;\n  nameAttr?: string;\n}\n\nexport interface LdapGroupSearch {\n  baseDN?: string;\n  filter?: string;\n  scope?: string;\n  userAttr?: string;\n  groupAttr?: string;\n  nameAttr?: string;\n}\n\n// https://godoc.org/github.com/coreos/dex/connector/oidc\nexport interface OidcConfig {\n  issuer?: string;\n  clientID?: string;\n  clientSecret?: string;\n  clientSecretRef?: string;\n  redirectURI?: string;\n  logoutURL?: string;\n  scopes?: string[];\n}\n\nexport interface AccessTokenInfo extends KubernetesResource {\n  spec: {\n    timestamp: number;\n    expiration: number;\n    description: string;\n  };\n}\n\nexport enum ChartRepoType {\n  Chart = 'Chart',\n  Git = 'Git',\n  OCIChart = 'OCI Chart',\n}\n\nexport interface ChartRepoSpec {\n  secret?: {\n    name: string;\n  };\n  url: string;\n  type?: ChartRepoType;\n  source?: {\n    url: string;\n    path: string;\n  };\n}\n\nexport interface ChartRepoStatus {\n  phase: ChartRepoPhaseEnum;\n}\n\nexport enum ChartRepoPhaseEnum {\n  Synced = 'Synced',\n  Failed = 'Failed',\n  Pending = 'Pending',\n}\n\nexport interface ChartRepoCreate extends KubernetesResource {\n  spec: ChartRepoCreateSpec;\n}\n\nexport interface ChartRepoCreateSpec {\n  secret?: Secret;\n  chartRepo: ChartRepo;\n}\n\nexport interface Chart extends KubernetesResource {\n  spec: {\n    appName?: string; // refers to: http://confluence.alauda.cn/pages/viewpage.action?pageId=50836763#id-[WIP]API%E8%AE%BE%E8%AE%A1-Chart%E5%88%97%E8%A1%A8\n    versions?: ChartVersion[];\n  };\n}\n\nexport enum ChartUploadStatusEnum {\n  UPLOAD_SUCCEEDED = 'upload_succeeded',\n  UPLOAD_FAILED = 'upload_failed',\n  UPLOADING = 'uploading',\n}\n\nexport interface ChartVersion {\n  name: string;\n  apiVersion: string;\n  appVersion: string;\n  deprecated: boolean;\n  created: string;\n  description: string;\n  digest: string;\n  urls: string[];\n  sources: string[];\n  version: string;\n  icon: string;\n  home: string;\n  maintainers: Array<{\n    name: string;\n    email: string;\n  }>;\n  status: ChartUploadStatusEnum;\n  annotations: StringMap;\n}\n\n// ChartRepo & Chart & HelmRequest\n// http://confluence.alaudatech.com/pages/viewpage.action?pageId=50836763\nexport interface ChartRepo extends KubernetesResource {\n  spec: ChartRepoSpec;\n  status?: ChartRepoStatus;\n}\n"]}
|