@alauda-fe/common 1.4.34 → 1.4.35
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/core/types/k8s/raw.d.ts
CHANGED
|
@@ -47,7 +47,7 @@ export declare enum SecretType {
|
|
|
47
47
|
BasicAuth = "kubernetes.io/basic-auth",
|
|
48
48
|
BasicAuthSecret = "kubernetes.io/basic-auth-secret",
|
|
49
49
|
Database = "kubernetes.io/database",
|
|
50
|
-
|
|
50
|
+
DKConfigJson = "kubernetes.io/dockerconfigjson",
|
|
51
51
|
OAuth2 = "katanomi.dev/oauth2",
|
|
52
52
|
NoAuth = "kubernetes.io/no-auth",
|
|
53
53
|
DevOpsOAuth2 = "devops.alauda.io/oauth2",
|
|
@@ -24,7 +24,7 @@ export var SecretType;
|
|
|
24
24
|
SecretType["BasicAuth"] = "kubernetes.io/basic-auth";
|
|
25
25
|
SecretType["BasicAuthSecret"] = "kubernetes.io/basic-auth-secret";
|
|
26
26
|
SecretType["Database"] = "kubernetes.io/database";
|
|
27
|
-
SecretType["
|
|
27
|
+
SecretType["DKConfigJson"] = "kubernetes.io/dockerconfigjson";
|
|
28
28
|
SecretType["OAuth2"] = "katanomi.dev/oauth2";
|
|
29
29
|
SecretType["NoAuth"] = "kubernetes.io/no-auth";
|
|
30
30
|
SecretType["DevOpsOAuth2"] = "devops.alauda.io/oauth2";
|
|
@@ -123,4 +123,4 @@ export const SERVICE_PORT_PROTOCOLS = [
|
|
|
123
123
|
'HTTP2',
|
|
124
124
|
'gRPC',
|
|
125
125
|
];
|
|
126
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"raw.js","sourceRoot":"","sources":["../../../../../../../libs/common/src/core/types/k8s/raw.ts"],"names":[],"mappings":"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","sourcesContent":["// TypeMeta describes an individual object in an API response or request\n// with strings representing the type of the object and its API schema version.\n// Structures that are versioned or persisted should inline TypeMeta.\n\n/**\n * 此文件只维护 所有的 k8s 原生类型\n */\n\nimport { StringMap } from '../commons';\nimport { ValueOf } from '../helpers';\nimport { OpenAPIV3SchemaObject } from '../schema';\n\nimport {\n  KubernetesResource,\n  LabelSelector,\n  LabelSelectorRequirement,\n  ObjectMeta,\n  ObjectReference,\n  Condition,\n} from './core';\n\nexport interface Secret<T = StringMap> extends KubernetesResource {\n  data?: T;\n  stringData?: StringMap;\n  type?: SecretType;\n  // ! hack, not spec\n  global?: boolean;\n  certificate?: Certificate;\n}\n\nexport interface Namespace extends KubernetesResource {\n  status?: NamespaceStatus;\n}\n\nexport interface NamespaceStatus {\n  phase?: string;\n}\n\nexport interface ScopedResourceSelectorRequirement {\n  operator: 'In' | 'NotIn' | 'Exists' | 'DoesNotExist';\n  scopeName: string;\n  values: string;\n}\n\nexport interface ScopeSelector {\n  matchExpressions: ScopedResourceSelectorRequirement[];\n}\n\nexport enum K8sResourceAction {\n  GET = 'get',\n  LIST = 'list',\n  WATCH = 'watch',\n  CREATE = 'create',\n  UPDATE = 'update',\n  PATCH = 'patch',\n  DELETE = 'delete',\n  DELETE_COLLECTION = 'deletecollection',\n  PROXY = 'proxy',\n  REDIRECT = 'redirect',\n  ALL = '*',\n}\n\nexport enum SecretType {\n  Opaque = 'Opaque',\n  TLS = 'kubernetes.io/tls',\n  SSHKey = 'kubernetes.io/ssh-public-key',\n  SSHAuth = 'kubernetes.io/ssh-auth',\n  BasicAuth = 'kubernetes.io/basic-auth',\n  BasicAuthSecret = 'kubernetes.io/basic-auth-secret',\n  Database = 'kubernetes.io/database',\n  DockerConfigJson = 'kubernetes.io/dockerconfigjson',\n  OAuth2 = 'katanomi.dev/oauth2',\n  NoAuth = 'kubernetes.io/no-auth',\n  DevOpsOAuth2 = 'devops.alauda.io/oauth2',\n  DynamicSecretKey = 'katanomi.dev/dynamic',\n  CloudCredential = 'CloudCredential',\n}\n\nexport interface StatefulSet extends KubernetesResource {\n  spec?: StatefulSetSpec;\n  status?: StatefulSetStatus;\n}\n\nexport interface StatefulSetSpec {\n  replicas?: number;\n  selector?: LabelSelector;\n  template?: PodTemplateSpec;\n\n  // serviceName is the name of the service that governs this StatefulSet.\n  // This service must exist before the StatefulSet, and is responsible for\n  // the network identity of the set. Pods get DNS/hostnames that follow the\n  // pattern: pod-specific-string.serviceName.default.svc.cluster.local\n  // where \"pod-specific-string\" is managed by the StatefulSet controller.\n  serviceName?: string;\n  updateStrategy?: StatefulSetUpdateStrategy;\n  revisionHistoryLimit?: number;\n  volumeClaimTemplates?: PersistentVolumeClaim[];\n}\n\nexport interface PodTemplateSpec extends KubernetesResource {\n  spec?: PodSpec;\n}\n\nexport interface PodSpec {\n  containers?: Container[];\n  initContainers?: Container[];\n  ephemeralContainers?: EphemeralContainer[];\n  volumes?: Volume[];\n  hostAliases?: HostAliases[];\n  nodeSelector?: StringMap;\n  hostNetwork?: boolean;\n  affinity?: Affinity;\n  restartPolicy?: string;\n  imagePullSecrets?: LocalObjectReference[];\n  serviceAccountName?: string;\n  serviceAccount?: string;\n  nodeName?: string;\n  terminationGracePeriodSeconds?: number;\n  tolerations?: Toleration[];\n}\n\nexport interface Toleration {\n  key?: string;\n  value?: string;\n  operator?: TolerationOperator;\n  tolerationSeconds?: number;\n  effect?: TaintEffect;\n}\n\nexport enum TolerationOperator {\n  Exists = 'Exists',\n  Equal = 'Equal',\n}\n\nexport enum TaintEffect {\n  NoSchedule = 'NoSchedule',\n  PreferNoSchedule = 'PreferNoSchedule',\n  NoExecute = 'NoExecute',\n}\n\nexport interface Container {\n  name?: string;\n  image?: string;\n  command?: string[];\n  args?: string[];\n  env?: EnvVar[];\n  envFrom?: EnvFromSource[];\n  workingDir?: string;\n  ports?: ContainerPort[];\n  resources?: ResourceRequirements;\n  volumeMounts?: VolumeMount[];\n  livenessProbe?: Probe;\n  readinessProbe?: Probe;\n  lifecycle?: PodLifeCycle;\n  restartPolicy?: string;\n}\n\nexport interface EnvVarSource {\n  configMapKeyRef?: ConfigMapKeyRef;\n  secretKeyRef?: SecretKeyRef;\n  fieldRef?: ObjectFieldSelector;\n  resourceFieldRef?: ResourceFieldSelector;\n}\n\nexport interface EnvVar {\n  name: string;\n  value?: string;\n  valueFrom?: EnvVarSource;\n}\n\nexport interface EnvFromSource {\n  prefix?: string;\n  configMapRef?: ConfigMapRef;\n  secretRef?: SecretRef;\n}\n\nexport interface PodLifeCycle {\n  postStart?: PodLifeCycleHook;\n  preStop?: PodLifeCycleHook;\n}\n\nexport interface PodLifeCycleHook {\n  exec: { command: string[] };\n}\n\nexport interface HTTPGetAction {\n  host?: string;\n  httpHeaders?: HTTPHeader[];\n  path: string;\n  port?: number | string;\n  scheme?: string;\n}\n\nexport interface EphemeralContainer {\n  command: string[];\n  image: string;\n  imagePullPolicy: string;\n  name: string;\n  stdin: boolean;\n  tty: boolean;\n  terminationMessagePolicy?: string;\n  [key: string]: unknown;\n}\n\nexport type StatefulSetStatus = Partial<{\n  collisionCount: number;\n  observedGeneration: number;\n  replicas: number;\n  readyReplicas: number;\n  currentReplicas: number;\n  currentRevision: string;\n  updateRevision: string;\n  updatedReplicas?: number;\n}>;\n\nexport type DeploymentStrategyType = 'RollingUpdate' | 'Recreate';\nexport type DaemonSetUpdateStrategyType = 'RollingUpdate' | 'OnDelete';\nexport type StatefulSetUpdateStrategyType = 'RollingUpdate' | 'OnDelete';\n\nexport interface DeploymentStrategy {\n  type?: DeploymentStrategyType;\n  rollingUpdate?: RollingUpdateDeployment;\n}\n\nexport interface RollingUpdateDeployment {\n  maxUnavailable?: string | number;\n  maxSurge?: string | number;\n}\n\nexport interface StatefulSetUpdateStrategy {\n  type?: StatefulSetUpdateStrategyType;\n  rollingUpdate?: RollingUpdateStatefulSetStrategy;\n}\n\nexport interface RollingUpdateStatefulSetStrategy {\n  partition?: string | number;\n}\n\nexport interface Ingress extends KubernetesResource {\n  spec?: IngressSpec;\n}\n\nexport interface IngressSpec {\n  ingressClassName?: string;\n  rules?: IngressRule[];\n  tls?: IngressTLS[];\n}\n\nexport interface IngressRule {\n  host?: string;\n  http: HTTPIngressRuleValue;\n}\n\nexport interface HTTPIngressRuleValue {\n  paths: HTTPIngressPath[];\n}\n\nexport interface HTTPIngressPath {\n  path: string;\n  pathType: 'Prefix' | 'Exact' | 'ImplementationSpecific';\n  backend: IngressBackend;\n}\n\nexport interface IngressBackend {\n  serviceName?: string;\n  servicePort?: number;\n  service?: {\n    name: string;\n    port: {\n      number: number;\n    };\n  };\n}\n\nexport interface IngressTLS {\n  hosts?: string[];\n  secretName?: string;\n  global?: boolean;\n  certificate?: Certificate;\n}\n\nexport interface IngressStatus {\n  loadBalancer?: IngressLoadBalancerStatus;\n}\n\nexport interface IngressLoadBalancerStatus {\n  ingress?: LoadBalancerIngress[];\n}\n\nexport interface LoadBalancerIngress {\n  ip: string;\n  hostname: string;\n}\n\nexport const VolumeMode = {\n  FILE_SYSTEM: 'Filesystem',\n  BLOCK_DEVICE: 'Block',\n} as const;\n\nexport type VolumeMode = ValueOf<typeof VolumeMode>;\n\nexport const VolumeModes = [VolumeMode.BLOCK_DEVICE, VolumeMode.FILE_SYSTEM];\n\nexport const AccessMode = {\n  RWO: 'ReadWriteOnce',\n  ROX: 'ReadOnlyMany',\n  RWX: 'ReadWriteMany',\n  RWOP: 'ReadWriteOncePod',\n} as const;\n\nexport type AccessMode = ValueOf<typeof AccessMode>;\n\nexport const AccessModes = [AccessMode.RWO, AccessMode.ROX, AccessMode.RWX];\n\nexport interface PersistentVolumeClaim extends KubernetesResource {\n  spec: PersistentVolumeClaimSpec;\n  status?: PersistentVolumeClaimStatus;\n}\n\nexport interface PersistentVolumeClaimStatus {\n  phase: string;\n  capacity?: { storage: string };\n}\n\nexport interface PersistentVolumeClaimSpec {\n  // null 表示使用默认 sc\n  // \"\" 表示不设置存储类\n  storageClassName?: string;\n  volumeName?: string;\n  resources: {\n    requests: { storage: string };\n  };\n  dataSource?: PersistentVolumeClaimDataSource;\n  selector?: LabelSelector;\n  accessModes: AccessMode[];\n  volumeMode?: VolumeMode;\n}\n\nexport interface PersistentVolumeClaimDataSource {\n  name: string;\n  kind: string;\n  apiGroup: string;\n}\n\nexport interface APIResourceItem {\n  name: string;\n  singularName: string;\n  namespaced: boolean;\n  kind: string;\n  verbs: K8sResourceAction[];\n  groupVersion?: string[];\n}\n\nexport interface APIResourceList extends KubernetesResource {\n  kind: 'APIResourceList';\n  apiVersion?: string;\n  groupVersion: string;\n  resources: APIResourceItem[];\n}\n\nexport interface ResourceAttributes<T extends K8sResourceAction> {\n  group: string;\n  resource: string;\n  verb: T;\n  namespace?: string;\n  name?: string;\n}\n\nexport interface SubjectAccessReviewSpec<T extends K8sResourceAction> {\n  resourceAttributes: ResourceAttributes<T>;\n}\n\nexport interface SubjectAccessReviewStatus {\n  allowed: boolean;\n  denied?: boolean;\n  evaluationError?: string;\n  reason?: string;\n}\n\nexport interface SubjectAccessReview<\n  T extends K8sResourceAction = K8sResourceAction,\n> extends KubernetesResource {\n  kind: 'SubjectAccessReview';\n  spec: SubjectAccessReviewSpec<T>;\n  status: SubjectAccessReviewStatus;\n}\n\nexport interface SelfResourceAttributes<T extends K8sResourceAction>\n  extends ResourceAttributes<T> {\n  project?: string;\n  cluster?: string;\n}\n\nexport interface SelfSubjectAccessReviewSpec<T extends K8sResourceAction>\n  extends SubjectAccessReviewSpec<T> {\n  resourceAttributes: SelfResourceAttributes<T>;\n}\n\nexport interface SelfSubjectAccessReview<\n  T extends K8sResourceAction = K8sResourceAction,\n> extends KubernetesResource {\n  kind: 'SelfSubjectAccessReview';\n  spec: SelfSubjectAccessReviewSpec<T>;\n  status: SubjectAccessReviewStatus;\n}\n\nexport enum DependencyType {\n  Any = 'any',\n  All = 'all',\n}\n\nexport enum FeatureStage {\n  Alpha = 'Alpha',\n  Beta = 'Beta',\n  GA = 'GA',\n  EOF = 'EOF',\n}\n\nexport interface FeatureGate extends KubernetesResource {\n  spec: {\n    dependency: {\n      type: DependencyType;\n      featureGates: string[];\n    };\n    description: string;\n    enabled: boolean;\n    stage: FeatureStage;\n  };\n  status: {\n    enabled: boolean;\n  };\n}\n\nexport interface FeatureGateEnterpriseSupport extends KubernetesResource {\n  spec: FeatureGateEnterpriseSupportSpec;\n  status: FeatureGateEnterpriseSupportStatus;\n}\n\nexport interface FeatureGateEnterpriseSupportSpec {\n  products: Array<{ name: string }>;\n  validity: {\n    notBefore: string;\n    notAfter: string;\n  };\n  type: string;\n  name: string;\n  version: string;\n  licenseKind: string;\n  baremetalClusterCPUCoreLimit: number;\n  importedClusterNodeLimit: number;\n  allowProductVersion: string;\n}\n\nexport interface FeatureGateEnterpriseSupportStatus {\n  phase: EnterpriseSupportStatusType;\n  reason: EnterpriseSupportStatusReason[];\n  baremetalClusterCPUCoreNum: number;\n  importedClusterNodeNum: number;\n  currentProductVersion: string;\n  licenseExempt?: boolean;\n}\n\nexport enum EnterpriseSupportStatusType {\n  inService = 'InService',\n  outOfService = 'OutOfService',\n  warning = 'Warning',\n}\n\nexport enum EnterpriseSupportStatusReason {\n  ExceedResourceLimit = 'ExceedResourceLimit',\n  ExceedNodeLimit = 'ExceedNodeLimit',\n  MismatchProductVersion = 'MismatchProductVersion',\n  MismatchSubProducts = 'MismatchSubProducts',\n  NotExist = 'NotExist',\n  Expired = 'Expired',\n  Pending = 'Pending',\n  ExpiringSoon = 'ExpiringSoon',\n}\n\nexport enum SecurityPolicyRuleName {\n  password = 'PasswordPolicy',\n  lock = 'UserLockedPolicy',\n  disable = 'UserDisabledPolicy',\n  notification = 'NotificationPolicy',\n  access = 'AccessControlPolicy',\n}\n\nexport interface SecurityPolicyRule {\n  name: SecurityPolicyRuleName;\n  items: Array<{\n    enable: boolean;\n    key: string;\n    value: string;\n  }>;\n}\n\nexport interface SecurityPolicyResource extends KubernetesResource {\n  rules: SecurityPolicyRule[];\n}\n\nexport interface Status {\n  kind: 'Status';\n  apiVersion: string;\n  metadata: {\n    continue?: string;\n  };\n  status: string;\n  message: string;\n  reason: string;\n  code: number;\n  details?: {\n    group?: string;\n    kind: string;\n    name: string;\n    uid: string;\n    causes: Array<{\n      message?: string;\n      reason?: string;\n      field?: string;\n    }>;\n  };\n}\n\nexport interface LocalObjectReference {\n  name: string;\n}\n\nexport interface ConfigMapKeyRef extends LocalObjectReference {\n  key: string;\n  optional?: boolean;\n}\n\nexport interface SecretKeyRef extends LocalObjectReference {\n  key: string;\n  optional?: boolean;\n}\n\nexport interface ConfigMapRef extends LocalObjectReference {\n  optional?: boolean;\n}\n\nexport interface SecretRef extends LocalObjectReference {\n  optional?: boolean;\n}\n\nexport interface ObjectFieldSelector {\n  apiVersion?: string;\n  fieldPath: string;\n}\nexport interface ResourceFieldSelector {\n  containerName?: string;\n  divisor?: string;\n  resource: string;\n}\n\n/**\n * Workload API\n */\nexport interface Deployment extends KubernetesResource {\n  name?: string;\n  spec?: DeploymentSpec;\n  status?: DeploymentStatus;\n  generation?: number;\n}\n\n// DeploymentSpec is the specification of the desired behavior of the Deployment.\nexport interface DeploymentSpec {\n  replicas?: number;\n  selector?: LabelSelector;\n  template?: PodTemplateSpec;\n  strategy?: DeploymentStrategy;\n  minReadySeconds?: number;\n  revisionHistoryLimit?: number;\n}\n\nexport interface Pod extends KubernetesResource {\n  spec?: PodSpec;\n  status?: PodStatus;\n}\n\nexport interface PodStatus {\n  conditions?: Condition[];\n  containerStatuses?: ContainerStatus[];\n  hostIP?: string;\n  initContainerStatuses?: ContainerStatus[];\n  ephemeralContainerStatuses?: ContainerStatus[];\n  message?: string;\n  nominatedNodeName?: string;\n  phase?: string;\n  podIP?: string;\n  podIPs?: Array<{ ip: string }>;\n  qosClass?: string;\n  reason?: string;\n  startTime?: string;\n}\n\nexport interface HostAliases {\n  ip: string;\n  hostnames: string[];\n}\n\nexport interface ContainerStatus {\n  containerID?: string;\n  image?: string;\n  imageID?: string;\n  lastState?: ContainerState;\n  name?: string;\n  ready?: boolean;\n  restartCount?: number;\n  state?: ContainerState;\n  started?: boolean;\n}\n\nexport interface ContainerState {\n  running?: ContainerStateRunning;\n  terminated?: ContainerStateTerminated;\n  waiting?: ContainerStateWaiting;\n}\n\nexport interface ContainerStateRunning {\n  startedAt?: string;\n}\n\nexport interface ContainerStateTerminated {\n  containerID?: string;\n  exitCode?: number;\n  finishedAt?: string;\n  message?: string;\n  reason?: string;\n  signal?: number;\n  startedAt?: string;\n}\n\nexport interface ContainerStateWaiting {\n  message?: string;\n  reason?: string;\n}\n\nexport interface DeploymentStatus {\n  availableReplicas?: number;\n  collisionCount?: number;\n  observedGeneration?: number;\n  readyReplicas?: number;\n  replicas?: number;\n  unavailableReplicas?: number;\n  updatedReplicas?: number;\n  conditions?: Condition[];\n}\n\nexport interface RequiredAffinity {\n  topologyKey: string;\n  labelSelector: LabelSelector;\n}\n\nexport interface PreferredAffinity {\n  weight: number;\n  podAffinityTerm: {\n    labelSelector?: LabelSelector;\n    topologyKey: string;\n  };\n}\n\nexport interface PodAffinity {\n  requiredDuringSchedulingIgnoredDuringExecution?: RequiredAffinity[];\n  preferredDuringSchedulingIgnoredDuringExecution?: PreferredAffinity[];\n}\n\nexport interface PodSpecAffinity {\n  podAffinity?: Affinity;\n  podAntiAffinity?: Affinity;\n  nodeAffinity?: Affinity;\n}\n\nexport interface Affinity {\n  requiredDuringSchedulingIgnoredDuringExecution?:\n    | PodAffinityTerm[]\n    | NodeAffinityTerm;\n  preferredDuringSchedulingIgnoredDuringExecution?: WeightedPodAffinityTerm[];\n}\n\nexport interface WeightedNodeAffinityTerm {\n  weight: number;\n  preference: NodeSelectorTerm;\n}\n\nexport interface NodeAffinity {\n  requiredDuringSchedulingIgnoredDuringExecution?: NodeAffinityTerm;\n  preferredDuringSchedulingIgnoredDuringExecution?: WeightedNodeAffinityTerm[];\n}\n\nexport interface WeightedPodAffinityTerm {\n  podAffinityTerm: PodAffinityTerm;\n  weight: number;\n}\n\nexport interface PodAffinityTerm {\n  labelSelector?: LabelSelector;\n  topologyKey: string;\n  namespaces?: string[];\n}\n\nexport interface NodeAffinityTerm {\n  nodeSelectorTerms: NodeSelectorTerm[];\n}\n\nexport interface NodeSelectorTerm {\n  matchExpressions: LabelSelectorRequirement[];\n}\n\nexport enum VolumeTypeEnum {\n  persistentVolumeClaim = 'persistentVolumeClaim',\n  configMap = 'configMap',\n  secret = 'secret',\n  ephemeral = 'ephemeral',\n  emptyDir = 'emptyDir',\n  hostPath = 'hostPath',\n}\n\nexport interface Volume {\n  name: string;\n  [VolumeTypeEnum.emptyDir]?: EmptyDirVolumeSource;\n  [VolumeTypeEnum.configMap]?: ConfigMapVolumeSource;\n  [VolumeTypeEnum.secret]?: SecretVolumeSource;\n  [VolumeTypeEnum.persistentVolumeClaim]?: PersistentVolumeClaimVolumeSource;\n  [VolumeTypeEnum.hostPath]?: HostPathVolumeSource;\n  [VolumeTypeEnum.ephemeral]?: EphemeralVolumeSource;\n  // other iaas storage definitions not included\n  isAppResource?: boolean; // 是否OAM应用资源\n  mountPath?: string; // for oam component webservice component. 未来可能单独定义\n}\n\nexport interface CsiVolumeSource {\n  driver: 'objectstorage.k8s.io';\n  volumeAttributes: {\n    'bar-name': string;\n    'bar-namespace': string;\n    bucketRequestName: string;\n  };\n}\n\nexport interface KeyToPath {\n  key?: string;\n  mode?: number;\n  path?: string;\n}\n\nexport interface EmptyDirVolumeSource {\n  medium?: string;\n  sizeLimit?: string; // eg: 1500m refers to: https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.15/#quantity-resource-core\n}\n\nexport interface ConfigMapVolumeSource {\n  name: string;\n  optional?: boolean;\n  items?: KeyToPath[];\n}\n\nexport interface SecretVolumeSource {\n  secretName: string;\n  optional?: boolean;\n  items?: KeyToPath[];\n}\n\nexport interface HostPathVolumeSource {\n  type?: string;\n  path: string;\n}\n\nexport interface PersistentVolumeClaimVolumeSource {\n  claimName: string;\n  readOnly?: boolean;\n}\n\nexport interface EphemeralVolumeSource {\n  volumeClaimTemplate: PersistentVolumeClaim;\n}\n\nexport interface Probe {\n  exec?: ExecAction;\n  failureThreshold?: number;\n  httpGet?: HTTPGetAction;\n  initialDelaySeconds?: number;\n  periodSeconds?: number;\n  successThreshold?: number;\n  tcpSocket?: TCPSocketAction;\n  timeoutSeconds?: number;\n}\n\nexport interface ExecAction {\n  command?: string[];\n}\n\nexport interface HTTPHeader {\n  name?: string;\n  value?: string;\n}\n\nexport interface TCPSocketAction {\n  host?: string;\n  port?: number | string;\n}\n\nexport interface VolumeMount {\n  name: string;\n  mountPath?: string;\n  readOnly?: boolean;\n  subPath?: string;\n  mountPropagation?: string;\n}\n\nexport interface ResourceRequirements {\n  limits?: StringMap;\n  requests?: StringMap;\n}\n\nexport interface ContainerPort {\n  name?: string;\n  hostPort?: number;\n  containerPort?: number;\n  servicePort?: number;\n  protocol?: 'TCP' | 'UDP';\n  hostIP?: string;\n}\n\nexport interface Certificate {\n  name: string;\n  namespace: string;\n  notBefore: string;\n  notAfter: string;\n  dnsNames: string[];\n  valid: boolean;\n  reasonCode?:\n    | 1 // 证书格式有误\n    | 2 // 证书不在有效期内\n    | 3; // 证书信息未知\n}\n\nexport const AlbProtocolMapper = {\n  http: 'HTTP',\n  https: 'HTTPS',\n  grpc: 'gRPC',\n  tcp: 'TCP',\n  udp: 'UDP',\n} as const;\n\nexport type AlbProtocol = keyof typeof AlbProtocolMapper;\n\nexport interface FrontendSpec {\n  port?: number | '';\n  protocol?: AlbProtocol;\n  source?: {\n    name: string;\n    namespace: string;\n    type: string;\n  };\n  backendProtocol?: 'HTTP' | 'HTTPS' | 'gRPC';\n  serviceGroup?: ServiceGroup;\n  certificate_name?: string;\n}\n\nexport interface RuleService {\n  name: string;\n  namespace: string;\n  port: number;\n  weight: number;\n}\n\nexport interface ServiceGroup {\n  services: RuleService[];\n  session_affinity_policy?: string;\n  session_affinity_attribute?: string;\n}\n\nexport interface RollingUpdateDaemonSet {\n  maxUnavailable?: string | number;\n}\n\nexport interface DaemonSetUpdateStrategy {\n  type?: DaemonSetUpdateStrategyType;\n  rollingUpdate?: RollingUpdateDaemonSet;\n}\n\nexport interface DaemonSet extends KubernetesResource {\n  spec?: DaemonSetSpec;\n  status?: DaemonSetStatus;\n}\n\nexport interface DaemonSetSpec {\n  selector?: LabelSelector;\n  template?: PodTemplateSpec;\n  updateStrategy?: DaemonSetUpdateStrategy;\n  minReadySeconds?: number;\n  revisionHistoryLimit?: number;\n}\n\nexport type DaemonSetStatus = Partial<{\n  currentNumberScheduled: number;\n  numberMisscheduled: number;\n  desiredNumberScheduled: number;\n  numberReady: number;\n  observedGeneration: number;\n  updatedNumberScheduled: number;\n  numberUnavailable: number;\n  numberAvailable: number;\n}>;\n\nexport interface ConfigMap<T = StringMap> extends KubernetesResource {\n  data?: T;\n  binaryData?: StringMap;\n}\n\n// https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.11/#cronjobspec-v1beta1-batch\nexport interface CronJobSpec {\n  concurrencyPolicy?: string;\n  failedJobsHistoryLimit?: number | '';\n  schedule?: string;\n  startingDeadlineSeconds?: number | '';\n  successfulJobsHistoryLimit?: number | '';\n  suspend?: boolean;\n  timeZone?: string;\n  jobTemplate?: JobTemplateSpec;\n}\n\nexport interface Job extends KubernetesResource {\n  spec?: JobSpec;\n  status?: JobStatus;\n}\n\nexport interface JobSpec {\n  activeDeadlineSeconds?: number | '';\n  backoffLimit?: number | '';\n  completions?: number | '';\n  manualSelector?: boolean;\n  parallelism?: number | '';\n  selector?: LabelSelector;\n  template?: PodTemplateSpec;\n  startingDeadlineSeconds?: number | '';\n}\n\n// https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.11/#jobtemplatespec-v1beta1-batch\nexport interface JobTemplateSpec {\n  metadata?: ObjectMeta;\n  spec?: JobSpec;\n}\n\nexport interface JobStatus {\n  active: number | '';\n  completionTime: string;\n  conditions: Condition[];\n  startTime: string;\n  succeeded: number;\n  failed: number;\n}\n\nexport interface CronJobStatus {\n  active?: ObjectReference[];\n  lastScheduleTime: string;\n}\n\nexport interface CronJob extends KubernetesResource {\n  spec?: CronJobSpec;\n  status?: CronJobStatus;\n}\n\nexport type NodeStatusReason =\n  | 'KubeletHasSufficientDisk'\n  | 'KubeletHasSufficientMemory'\n  | 'KubeletHasNoDiskPressure'\n  | 'KubeletReady';\n\nexport type NodeStatusType =\n  | 'OutOfDisk'\n  | 'MemoryPressure'\n  | 'DiskPressure'\n  | 'Ready';\n\nexport interface NodeTaint {\n  key: string;\n  timeAdded?: string;\n  effect: TaintEffect;\n  value?: string;\n  unschedulable?: boolean;\n}\n\nexport interface Node extends KubernetesResource {\n  spec?: {\n    providerID?: string;\n    taints?: NodeTaint[];\n    configSource?: string;\n    unschedulable?: boolean;\n    podCIDR?: string;\n    podCIDRs?: string[];\n    externalID?: string;\n    ip?: string;\n  };\n  status?: NodeStatus;\n}\n\nexport interface NodeStatus {\n  volumesAttached: boolean;\n  daemonEndpoints: {\n    kubeletEndpoint: {\n      port: number;\n    };\n  };\n  capacity: Record<string, string>;\n  addresses: Array<{\n    type: string;\n    address: string;\n  }>;\n  allocatable: {\n    'alpha.kubernetes.io/nvidia-gpu': string;\n    'tencent.com/vcuda-core': string;\n    'tencent.com/vcuda-memory': string;\n    pods: string;\n    cpu: string;\n    memory: string;\n  };\n  images: Array<{\n    sizeBytes: number;\n    names: string[];\n  }>;\n  nodeInfo: {\n    kubeProxyVersion: string;\n    operatingSystem: string;\n    kernelVersion: string;\n    systemUUID: string;\n    containerRuntimeVersion: string;\n    osImage: string;\n    architecture: string;\n    bootID: string;\n    machineID: string;\n    kubeletVersion: string;\n  };\n  volumesInUse: boolean;\n  phase: string;\n  conditions: Condition[];\n}\n\nexport interface Service extends KubernetesResource {\n  kind: 'Service';\n  spec?: ServiceSpec;\n  status?: {\n    loadBalancer?: {\n      ingress?: Array<{\n        hostname?: string;\n        ip?: string;\n      }>;\n    };\n  };\n}\n\nexport const SERVICE_TYPES = [\n  'ClusterIP',\n  'NodePort',\n  'LoadBalancer',\n  'ExternalName',\n] as const;\nexport const SERVICE_SESSION_AFFINITIES = ['None', 'ClientIP'] as const;\n\nexport type ServiceType = (typeof SERVICE_TYPES)[number];\n\nexport type ServiceSessionAffinity =\n  (typeof SERVICE_SESSION_AFFINITIES)[number];\n\nexport interface ServiceSpec {\n  clusterIP?: string;\n  clusterIPs?: string[];\n  externalIPs?: string[];\n  externalName?: string;\n  ipFamilies?: ['IPv4'] | ['IPv6'] | ['IPv4', 'IPv6'] | ['IPv6', 'IPv4'];\n  ipFamilyPolicy?: 'SingleStack' | 'PreferDualStack' | 'RequireDualStack';\n  ports?: ServicePort[];\n  selector?: StringMap;\n  type?: ServiceType;\n  sessionAffinity?: ServiceSessionAffinity;\n}\n\nexport const SERVICE_PORT_BASE_PROTOCOLS = ['TCP', 'UDP'] as const;\nexport type ServicePortBaseProtocol =\n  (typeof SERVICE_PORT_BASE_PROTOCOLS)[number];\n\nexport const SERVICE_PORT_PROTOCOLS = [\n  'TCP',\n  'UDP',\n  'HTTP',\n  'HTTPS',\n  'HTTP2',\n  'gRPC',\n] as const;\nexport type ServicePortProtocol = (typeof SERVICE_PORT_PROTOCOLS)[number];\n\nexport interface ServicePort {\n  name?: string;\n  nodePort?: number;\n  port?: number;\n  protocol?: ServicePortBaseProtocol;\n  appProtocol?: Lowercase<ServicePortProtocol>;\n  targetPort?: number | string;\n}\n\nexport interface CustomResourceDefinitionVersion {\n  name: string;\n  served: boolean;\n  storage: boolean;\n  schema?: {\n    openAPIV3Schema: OpenAPIV3SchemaObject;\n  };\n}\n\nexport interface CustomResourceDefinition extends KubernetesResource {\n  kind: 'CustomResourceDefinition';\n  spec: {\n    group: string;\n    version: string;\n    names: {\n      plural: string;\n      singular: string;\n      kind: string;\n      listKind: string;\n    };\n    scope: string;\n    validation: {\n      openAPIV3Schema: OpenAPIV3SchemaObject;\n    };\n    versions: CustomResourceDefinitionVersion[];\n    preserveUnknownFields: boolean;\n  };\n}\n\nexport interface NameSpaceResourceRatio extends KubernetesResource {\n  spec: {\n    cpu: number;\n    memory: number;\n  };\n  status: {\n    clusterCPU: number;\n    clusterMemory: number;\n  };\n}\n\n// https://github.com/kubernetes/kubernetes/blob/5a99930ab57b2c7837960b21d2c92e958db8c377/pkg/apis/core/types.go#L5575\nexport interface K8sEventSeries {\n  count: number;\n  lastObservedTime: string;\n}\n\nexport interface K8sEventSource {\n  component?: string;\n  host?: string;\n}\n\nexport interface K8sEvent extends KubernetesResource {\n  involvedObject?: ObjectReference;\n  reason?: string;\n  message?: string;\n  source?: K8sEventSource;\n  firstTimestamp?: string;\n  lastTimestamp?: string;\n  count?: number;\n  type?: string;\n  eventTime?: string;\n  series?: K8sEventSeries;\n  action?: string;\n  related?: ObjectReference;\n  reportingController?: string;\n  reportingInstance?: string;\n}\n\nexport interface ResourcePatch extends KubernetesResource {\n  spec?: {\n    jsonPatch: Array<{\n      op: string;\n      path: string;\n      value: string;\n    }>;\n    target?: {\n      apiVersion: string;\n      kind: string;\n      name: string;\n      namespace: string;\n    };\n    release: string;\n  };\n}\n"]}
|
|
126
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"raw.js","sourceRoot":"","sources":["../../../../../../../libs/common/src/core/types/k8s/raw.ts"],"names":[],"mappings":"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","sourcesContent":["// TypeMeta describes an individual object in an API response or request\n// with strings representing the type of the object and its API schema version.\n// Structures that are versioned or persisted should inline TypeMeta.\n\n/**\n * 此文件只维护 所有的 k8s 原生类型\n */\n\nimport { StringMap } from '../commons';\nimport { ValueOf } from '../helpers';\nimport { OpenAPIV3SchemaObject } from '../schema';\n\nimport {\n  KubernetesResource,\n  LabelSelector,\n  LabelSelectorRequirement,\n  ObjectMeta,\n  ObjectReference,\n  Condition,\n} from './core';\n\nexport interface Secret<T = StringMap> extends KubernetesResource {\n  data?: T;\n  stringData?: StringMap;\n  type?: SecretType;\n  // ! hack, not spec\n  global?: boolean;\n  certificate?: Certificate;\n}\n\nexport interface Namespace extends KubernetesResource {\n  status?: NamespaceStatus;\n}\n\nexport interface NamespaceStatus {\n  phase?: string;\n}\n\nexport interface ScopedResourceSelectorRequirement {\n  operator: 'In' | 'NotIn' | 'Exists' | 'DoesNotExist';\n  scopeName: string;\n  values: string;\n}\n\nexport interface ScopeSelector {\n  matchExpressions: ScopedResourceSelectorRequirement[];\n}\n\nexport enum K8sResourceAction {\n  GET = 'get',\n  LIST = 'list',\n  WATCH = 'watch',\n  CREATE = 'create',\n  UPDATE = 'update',\n  PATCH = 'patch',\n  DELETE = 'delete',\n  DELETE_COLLECTION = 'deletecollection',\n  PROXY = 'proxy',\n  REDIRECT = 'redirect',\n  ALL = '*',\n}\n\nexport enum SecretType {\n  Opaque = 'Opaque',\n  TLS = 'kubernetes.io/tls',\n  SSHKey = 'kubernetes.io/ssh-public-key',\n  SSHAuth = 'kubernetes.io/ssh-auth',\n  BasicAuth = 'kubernetes.io/basic-auth',\n  BasicAuthSecret = 'kubernetes.io/basic-auth-secret',\n  Database = 'kubernetes.io/database',\n  DKConfigJson = 'kubernetes.io/dockerconfigjson',\n  OAuth2 = 'katanomi.dev/oauth2',\n  NoAuth = 'kubernetes.io/no-auth',\n  DevOpsOAuth2 = 'devops.alauda.io/oauth2',\n  DynamicSecretKey = 'katanomi.dev/dynamic',\n  CloudCredential = 'CloudCredential',\n}\n\nexport interface StatefulSet extends KubernetesResource {\n  spec?: StatefulSetSpec;\n  status?: StatefulSetStatus;\n}\n\nexport interface StatefulSetSpec {\n  replicas?: number;\n  selector?: LabelSelector;\n  template?: PodTemplateSpec;\n\n  // serviceName is the name of the service that governs this StatefulSet.\n  // This service must exist before the StatefulSet, and is responsible for\n  // the network identity of the set. Pods get DNS/hostnames that follow the\n  // pattern: pod-specific-string.serviceName.default.svc.cluster.local\n  // where \"pod-specific-string\" is managed by the StatefulSet controller.\n  serviceName?: string;\n  updateStrategy?: StatefulSetUpdateStrategy;\n  revisionHistoryLimit?: number;\n  volumeClaimTemplates?: PersistentVolumeClaim[];\n}\n\nexport interface PodTemplateSpec extends KubernetesResource {\n  spec?: PodSpec;\n}\n\nexport interface PodSpec {\n  containers?: Container[];\n  initContainers?: Container[];\n  ephemeralContainers?: EphemeralContainer[];\n  volumes?: Volume[];\n  hostAliases?: HostAliases[];\n  nodeSelector?: StringMap;\n  hostNetwork?: boolean;\n  affinity?: Affinity;\n  restartPolicy?: string;\n  imagePullSecrets?: LocalObjectReference[];\n  serviceAccountName?: string;\n  serviceAccount?: string;\n  nodeName?: string;\n  terminationGracePeriodSeconds?: number;\n  tolerations?: Toleration[];\n}\n\nexport interface Toleration {\n  key?: string;\n  value?: string;\n  operator?: TolerationOperator;\n  tolerationSeconds?: number;\n  effect?: TaintEffect;\n}\n\nexport enum TolerationOperator {\n  Exists = 'Exists',\n  Equal = 'Equal',\n}\n\nexport enum TaintEffect {\n  NoSchedule = 'NoSchedule',\n  PreferNoSchedule = 'PreferNoSchedule',\n  NoExecute = 'NoExecute',\n}\n\nexport interface Container {\n  name?: string;\n  image?: string;\n  command?: string[];\n  args?: string[];\n  env?: EnvVar[];\n  envFrom?: EnvFromSource[];\n  workingDir?: string;\n  ports?: ContainerPort[];\n  resources?: ResourceRequirements;\n  volumeMounts?: VolumeMount[];\n  livenessProbe?: Probe;\n  readinessProbe?: Probe;\n  lifecycle?: PodLifeCycle;\n  restartPolicy?: string;\n}\n\nexport interface EnvVarSource {\n  configMapKeyRef?: ConfigMapKeyRef;\n  secretKeyRef?: SecretKeyRef;\n  fieldRef?: ObjectFieldSelector;\n  resourceFieldRef?: ResourceFieldSelector;\n}\n\nexport interface EnvVar {\n  name: string;\n  value?: string;\n  valueFrom?: EnvVarSource;\n}\n\nexport interface EnvFromSource {\n  prefix?: string;\n  configMapRef?: ConfigMapRef;\n  secretRef?: SecretRef;\n}\n\nexport interface PodLifeCycle {\n  postStart?: PodLifeCycleHook;\n  preStop?: PodLifeCycleHook;\n}\n\nexport interface PodLifeCycleHook {\n  exec: { command: string[] };\n}\n\nexport interface HTTPGetAction {\n  host?: string;\n  httpHeaders?: HTTPHeader[];\n  path: string;\n  port?: number | string;\n  scheme?: string;\n}\n\nexport interface EphemeralContainer {\n  command: string[];\n  image: string;\n  imagePullPolicy: string;\n  name: string;\n  stdin: boolean;\n  tty: boolean;\n  terminationMessagePolicy?: string;\n  [key: string]: unknown;\n}\n\nexport type StatefulSetStatus = Partial<{\n  collisionCount: number;\n  observedGeneration: number;\n  replicas: number;\n  readyReplicas: number;\n  currentReplicas: number;\n  currentRevision: string;\n  updateRevision: string;\n  updatedReplicas?: number;\n}>;\n\nexport type DeploymentStrategyType = 'RollingUpdate' | 'Recreate';\nexport type DaemonSetUpdateStrategyType = 'RollingUpdate' | 'OnDelete';\nexport type StatefulSetUpdateStrategyType = 'RollingUpdate' | 'OnDelete';\n\nexport interface DeploymentStrategy {\n  type?: DeploymentStrategyType;\n  rollingUpdate?: RollingUpdateDeployment;\n}\n\nexport interface RollingUpdateDeployment {\n  maxUnavailable?: string | number;\n  maxSurge?: string | number;\n}\n\nexport interface StatefulSetUpdateStrategy {\n  type?: StatefulSetUpdateStrategyType;\n  rollingUpdate?: RollingUpdateStatefulSetStrategy;\n}\n\nexport interface RollingUpdateStatefulSetStrategy {\n  partition?: string | number;\n}\n\nexport interface Ingress extends KubernetesResource {\n  spec?: IngressSpec;\n}\n\nexport interface IngressSpec {\n  ingressClassName?: string;\n  rules?: IngressRule[];\n  tls?: IngressTLS[];\n}\n\nexport interface IngressRule {\n  host?: string;\n  http: HTTPIngressRuleValue;\n}\n\nexport interface HTTPIngressRuleValue {\n  paths: HTTPIngressPath[];\n}\n\nexport interface HTTPIngressPath {\n  path: string;\n  pathType: 'Prefix' | 'Exact' | 'ImplementationSpecific';\n  backend: IngressBackend;\n}\n\nexport interface IngressBackend {\n  serviceName?: string;\n  servicePort?: number;\n  service?: {\n    name: string;\n    port: {\n      number: number;\n    };\n  };\n}\n\nexport interface IngressTLS {\n  hosts?: string[];\n  secretName?: string;\n  global?: boolean;\n  certificate?: Certificate;\n}\n\nexport interface IngressStatus {\n  loadBalancer?: IngressLoadBalancerStatus;\n}\n\nexport interface IngressLoadBalancerStatus {\n  ingress?: LoadBalancerIngress[];\n}\n\nexport interface LoadBalancerIngress {\n  ip: string;\n  hostname: string;\n}\n\nexport const VolumeMode = {\n  FILE_SYSTEM: 'Filesystem',\n  BLOCK_DEVICE: 'Block',\n} as const;\n\nexport type VolumeMode = ValueOf<typeof VolumeMode>;\n\nexport const VolumeModes = [VolumeMode.BLOCK_DEVICE, VolumeMode.FILE_SYSTEM];\n\nexport const AccessMode = {\n  RWO: 'ReadWriteOnce',\n  ROX: 'ReadOnlyMany',\n  RWX: 'ReadWriteMany',\n  RWOP: 'ReadWriteOncePod',\n} as const;\n\nexport type AccessMode = ValueOf<typeof AccessMode>;\n\nexport const AccessModes = [AccessMode.RWO, AccessMode.ROX, AccessMode.RWX];\n\nexport interface PersistentVolumeClaim extends KubernetesResource {\n  spec: PersistentVolumeClaimSpec;\n  status?: PersistentVolumeClaimStatus;\n}\n\nexport interface PersistentVolumeClaimStatus {\n  phase: string;\n  capacity?: { storage: string };\n}\n\nexport interface PersistentVolumeClaimSpec {\n  // null 表示使用默认 sc\n  // \"\" 表示不设置存储类\n  storageClassName?: string;\n  volumeName?: string;\n  resources: {\n    requests: { storage: string };\n  };\n  dataSource?: PersistentVolumeClaimDataSource;\n  selector?: LabelSelector;\n  accessModes: AccessMode[];\n  volumeMode?: VolumeMode;\n}\n\nexport interface PersistentVolumeClaimDataSource {\n  name: string;\n  kind: string;\n  apiGroup: string;\n}\n\nexport interface APIResourceItem {\n  name: string;\n  singularName: string;\n  namespaced: boolean;\n  kind: string;\n  verbs: K8sResourceAction[];\n  groupVersion?: string[];\n}\n\nexport interface APIResourceList extends KubernetesResource {\n  kind: 'APIResourceList';\n  apiVersion?: string;\n  groupVersion: string;\n  resources: APIResourceItem[];\n}\n\nexport interface ResourceAttributes<T extends K8sResourceAction> {\n  group: string;\n  resource: string;\n  verb: T;\n  namespace?: string;\n  name?: string;\n}\n\nexport interface SubjectAccessReviewSpec<T extends K8sResourceAction> {\n  resourceAttributes: ResourceAttributes<T>;\n}\n\nexport interface SubjectAccessReviewStatus {\n  allowed: boolean;\n  denied?: boolean;\n  evaluationError?: string;\n  reason?: string;\n}\n\nexport interface SubjectAccessReview<\n  T extends K8sResourceAction = K8sResourceAction,\n> extends KubernetesResource {\n  kind: 'SubjectAccessReview';\n  spec: SubjectAccessReviewSpec<T>;\n  status: SubjectAccessReviewStatus;\n}\n\nexport interface SelfResourceAttributes<T extends K8sResourceAction>\n  extends ResourceAttributes<T> {\n  project?: string;\n  cluster?: string;\n}\n\nexport interface SelfSubjectAccessReviewSpec<T extends K8sResourceAction>\n  extends SubjectAccessReviewSpec<T> {\n  resourceAttributes: SelfResourceAttributes<T>;\n}\n\nexport interface SelfSubjectAccessReview<\n  T extends K8sResourceAction = K8sResourceAction,\n> extends KubernetesResource {\n  kind: 'SelfSubjectAccessReview';\n  spec: SelfSubjectAccessReviewSpec<T>;\n  status: SubjectAccessReviewStatus;\n}\n\nexport enum DependencyType {\n  Any = 'any',\n  All = 'all',\n}\n\nexport enum FeatureStage {\n  Alpha = 'Alpha',\n  Beta = 'Beta',\n  GA = 'GA',\n  EOF = 'EOF',\n}\n\nexport interface FeatureGate extends KubernetesResource {\n  spec: {\n    dependency: {\n      type: DependencyType;\n      featureGates: string[];\n    };\n    description: string;\n    enabled: boolean;\n    stage: FeatureStage;\n  };\n  status: {\n    enabled: boolean;\n  };\n}\n\nexport interface FeatureGateEnterpriseSupport extends KubernetesResource {\n  spec: FeatureGateEnterpriseSupportSpec;\n  status: FeatureGateEnterpriseSupportStatus;\n}\n\nexport interface FeatureGateEnterpriseSupportSpec {\n  products: Array<{ name: string }>;\n  validity: {\n    notBefore: string;\n    notAfter: string;\n  };\n  type: string;\n  name: string;\n  version: string;\n  licenseKind: string;\n  baremetalClusterCPUCoreLimit: number;\n  importedClusterNodeLimit: number;\n  allowProductVersion: string;\n}\n\nexport interface FeatureGateEnterpriseSupportStatus {\n  phase: EnterpriseSupportStatusType;\n  reason: EnterpriseSupportStatusReason[];\n  baremetalClusterCPUCoreNum: number;\n  importedClusterNodeNum: number;\n  currentProductVersion: string;\n  licenseExempt?: boolean;\n}\n\nexport enum EnterpriseSupportStatusType {\n  inService = 'InService',\n  outOfService = 'OutOfService',\n  warning = 'Warning',\n}\n\nexport enum EnterpriseSupportStatusReason {\n  ExceedResourceLimit = 'ExceedResourceLimit',\n  ExceedNodeLimit = 'ExceedNodeLimit',\n  MismatchProductVersion = 'MismatchProductVersion',\n  MismatchSubProducts = 'MismatchSubProducts',\n  NotExist = 'NotExist',\n  Expired = 'Expired',\n  Pending = 'Pending',\n  ExpiringSoon = 'ExpiringSoon',\n}\n\nexport enum SecurityPolicyRuleName {\n  password = 'PasswordPolicy',\n  lock = 'UserLockedPolicy',\n  disable = 'UserDisabledPolicy',\n  notification = 'NotificationPolicy',\n  access = 'AccessControlPolicy',\n}\n\nexport interface SecurityPolicyRule {\n  name: SecurityPolicyRuleName;\n  items: Array<{\n    enable: boolean;\n    key: string;\n    value: string;\n  }>;\n}\n\nexport interface SecurityPolicyResource extends KubernetesResource {\n  rules: SecurityPolicyRule[];\n}\n\nexport interface Status {\n  kind: 'Status';\n  apiVersion: string;\n  metadata: {\n    continue?: string;\n  };\n  status: string;\n  message: string;\n  reason: string;\n  code: number;\n  details?: {\n    group?: string;\n    kind: string;\n    name: string;\n    uid: string;\n    causes: Array<{\n      message?: string;\n      reason?: string;\n      field?: string;\n    }>;\n  };\n}\n\nexport interface LocalObjectReference {\n  name: string;\n}\n\nexport interface ConfigMapKeyRef extends LocalObjectReference {\n  key: string;\n  optional?: boolean;\n}\n\nexport interface SecretKeyRef extends LocalObjectReference {\n  key: string;\n  optional?: boolean;\n}\n\nexport interface ConfigMapRef extends LocalObjectReference {\n  optional?: boolean;\n}\n\nexport interface SecretRef extends LocalObjectReference {\n  optional?: boolean;\n}\n\nexport interface ObjectFieldSelector {\n  apiVersion?: string;\n  fieldPath: string;\n}\nexport interface ResourceFieldSelector {\n  containerName?: string;\n  divisor?: string;\n  resource: string;\n}\n\n/**\n * Workload API\n */\nexport interface Deployment extends KubernetesResource {\n  name?: string;\n  spec?: DeploymentSpec;\n  status?: DeploymentStatus;\n  generation?: number;\n}\n\n// DeploymentSpec is the specification of the desired behavior of the Deployment.\nexport interface DeploymentSpec {\n  replicas?: number;\n  selector?: LabelSelector;\n  template?: PodTemplateSpec;\n  strategy?: DeploymentStrategy;\n  minReadySeconds?: number;\n  revisionHistoryLimit?: number;\n}\n\nexport interface Pod extends KubernetesResource {\n  spec?: PodSpec;\n  status?: PodStatus;\n}\n\nexport interface PodStatus {\n  conditions?: Condition[];\n  containerStatuses?: ContainerStatus[];\n  hostIP?: string;\n  initContainerStatuses?: ContainerStatus[];\n  ephemeralContainerStatuses?: ContainerStatus[];\n  message?: string;\n  nominatedNodeName?: string;\n  phase?: string;\n  podIP?: string;\n  podIPs?: Array<{ ip: string }>;\n  qosClass?: string;\n  reason?: string;\n  startTime?: string;\n}\n\nexport interface HostAliases {\n  ip: string;\n  hostnames: string[];\n}\n\nexport interface ContainerStatus {\n  containerID?: string;\n  image?: string;\n  imageID?: string;\n  lastState?: ContainerState;\n  name?: string;\n  ready?: boolean;\n  restartCount?: number;\n  state?: ContainerState;\n  started?: boolean;\n}\n\nexport interface ContainerState {\n  running?: ContainerStateRunning;\n  terminated?: ContainerStateTerminated;\n  waiting?: ContainerStateWaiting;\n}\n\nexport interface ContainerStateRunning {\n  startedAt?: string;\n}\n\nexport interface ContainerStateTerminated {\n  containerID?: string;\n  exitCode?: number;\n  finishedAt?: string;\n  message?: string;\n  reason?: string;\n  signal?: number;\n  startedAt?: string;\n}\n\nexport interface ContainerStateWaiting {\n  message?: string;\n  reason?: string;\n}\n\nexport interface DeploymentStatus {\n  availableReplicas?: number;\n  collisionCount?: number;\n  observedGeneration?: number;\n  readyReplicas?: number;\n  replicas?: number;\n  unavailableReplicas?: number;\n  updatedReplicas?: number;\n  conditions?: Condition[];\n}\n\nexport interface RequiredAffinity {\n  topologyKey: string;\n  labelSelector: LabelSelector;\n}\n\nexport interface PreferredAffinity {\n  weight: number;\n  podAffinityTerm: {\n    labelSelector?: LabelSelector;\n    topologyKey: string;\n  };\n}\n\nexport interface PodAffinity {\n  requiredDuringSchedulingIgnoredDuringExecution?: RequiredAffinity[];\n  preferredDuringSchedulingIgnoredDuringExecution?: PreferredAffinity[];\n}\n\nexport interface PodSpecAffinity {\n  podAffinity?: Affinity;\n  podAntiAffinity?: Affinity;\n  nodeAffinity?: Affinity;\n}\n\nexport interface Affinity {\n  requiredDuringSchedulingIgnoredDuringExecution?:\n    | PodAffinityTerm[]\n    | NodeAffinityTerm;\n  preferredDuringSchedulingIgnoredDuringExecution?: WeightedPodAffinityTerm[];\n}\n\nexport interface WeightedNodeAffinityTerm {\n  weight: number;\n  preference: NodeSelectorTerm;\n}\n\nexport interface NodeAffinity {\n  requiredDuringSchedulingIgnoredDuringExecution?: NodeAffinityTerm;\n  preferredDuringSchedulingIgnoredDuringExecution?: WeightedNodeAffinityTerm[];\n}\n\nexport interface WeightedPodAffinityTerm {\n  podAffinityTerm: PodAffinityTerm;\n  weight: number;\n}\n\nexport interface PodAffinityTerm {\n  labelSelector?: LabelSelector;\n  topologyKey: string;\n  namespaces?: string[];\n}\n\nexport interface NodeAffinityTerm {\n  nodeSelectorTerms: NodeSelectorTerm[];\n}\n\nexport interface NodeSelectorTerm {\n  matchExpressions: LabelSelectorRequirement[];\n}\n\nexport enum VolumeTypeEnum {\n  persistentVolumeClaim = 'persistentVolumeClaim',\n  configMap = 'configMap',\n  secret = 'secret',\n  ephemeral = 'ephemeral',\n  emptyDir = 'emptyDir',\n  hostPath = 'hostPath',\n}\n\nexport interface Volume {\n  name: string;\n  [VolumeTypeEnum.emptyDir]?: EmptyDirVolumeSource;\n  [VolumeTypeEnum.configMap]?: ConfigMapVolumeSource;\n  [VolumeTypeEnum.secret]?: SecretVolumeSource;\n  [VolumeTypeEnum.persistentVolumeClaim]?: PersistentVolumeClaimVolumeSource;\n  [VolumeTypeEnum.hostPath]?: HostPathVolumeSource;\n  [VolumeTypeEnum.ephemeral]?: EphemeralVolumeSource;\n  // other iaas storage definitions not included\n  isAppResource?: boolean; // 是否OAM应用资源\n  mountPath?: string; // for oam component webservice component. 未来可能单独定义\n}\n\nexport interface CsiVolumeSource {\n  driver: 'objectstorage.k8s.io';\n  volumeAttributes: {\n    'bar-name': string;\n    'bar-namespace': string;\n    bucketRequestName: string;\n  };\n}\n\nexport interface KeyToPath {\n  key?: string;\n  mode?: number;\n  path?: string;\n}\n\nexport interface EmptyDirVolumeSource {\n  medium?: string;\n  sizeLimit?: string; // eg: 1500m refers to: https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.15/#quantity-resource-core\n}\n\nexport interface ConfigMapVolumeSource {\n  name: string;\n  optional?: boolean;\n  items?: KeyToPath[];\n}\n\nexport interface SecretVolumeSource {\n  secretName: string;\n  optional?: boolean;\n  items?: KeyToPath[];\n}\n\nexport interface HostPathVolumeSource {\n  type?: string;\n  path: string;\n}\n\nexport interface PersistentVolumeClaimVolumeSource {\n  claimName: string;\n  readOnly?: boolean;\n}\n\nexport interface EphemeralVolumeSource {\n  volumeClaimTemplate: PersistentVolumeClaim;\n}\n\nexport interface Probe {\n  exec?: ExecAction;\n  failureThreshold?: number;\n  httpGet?: HTTPGetAction;\n  initialDelaySeconds?: number;\n  periodSeconds?: number;\n  successThreshold?: number;\n  tcpSocket?: TCPSocketAction;\n  timeoutSeconds?: number;\n}\n\nexport interface ExecAction {\n  command?: string[];\n}\n\nexport interface HTTPHeader {\n  name?: string;\n  value?: string;\n}\n\nexport interface TCPSocketAction {\n  host?: string;\n  port?: number | string;\n}\n\nexport interface VolumeMount {\n  name: string;\n  mountPath?: string;\n  readOnly?: boolean;\n  subPath?: string;\n  mountPropagation?: string;\n}\n\nexport interface ResourceRequirements {\n  limits?: StringMap;\n  requests?: StringMap;\n}\n\nexport interface ContainerPort {\n  name?: string;\n  hostPort?: number;\n  containerPort?: number;\n  servicePort?: number;\n  protocol?: 'TCP' | 'UDP';\n  hostIP?: string;\n}\n\nexport interface Certificate {\n  name: string;\n  namespace: string;\n  notBefore: string;\n  notAfter: string;\n  dnsNames: string[];\n  valid: boolean;\n  reasonCode?:\n    | 1 // 证书格式有误\n    | 2 // 证书不在有效期内\n    | 3; // 证书信息未知\n}\n\nexport const AlbProtocolMapper = {\n  http: 'HTTP',\n  https: 'HTTPS',\n  grpc: 'gRPC',\n  tcp: 'TCP',\n  udp: 'UDP',\n} as const;\n\nexport type AlbProtocol = keyof typeof AlbProtocolMapper;\n\nexport interface FrontendSpec {\n  port?: number | '';\n  protocol?: AlbProtocol;\n  source?: {\n    name: string;\n    namespace: string;\n    type: string;\n  };\n  backendProtocol?: 'HTTP' | 'HTTPS' | 'gRPC';\n  serviceGroup?: ServiceGroup;\n  certificate_name?: string;\n}\n\nexport interface RuleService {\n  name: string;\n  namespace: string;\n  port: number;\n  weight: number;\n}\n\nexport interface ServiceGroup {\n  services: RuleService[];\n  session_affinity_policy?: string;\n  session_affinity_attribute?: string;\n}\n\nexport interface RollingUpdateDaemonSet {\n  maxUnavailable?: string | number;\n}\n\nexport interface DaemonSetUpdateStrategy {\n  type?: DaemonSetUpdateStrategyType;\n  rollingUpdate?: RollingUpdateDaemonSet;\n}\n\nexport interface DaemonSet extends KubernetesResource {\n  spec?: DaemonSetSpec;\n  status?: DaemonSetStatus;\n}\n\nexport interface DaemonSetSpec {\n  selector?: LabelSelector;\n  template?: PodTemplateSpec;\n  updateStrategy?: DaemonSetUpdateStrategy;\n  minReadySeconds?: number;\n  revisionHistoryLimit?: number;\n}\n\nexport type DaemonSetStatus = Partial<{\n  currentNumberScheduled: number;\n  numberMisscheduled: number;\n  desiredNumberScheduled: number;\n  numberReady: number;\n  observedGeneration: number;\n  updatedNumberScheduled: number;\n  numberUnavailable: number;\n  numberAvailable: number;\n}>;\n\nexport interface ConfigMap<T = StringMap> extends KubernetesResource {\n  data?: T;\n  binaryData?: StringMap;\n}\n\n// https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.11/#cronjobspec-v1beta1-batch\nexport interface CronJobSpec {\n  concurrencyPolicy?: string;\n  failedJobsHistoryLimit?: number | '';\n  schedule?: string;\n  startingDeadlineSeconds?: number | '';\n  successfulJobsHistoryLimit?: number | '';\n  suspend?: boolean;\n  timeZone?: string;\n  jobTemplate?: JobTemplateSpec;\n}\n\nexport interface Job extends KubernetesResource {\n  spec?: JobSpec;\n  status?: JobStatus;\n}\n\nexport interface JobSpec {\n  activeDeadlineSeconds?: number | '';\n  backoffLimit?: number | '';\n  completions?: number | '';\n  manualSelector?: boolean;\n  parallelism?: number | '';\n  selector?: LabelSelector;\n  template?: PodTemplateSpec;\n  startingDeadlineSeconds?: number | '';\n}\n\n// https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.11/#jobtemplatespec-v1beta1-batch\nexport interface JobTemplateSpec {\n  metadata?: ObjectMeta;\n  spec?: JobSpec;\n}\n\nexport interface JobStatus {\n  active: number | '';\n  completionTime: string;\n  conditions: Condition[];\n  startTime: string;\n  succeeded: number;\n  failed: number;\n}\n\nexport interface CronJobStatus {\n  active?: ObjectReference[];\n  lastScheduleTime: string;\n}\n\nexport interface CronJob extends KubernetesResource {\n  spec?: CronJobSpec;\n  status?: CronJobStatus;\n}\n\nexport type NodeStatusReason =\n  | 'KubeletHasSufficientDisk'\n  | 'KubeletHasSufficientMemory'\n  | 'KubeletHasNoDiskPressure'\n  | 'KubeletReady';\n\nexport type NodeStatusType =\n  | 'OutOfDisk'\n  | 'MemoryPressure'\n  | 'DiskPressure'\n  | 'Ready';\n\nexport interface NodeTaint {\n  key: string;\n  timeAdded?: string;\n  effect: TaintEffect;\n  value?: string;\n  unschedulable?: boolean;\n}\n\nexport interface Node extends KubernetesResource {\n  spec?: {\n    providerID?: string;\n    taints?: NodeTaint[];\n    configSource?: string;\n    unschedulable?: boolean;\n    podCIDR?: string;\n    podCIDRs?: string[];\n    externalID?: string;\n    ip?: string;\n  };\n  status?: NodeStatus;\n}\n\nexport interface NodeStatus {\n  volumesAttached: boolean;\n  daemonEndpoints: {\n    kubeletEndpoint: {\n      port: number;\n    };\n  };\n  capacity: Record<string, string>;\n  addresses: Array<{\n    type: string;\n    address: string;\n  }>;\n  allocatable: {\n    'alpha.kubernetes.io/nvidia-gpu': string;\n    'tencent.com/vcuda-core': string;\n    'tencent.com/vcuda-memory': string;\n    pods: string;\n    cpu: string;\n    memory: string;\n  };\n  images: Array<{\n    sizeBytes: number;\n    names: string[];\n  }>;\n  nodeInfo: {\n    kubeProxyVersion: string;\n    operatingSystem: string;\n    kernelVersion: string;\n    systemUUID: string;\n    containerRuntimeVersion: string;\n    osImage: string;\n    architecture: string;\n    bootID: string;\n    machineID: string;\n    kubeletVersion: string;\n  };\n  volumesInUse: boolean;\n  phase: string;\n  conditions: Condition[];\n}\n\nexport interface Service extends KubernetesResource {\n  kind: 'Service';\n  spec?: ServiceSpec;\n  status?: {\n    loadBalancer?: {\n      ingress?: Array<{\n        hostname?: string;\n        ip?: string;\n      }>;\n    };\n  };\n}\n\nexport const SERVICE_TYPES = [\n  'ClusterIP',\n  'NodePort',\n  'LoadBalancer',\n  'ExternalName',\n] as const;\nexport const SERVICE_SESSION_AFFINITIES = ['None', 'ClientIP'] as const;\n\nexport type ServiceType = (typeof SERVICE_TYPES)[number];\n\nexport type ServiceSessionAffinity =\n  (typeof SERVICE_SESSION_AFFINITIES)[number];\n\nexport interface ServiceSpec {\n  clusterIP?: string;\n  clusterIPs?: string[];\n  externalIPs?: string[];\n  externalName?: string;\n  ipFamilies?: ['IPv4'] | ['IPv6'] | ['IPv4', 'IPv6'] | ['IPv6', 'IPv4'];\n  ipFamilyPolicy?: 'SingleStack' | 'PreferDualStack' | 'RequireDualStack';\n  ports?: ServicePort[];\n  selector?: StringMap;\n  type?: ServiceType;\n  sessionAffinity?: ServiceSessionAffinity;\n}\n\nexport const SERVICE_PORT_BASE_PROTOCOLS = ['TCP', 'UDP'] as const;\nexport type ServicePortBaseProtocol =\n  (typeof SERVICE_PORT_BASE_PROTOCOLS)[number];\n\nexport const SERVICE_PORT_PROTOCOLS = [\n  'TCP',\n  'UDP',\n  'HTTP',\n  'HTTPS',\n  'HTTP2',\n  'gRPC',\n] as const;\nexport type ServicePortProtocol = (typeof SERVICE_PORT_PROTOCOLS)[number];\n\nexport interface ServicePort {\n  name?: string;\n  nodePort?: number;\n  port?: number;\n  protocol?: ServicePortBaseProtocol;\n  appProtocol?: Lowercase<ServicePortProtocol>;\n  targetPort?: number | string;\n}\n\nexport interface CustomResourceDefinitionVersion {\n  name: string;\n  served: boolean;\n  storage: boolean;\n  schema?: {\n    openAPIV3Schema: OpenAPIV3SchemaObject;\n  };\n}\n\nexport interface CustomResourceDefinition extends KubernetesResource {\n  kind: 'CustomResourceDefinition';\n  spec: {\n    group: string;\n    version: string;\n    names: {\n      plural: string;\n      singular: string;\n      kind: string;\n      listKind: string;\n    };\n    scope: string;\n    validation: {\n      openAPIV3Schema: OpenAPIV3SchemaObject;\n    };\n    versions: CustomResourceDefinitionVersion[];\n    preserveUnknownFields: boolean;\n  };\n}\n\nexport interface NameSpaceResourceRatio extends KubernetesResource {\n  spec: {\n    cpu: number;\n    memory: number;\n  };\n  status: {\n    clusterCPU: number;\n    clusterMemory: number;\n  };\n}\n\n// https://github.com/kubernetes/kubernetes/blob/5a99930ab57b2c7837960b21d2c92e958db8c377/pkg/apis/core/types.go#L5575\nexport interface K8sEventSeries {\n  count: number;\n  lastObservedTime: string;\n}\n\nexport interface K8sEventSource {\n  component?: string;\n  host?: string;\n}\n\nexport interface K8sEvent extends KubernetesResource {\n  involvedObject?: ObjectReference;\n  reason?: string;\n  message?: string;\n  source?: K8sEventSource;\n  firstTimestamp?: string;\n  lastTimestamp?: string;\n  count?: number;\n  type?: string;\n  eventTime?: string;\n  series?: K8sEventSeries;\n  action?: string;\n  related?: ObjectReference;\n  reportingController?: string;\n  reportingInstance?: string;\n}\n\nexport interface ResourcePatch extends KubernetesResource {\n  spec?: {\n    jsonPatch: Array<{\n      op: string;\n      path: string;\n      value: string;\n    }>;\n    target?: {\n      apiVersion: string;\n      kind: string;\n      name: string;\n      namespace: string;\n    };\n    release: string;\n  };\n}\n"]}
|