@alauda-fe/storage 0.0.9 → 0.0.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,2 +1,36 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiazhzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbW9kdWxlcy9zdG9yYWdlL3NyYy9saWIvdHlwZXMvazhzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBY2Nlc3NNb2RlLCBLdWJlcm5ldGVzUmVzb3VyY2UsIFN0cmluZ01hcCB9IGZyb20gJ0BhbGF1ZGEtZmUvY29tbW9uJztcblxuaW1wb3J0IHtcbiAgUmVjbGFpbVBvbGljeSxcbiAgU3RvcmFnZVByb3Zpc2lvbmVyLFxuICBWb2x1bWVCaW5kaW5nTW9kZSxcbn0gZnJvbSAnLi9jb21tb25zJztcblxuZXhwb3J0IGludGVyZmFjZSBWb2x1bWVTbmFwc2hvdENsYXNzIGV4dGVuZHMgS3ViZXJuZXRlc1Jlc291cmNlIHtcbiAgZHJpdmVyOiBzdHJpbmc7XG4gIHBhcmFtZXRlcnM/OiBTdHJpbmdNYXA7XG4gIGRlbGV0aW9uUG9saWN5Pzogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFZvbHVtZVNuYXBzaG90IGV4dGVuZHMgS3ViZXJuZXRlc1Jlc291cmNlIHtcbiAgc3BlYzogVm9sdW1lU25hcHNob3RTcGVjO1xuICBzdGF0dXM/OiB7XG4gICAgYm91bmRWb2x1bWVTbmFwc2hvdENvbnRlbnROYW1lPzogc3RyaW5nO1xuICAgIHJlYWR5VG9Vc2U/OiBib29sZWFuO1xuICAgIGVycm9yPzogc3RyaW5nO1xuICAgIHJlc3RvcmVTaXplPzogc3RyaW5nO1xuICB9O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFZvbHVtZVNuYXBzaG90U3BlYyB7XG4gIHZvbHVtZVNuYXBzaG90Q2xhc3NOYW1lOiBzdHJpbmc7XG4gIHNvdXJjZT86IHtcbiAgICBwZXJzaXN0ZW50Vm9sdW1lQ2xhaW1OYW1lPzogc3RyaW5nO1xuICB9O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFN0b3JhZ2VDbGFzcyBleHRlbmRzIEt1YmVybmV0ZXNSZXNvdXJjZSB7XG4gIGFwaVZlcnNpb246ICdzdG9yYWdlLms4cy5pby92MSc7XG4gIGtpbmQ6ICdTdG9yYWdlQ2xhc3MnO1xuICBtb3VudE9wdGlvbnM/OiBzdHJpbmdbXTtcbiAgcGFyYW1ldGVycz86IFN0cmluZ01hcDtcbiAgcHJvdmlzaW9uZXI/OiBTdG9yYWdlUHJvdmlzaW9uZXI7XG4gIHJlY2xhaW1Qb2xpY3k/OiBSZWNsYWltUG9saWN5O1xuICB2b2x1bWVCaW5kaW5nTW9kZT86IFZvbHVtZUJpbmRpbmdNb2RlO1xuICBhbGxvd1ZvbHVtZUV4cGFuc2lvbj86IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQnVja2V0Q2xhc3MgZXh0ZW5kcyBLdWJlcm5ldGVzUmVzb3VyY2Uge1xuICBraW5kOiAnQnVja2V0Q2xhc3MnO1xuICBkcml2ZXJOYW1lOiBTdG9yYWdlUHJvdmlzaW9uZXI7XG4gIGRlbGV0aW9uUG9saWN5PzogUmVjbGFpbVBvbGljeTtcbiAgaXNEZWZhdWx0QnVja2V0Q2xhc3M/OiBib29sZWFuO1xuICBwYXJhbWV0ZXJzPzogU3RyaW5nTWFwO1xuICBwcm90b2NvbD86IHtcbiAgICBzMzoge1xuICAgICAgcmVnaW9uOiBzdHJpbmc7XG4gICAgICBzaWduYXR1cmVWZXJzaW9uOiBzdHJpbmc7XG4gICAgfTtcbiAgfTtcbn1cblxuZXhwb3J0IHR5cGUgQ29tbW9uU3RvcmFnZUNsYXNzID0gU3RvcmFnZUNsYXNzIHwgQnVja2V0Q2xhc3M7XG5cbmV4cG9ydCB0eXBlIENvbW1vblN0b3JhZ2VDbGFzc0tpbmQgPSBDb21tb25TdG9yYWdlQ2xhc3MgZXh0ZW5kcyB7XG4gIGtpbmQ6IGluZmVyIEs7XG59XG4gID8gS1xuICA6IG5ldmVyO1xuXG5leHBvcnQgaW50ZXJmYWNlIENlcGhGU1BlcnNpc3RlbnRWb2x1bWVTb3VyY2Uge1xuICBtb25pdG9yczogc3RyaW5nW107XG4gIHBhdGg/OiBzdHJpbmc7XG4gIHNlY3JldFJlZjogU2VjcmV0UmVmZXJlbmNlO1xuICB1c2VyOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2VjcmV0UmVmZXJlbmNlIHtcbiAgbmFtZTogc3RyaW5nO1xuICBuYW1lc3BhY2U6IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBQZXJzaXN0ZW50Vm9sdW1lU3BlYyBleHRlbmRzIFBlcnNpc3RlbnRWb2x1bWVTcGVjTWV0YSB7XG4gIGFjY2Vzc01vZGVzOiBbQWNjZXNzTW9kZV07XG4gIC8vIG51bGwg6KGo56S65L2/55So6buY6K6kIHNjXG4gIC8vIFwiXCIg5oiW5LiN5YaZ6K+l5a2X5q616KGo56S65LiN6K6+572u5a2Y5YKo57G7XG4gIHN0b3JhZ2VDbGFzc05hbWU/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGVyc2lzdGVudFZvbHVtZSBleHRlbmRzIEt1YmVybmV0ZXNSZXNvdXJjZSB7XG4gIGFwaVZlcnNpb246IHN0cmluZztcbiAga2luZDogc3RyaW5nO1xuICBzcGVjOiBQZXJzaXN0ZW50Vm9sdW1lU3BlYztcbiAgc3RhdHVzPzoge1xuICAgIHBoYXNlOiBzdHJpbmc7XG4gIH07XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGVyc2lzdGVudFZvbHVtZVNwZWNNZXRhIHtcbiAgY2FwYWNpdHk6IHtcbiAgICBzdG9yYWdlOiBzdHJpbmc7XG4gIH07XG4gIGNsYWltUmVmPzoge1xuICAgIGFwaVZlcnNpb246IHN0cmluZztcbiAgICBraW5kOiAnUGVyc2lzdGVudFZvbHVtZUNsYWltJztcbiAgICBuYW1lOiBzdHJpbmc7XG4gICAgbmFtZXNwYWNlOiBzdHJpbmc7XG4gICAgdWlkOiBzdHJpbmc7XG4gIH07XG4gIHBlcnNpc3RlbnRWb2x1bWVSZWNsYWltUG9saWN5OiAnUmV0YWluJyB8ICdEZWxldGUnO1xuICBob3N0UGF0aD86IHtcbiAgICBwYXRoOiBzdHJpbmc7XG4gIH07XG4gIG5mcz86IHtcbiAgICBzZXJ2ZXI6IHN0cmluZztcbiAgICBwYXRoOiBzdHJpbmc7XG4gIH07XG4gIGNlcGhmcz86IENlcGhGU1BlcnNpc3RlbnRWb2x1bWVTb3VyY2U7XG4gIG1vdW50T3B0aW9ucz86IHN0cmluZ1tdO1xuICBjc2k/OiB7XG4gICAgZHJpdmVyPzogc3RyaW5nO1xuICAgIHJlYWRPbmx5PzogYm9vbGVhbjtcbiAgICAvKiog6K+l5a2X5q6155SxVUnnlJ/miJDvvIwg6ZyA5L+d6K+B6ZuG576k5ZSv5LiA77yMIOWPr+mHh+eUqHV1aWQgKi9cbiAgICB2b2x1bWVIYW5kbGU/OiBzdHJpbmc7XG4gICAgdm9sdW1lQXR0cmlidXRlczoge1xuICAgICAgLyoqIG5mcyDmnI3liqHnq6/lnLDlnYAgKi9cbiAgICAgIHNlcnZlcjogc3RyaW5nO1xuICAgICAgLyoqIG5mcyDmnI3liqHnq69mc+ebruW9lSAqL1xuICAgICAgc2hhcmU6IHN0cmluZztcbiAgICB9O1xuICB9O1xufVxuIl19
1
+ const CephResourceConfigurationKeys = [
2
+ 'mgr',
3
+ 'mon',
4
+ 'osd',
5
+ 'rbdmirror',
6
+ 'prepareosd',
7
+ 'crashcollector',
8
+ 'cleanup',
9
+ ];
10
+ const CephPlacementConfigurationKeys = [
11
+ 'mgr',
12
+ 'mon',
13
+ 'rbdmirror',
14
+ 'cleanup',
15
+ 'all',
16
+ 'osd',
17
+ ];
18
+ export var TopolvmClusterStorageDeviceClassStatusEnum;
19
+ (function (TopolvmClusterStorageDeviceClassStatusEnum) {
20
+ TopolvmClusterStorageDeviceClassStatusEnum["AVAILABLE"] = "available";
21
+ TopolvmClusterStorageDeviceClassStatusEnum["NOT_AVAILABLE"] = "not_available";
22
+ })(TopolvmClusterStorageDeviceClassStatusEnum || (TopolvmClusterStorageDeviceClassStatusEnum = {}));
23
+ // MinioCluster
24
+ export var HealthStatus;
25
+ (function (HealthStatus) {
26
+ HealthStatus["GREEN"] = "green";
27
+ HealthStatus["YELLOW"] = "yellow";
28
+ HealthStatus["RED"] = "red";
29
+ })(HealthStatus || (HealthStatus = {}));
30
+ export var PoolState;
31
+ (function (PoolState) {
32
+ PoolState["POOL_NOT_CREATED"] = "PoolNotCreated";
33
+ PoolState["POOL_CREATED"] = "PoolCreated";
34
+ PoolState["POOL_INITIALIZED"] = "PoolInitialized";
35
+ })(PoolState || (PoolState = {}));
36
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"k8s.js","sourceRoot":"","sources":["../../../../../../modules/storage/src/lib/types/k8s.ts"],"names":[],"mappings":"AAiLA,MAAM,6BAA6B,GAAG;IACpC,KAAK;IACL,KAAK;IACL,KAAK;IACL,WAAW;IACX,YAAY;IACZ,gBAAgB;IAChB,SAAS;CACD,CAAC;AAiEX,MAAM,8BAA8B,GAAG;IACrC,KAAK;IACL,KAAK;IACL,WAAW;IACX,SAAS;IACT,KAAK;IACL,KAAK;CACG,CAAC;AAmKX,MAAM,CAAN,IAAY,0CAGX;AAHD,WAAY,0CAA0C;IACpD,qEAAuB,CAAA;IACvB,6EAA+B,CAAA;AACjC,CAAC,EAHW,0CAA0C,KAA1C,0CAA0C,QAGrD;AA8BD,eAAe;AAEf,MAAM,CAAN,IAAY,YAIX;AAJD,WAAY,YAAY;IACtB,+BAAe,CAAA;IACf,iCAAiB,CAAA;IACjB,2BAAW,CAAA;AACb,CAAC,EAJW,YAAY,KAAZ,YAAY,QAIvB;AAED,MAAM,CAAN,IAAY,SAIX;AAJD,WAAY,SAAS;IACnB,gDAAmC,CAAA;IACnC,yCAA4B,CAAA;IAC5B,iDAAoC,CAAA;AACtC,CAAC,EAJW,SAAS,KAAT,SAAS,QAIpB","sourcesContent":["import {\n  AccessMode,\n  Condition,\n  KubernetesResource,\n  StringMap,\n  Affinity,\n  ResourceRequirements,\n} from '@alauda-fe/common';\n\nimport {\n  ReclaimPolicy,\n  StorageProvisioner,\n  VolumeBindingMode,\n} from './commons';\n\nexport interface VolumeSnapshotClass extends KubernetesResource {\n  driver: string;\n  parameters?: StringMap;\n  deletionPolicy?: string;\n}\n\nexport interface VolumeSnapshot extends KubernetesResource {\n  spec: VolumeSnapshotSpec;\n  status?: {\n    boundVolumeSnapshotContentName?: string;\n    readyToUse?: boolean;\n    error?: string;\n    restoreSize?: string;\n  };\n}\n\nexport interface VolumeSnapshotSpec {\n  volumeSnapshotClassName: string;\n  source?: {\n    persistentVolumeClaimName?: string;\n  };\n}\n\nexport interface StorageClass extends KubernetesResource {\n  apiVersion: 'storage.k8s.io/v1';\n  kind: 'StorageClass';\n  mountOptions?: string[];\n  parameters?: StringMap;\n  provisioner?: StorageProvisioner;\n  reclaimPolicy?: ReclaimPolicy;\n  volumeBindingMode?: VolumeBindingMode;\n  allowVolumeExpansion?: boolean;\n}\n\nexport interface BucketClass extends KubernetesResource {\n  kind: 'BucketClass';\n  driverName: StorageProvisioner;\n  deletionPolicy?: ReclaimPolicy;\n  isDefaultBucketClass?: boolean;\n  parameters?: StringMap;\n  protocol?: {\n    s3: {\n      region: string;\n      signatureVersion: string;\n    };\n  };\n}\n\nexport type CommonStorageClass = StorageClass | BucketClass;\n\nexport type CommonStorageClassKind = CommonStorageClass extends {\n  kind: infer K;\n}\n  ? K\n  : never;\n\nexport interface CephFSPersistentVolumeSource {\n  monitors: string[];\n  path?: string;\n  secretRef: SecretReference;\n  user: string;\n}\n\nexport interface SecretReference {\n  name: string;\n  namespace: string;\n}\n\nexport interface PersistentVolumeSpec extends PersistentVolumeSpecMeta {\n  accessModes: [AccessMode];\n  // null 表示使用默认 sc\n  // \"\" 或不写该字段表示不设置存储类\n  storageClassName?: string;\n}\n\nexport interface PersistentVolume extends KubernetesResource {\n  apiVersion: string;\n  kind: string;\n  spec: PersistentVolumeSpec;\n  status?: {\n    phase: string;\n  };\n}\n\nexport interface PersistentVolumeSpecMeta {\n  capacity: {\n    storage: string;\n  };\n  claimRef?: {\n    apiVersion: string;\n    kind: 'PersistentVolumeClaim';\n    name: string;\n    namespace: string;\n    uid: string;\n  };\n  persistentVolumeReclaimPolicy: 'Retain' | 'Delete';\n  hostPath?: {\n    path: string;\n  };\n  nfs?: {\n    server: string;\n    path: string;\n  };\n  cephfs?: CephFSPersistentVolumeSource;\n  mountOptions?: string[];\n  csi?: {\n    driver?: string;\n    readOnly?: boolean;\n    /** 该字段由UI生成， 需保证集群唯一， 可采用uuid */\n    volumeHandle?: string;\n    volumeAttributes: {\n      /** nfs 服务端地址 */\n      server: string;\n      /** nfs 服务端fs目录 */\n      share: string;\n    };\n  };\n}\n\nexport interface VolumeClaimTemplate extends KubernetesResource {\n  spec: {\n    accessModes: string[];\n    resources: {\n      requests: {\n        storage: string;\n      };\n    };\n    storageClassName: string;\n  };\n}\n\nexport interface CephClusterNetwork {\n  ipFamily?: string;\n  provider?: string;\n}\n\nexport interface CephClusterStatus {\n  ceph: {\n    health: string;\n    lastChecked: string;\n    details: unknown;\n    capacity?: {\n      bytesAvailable: number;\n      bytesTotal: number;\n      bytesUsed: number;\n      lastUpdated: string;\n    };\n  };\n  conditions: Condition[];\n  message: string;\n  phase: string;\n  state: string;\n  version: {\n    image: string;\n    version: string;\n  };\n  storage: {\n    deviceClasses: Array<{ name: string }>;\n  };\n  network: CephClusterNetwork;\n}\n\nconst CephResourceConfigurationKeys = [\n  'mgr',\n  'mon',\n  'osd',\n  'rbdmirror',\n  'prepareosd',\n  'crashcollector',\n  'cleanup',\n] as const;\n\nexport interface CephDashBoardSpec {\n  enabled: boolean;\n  urlPrefix?: string;\n  port?: number;\n  ssl?: boolean;\n}\n\n// https://github.com/rook/rook/blob/master/Documentation/CRDs/Cluster/stretch-cluster.md\nexport interface StretchCluster {\n  failureDomainLabel: string;\n  subFailureDomain: string;\n  zones: Array<{\n    name: string;\n    arbiter?: boolean;\n  }>;\n}\n\nexport interface CephMonSettings {\n  count: number;\n  allowMultiplePerNode?: boolean;\n  volumeClaimTemplate?: PersistentVolumeSpec;\n  stretchCluster?: StretchCluster;\n}\n\nexport interface CephMgrSettings {\n  modules: Array<{\n    name: string;\n    enabled: boolean;\n  }>;\n  count?: number;\n}\n\nexport interface CephOsdConfiguration {\n  metadataDevice?: string;\n  storeType?: string;\n  databaseSizeMB?: number;\n  walSizeMB?: number;\n  osdsPerDevice?: number;\n  encryptedDevice?: boolean;\n  deviceClass?: string;\n}\n\nexport interface CephNodeSettings {\n  name: string;\n  config?: CephOsdConfiguration;\n  useAllDevices?: boolean;\n  deviceFilter?: RegExp;\n  devicePathFilter?: RegExp;\n  devices?: Array<{ config?: { deviceClass: string }; name: string }>;\n}\n\nexport interface CephDisruptionManagement {\n  managePodBudgets?: boolean;\n  osdMaintenanceTimeout?: number;\n  manageMachineDisruptionBudgets?: boolean;\n  machineDisruptionBudgetNamespace?: string;\n}\n\nexport interface CephStorageSettings {\n  useAllNodes?: boolean;\n  nodes: CephNodeSettings[];\n}\n\nconst CephPlacementConfigurationKeys = [\n  'mgr',\n  'mon',\n  'rbdmirror',\n  'cleanup',\n  'all',\n  'osd',\n] as const;\n\nexport interface CephPlacementNodeAffinity {\n  requiredDuringSchedulingIgnoredDuringExecution: {\n    nodeSelectorTerms: Array<{\n      matchExpressions: Array<{\n        key: string;\n        operator: 'In' | 'NotIn' | 'Exists' | 'DoesNotExist';\n        values?: string[];\n      }>;\n    }>;\n  };\n}\n\nexport interface CephPlacementConfiguration {\n  nodeAffinity?: CephPlacementNodeAffinity;\n  podAffinity?: Affinity;\n  podAntiAffinity?: Affinity;\n  tolerations?: any[];\n  topologySpreadConstraints?: any[];\n}\n\nexport interface CephClusterSpec {\n  priorityClassNames?: StringMap;\n  external?: {\n    enable: boolean;\n  };\n  cephVersion: {\n    image: string;\n    allowUnsupported?: boolean;\n  };\n  dataDirHostPath: string;\n  skipUpgradeChecks?: boolean;\n  continueUpgradeAfterChecksEvenIfNotHealthy?: boolean;\n  dashboard?: CephDashBoardSpec;\n  mon: CephMonSettings;\n  mgr?: CephMgrSettings;\n  storage?: CephStorageSettings;\n  removeOSDsIfOutAndSafeToRemove?: boolean;\n  crashCollector?: {\n    disable: boolean;\n  };\n  network?: CephClusterNetwork;\n  disruptionManagement?: CephDisruptionManagement;\n  placement?: Partial<\n    Record<\n      Partial<typeof CephPlacementConfigurationKeys>[number],\n      CephPlacementConfiguration\n    >\n  >;\n  resources?: Partial<\n    Record<\n      Partial<typeof CephResourceConfigurationKeys>[number],\n      {\n        requests: {\n          cpu: string;\n          memory: string;\n        };\n      }\n    >\n  >;\n  monitoring?: {\n    enabled: boolean;\n    ruleNamespace?: string;\n  };\n}\n\n// https://rook.io/docs/rook/v1.3/ceph-cluster-crd.html\nexport interface CephCluster extends KubernetesResource {\n  spec: CephClusterSpec;\n  status?: CephClusterStatus;\n}\n\nexport interface CephObjectPoolSpec {\n  deviceClass?: string;\n  failureDomain?: string;\n  replicated: {\n    size: number;\n    requireSafeReplicaSize?: boolean;\n  };\n  parameters?: {\n    compression_mode?: string;\n  };\n}\n\nexport interface CephMetadataServer {\n  activeCount: number;\n  activeStandby?: boolean;\n  placement?: CephPlacementConfiguration;\n  resources: ResourceRequirements;\n}\n\nexport interface CephFileSystem extends KubernetesResource {\n  spec: {\n    metadataPool?: any;\n    dataPools?: CephObjectPoolSpec[];\n    preservePoolsOnDelete?: boolean;\n    metadataServer?: CephMetadataServer;\n  };\n  status?: {\n    phase: string;\n  };\n}\n\nexport interface CephBlockPool extends KubernetesResource {\n  spec: {\n    deviceClass?: string;\n    failureDomain: string;\n    replicated: {\n      size: number;\n    };\n  };\n  status?: any;\n}\n\nexport interface CephObjectStore extends KubernetesResource {\n  spec: CephObjectStoreSpec;\n}\n\nexport interface CephObjectStoreGateway {\n  type: string;\n  port: number;\n  instances: number;\n  placement: {\n    nodeAffinity: CephPlacementNodeAffinity;\n  };\n  annotations: unknown;\n  resources: {\n    limits: StringMap;\n  };\n}\n\nexport interface CephObjectStoreSpec {\n  metadataPool?: CephObjectPoolSpec;\n  dataPool?: CephObjectPoolSpec;\n  preservePoolsOnDelete?: boolean;\n  gateway?: CephObjectStoreGateway;\n}\n\n// TopolvmCluster\nexport interface TopolvmNodeStorageStateClass {\n  className: string;\n  vgName: string;\n  deviceStates?: Array<{\n    name: string;\n    message?: string;\n    state: 'Online' | 'Offline';\n  }>;\n  state: 'Ready' | 'UnReady';\n}\n\nexport interface TopolvmClusterStatus {\n  phase?: 'Ready' | 'Failure';\n  nodeStorageState?: Array<{\n    failClasses: TopolvmNodeStorageStateClass[];\n    successClasses: TopolvmNodeStorageStateClass[];\n    node: string;\n    phase: 'Ready' | 'Failure' | 'Unknown' | 'Pending' | '';\n  }>;\n}\n\nexport type TopolvmDeviceType = 'disk' | 'loop' | 'lvm';\n\nexport enum TopolvmClusterStorageDeviceClassStatusEnum {\n  AVAILABLE = 'available',\n  NOT_AVAILABLE = 'not_available',\n}\n\nexport interface TopolvmClusterSpecDeviceClassItem {\n  className: string;\n  default: boolean;\n  volumeGroup: string;\n  devices: Array<{\n    name: string;\n    type: TopolvmDeviceType;\n  }>;\n}\n\nexport interface TopolvmClusterSpecDeviceClass {\n  nodeName: string;\n  classes: TopolvmClusterSpecDeviceClassItem[];\n}\n\nexport interface TopolvmClusterV2Spec {\n  cleanup?: boolean;\n  topolvmVersion: string;\n  storage?: {\n    deviceClasses: TopolvmClusterSpecDeviceClass[];\n  };\n}\n\nexport interface TopolvmClusterV2 extends KubernetesResource {\n  spec: TopolvmClusterV2Spec;\n  status?: TopolvmClusterStatus;\n}\n\n// MinioCluster\n\nexport enum HealthStatus {\n  GREEN = 'green',\n  YELLOW = 'yellow',\n  RED = 'red',\n}\n\nexport enum PoolState {\n  POOL_NOT_CREATED = 'PoolNotCreated',\n  POOL_CREATED = 'PoolCreated',\n  POOL_INITIALIZED = 'PoolInitialized',\n}\n\nexport interface MinioClusterStatus {\n  currentState: string;\n  healthStatus: HealthStatus;\n  drivesOnline: number;\n  pools: Array<{ ssName: string; state: PoolState }>;\n  usage: {\n    // 总minio可用容量\n    capacity: number;\n    // minio已使用容量\n    usage: number;\n    // 总裸设备容量\n    rawCapacity: number;\n    // 已使用裸设备容量\n    rawUsage: number;\n  };\n}\n\nexport interface MinioClusterPool {\n  affinity: {\n    podAntiAffinity?: Affinity;\n    nodeAffinity?: Affinity;\n  };\n  // 存储池名字由pool+序号组成 pool-0 pool-1\n  name: string;\n  // 根据所选节点数， 当节点数为3时， 此处填6， 当节点数>=4时， 填写实际所选节点数\n  servers: number;\n  // 1\n  volumesPerServer: number;\n  volumeClaimTemplate: VolumeClaimTemplate;\n  // 存储池pod容忍，默认容忍一切\n  tolerations?: Array<{ effect: string; operator: string }>;\n  resources?: {\n    limits?: {\n      cpu: string;\n      memory: string;\n    };\n    requests?: {\n      cpu: string;\n      memory: string;\n    };\n  };\n}\n\nexport interface MinioClusterSpec {\n  configuration: {\n    // minio配置secret 由tenant名字+ \"-env-configuration\"\n    name: string;\n  };\n  credsSecret: {\n    name: string;\n  };\n  image?: string;\n  requestAutoCert: boolean;\n  pools: MinioClusterPool[];\n  externalCertSecret?: Array<{ name: string; type: string }>;\n  sideCars?: {\n    resources: {\n      limits?: {\n        cpu: string;\n        memory: string;\n      };\n      requests?: {\n        cpu: string;\n        memory: string;\n      };\n    };\n  };\n}\n\nexport interface MinioCluster extends KubernetesResource {\n  spec: MinioClusterSpec;\n  status?: MinioClusterStatus;\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { AccessMode, KubernetesResource, StringMap } from '@alauda-fe/common';
1
+ import { AccessMode, Condition, KubernetesResource, StringMap, Affinity, ResourceRequirements } from '@alauda-fe/common';
2
2
  import { ReclaimPolicy, StorageProvisioner, VolumeBindingMode } from './commons';
3
3
  export interface VolumeSnapshotClass extends KubernetesResource {
4
4
  driver: string;
@@ -103,3 +103,350 @@ export interface PersistentVolumeSpecMeta {
103
103
  };
104
104
  };
105
105
  }
106
+ export interface VolumeClaimTemplate extends KubernetesResource {
107
+ spec: {
108
+ accessModes: string[];
109
+ resources: {
110
+ requests: {
111
+ storage: string;
112
+ };
113
+ };
114
+ storageClassName: string;
115
+ };
116
+ }
117
+ export interface CephClusterNetwork {
118
+ ipFamily?: string;
119
+ provider?: string;
120
+ }
121
+ export interface CephClusterStatus {
122
+ ceph: {
123
+ health: string;
124
+ lastChecked: string;
125
+ details: unknown;
126
+ capacity?: {
127
+ bytesAvailable: number;
128
+ bytesTotal: number;
129
+ bytesUsed: number;
130
+ lastUpdated: string;
131
+ };
132
+ };
133
+ conditions: Condition[];
134
+ message: string;
135
+ phase: string;
136
+ state: string;
137
+ version: {
138
+ image: string;
139
+ version: string;
140
+ };
141
+ storage: {
142
+ deviceClasses: Array<{
143
+ name: string;
144
+ }>;
145
+ };
146
+ network: CephClusterNetwork;
147
+ }
148
+ declare const CephResourceConfigurationKeys: readonly ["mgr", "mon", "osd", "rbdmirror", "prepareosd", "crashcollector", "cleanup"];
149
+ export interface CephDashBoardSpec {
150
+ enabled: boolean;
151
+ urlPrefix?: string;
152
+ port?: number;
153
+ ssl?: boolean;
154
+ }
155
+ export interface StretchCluster {
156
+ failureDomainLabel: string;
157
+ subFailureDomain: string;
158
+ zones: Array<{
159
+ name: string;
160
+ arbiter?: boolean;
161
+ }>;
162
+ }
163
+ export interface CephMonSettings {
164
+ count: number;
165
+ allowMultiplePerNode?: boolean;
166
+ volumeClaimTemplate?: PersistentVolumeSpec;
167
+ stretchCluster?: StretchCluster;
168
+ }
169
+ export interface CephMgrSettings {
170
+ modules: Array<{
171
+ name: string;
172
+ enabled: boolean;
173
+ }>;
174
+ count?: number;
175
+ }
176
+ export interface CephOsdConfiguration {
177
+ metadataDevice?: string;
178
+ storeType?: string;
179
+ databaseSizeMB?: number;
180
+ walSizeMB?: number;
181
+ osdsPerDevice?: number;
182
+ encryptedDevice?: boolean;
183
+ deviceClass?: string;
184
+ }
185
+ export interface CephNodeSettings {
186
+ name: string;
187
+ config?: CephOsdConfiguration;
188
+ useAllDevices?: boolean;
189
+ deviceFilter?: RegExp;
190
+ devicePathFilter?: RegExp;
191
+ devices?: Array<{
192
+ config?: {
193
+ deviceClass: string;
194
+ };
195
+ name: string;
196
+ }>;
197
+ }
198
+ export interface CephDisruptionManagement {
199
+ managePodBudgets?: boolean;
200
+ osdMaintenanceTimeout?: number;
201
+ manageMachineDisruptionBudgets?: boolean;
202
+ machineDisruptionBudgetNamespace?: string;
203
+ }
204
+ export interface CephStorageSettings {
205
+ useAllNodes?: boolean;
206
+ nodes: CephNodeSettings[];
207
+ }
208
+ declare const CephPlacementConfigurationKeys: readonly ["mgr", "mon", "rbdmirror", "cleanup", "all", "osd"];
209
+ export interface CephPlacementNodeAffinity {
210
+ requiredDuringSchedulingIgnoredDuringExecution: {
211
+ nodeSelectorTerms: Array<{
212
+ matchExpressions: Array<{
213
+ key: string;
214
+ operator: 'In' | 'NotIn' | 'Exists' | 'DoesNotExist';
215
+ values?: string[];
216
+ }>;
217
+ }>;
218
+ };
219
+ }
220
+ export interface CephPlacementConfiguration {
221
+ nodeAffinity?: CephPlacementNodeAffinity;
222
+ podAffinity?: Affinity;
223
+ podAntiAffinity?: Affinity;
224
+ tolerations?: any[];
225
+ topologySpreadConstraints?: any[];
226
+ }
227
+ export interface CephClusterSpec {
228
+ priorityClassNames?: StringMap;
229
+ external?: {
230
+ enable: boolean;
231
+ };
232
+ cephVersion: {
233
+ image: string;
234
+ allowUnsupported?: boolean;
235
+ };
236
+ dataDirHostPath: string;
237
+ skipUpgradeChecks?: boolean;
238
+ continueUpgradeAfterChecksEvenIfNotHealthy?: boolean;
239
+ dashboard?: CephDashBoardSpec;
240
+ mon: CephMonSettings;
241
+ mgr?: CephMgrSettings;
242
+ storage?: CephStorageSettings;
243
+ removeOSDsIfOutAndSafeToRemove?: boolean;
244
+ crashCollector?: {
245
+ disable: boolean;
246
+ };
247
+ network?: CephClusterNetwork;
248
+ disruptionManagement?: CephDisruptionManagement;
249
+ placement?: Partial<Record<Partial<typeof CephPlacementConfigurationKeys>[number], CephPlacementConfiguration>>;
250
+ resources?: Partial<Record<Partial<typeof CephResourceConfigurationKeys>[number], {
251
+ requests: {
252
+ cpu: string;
253
+ memory: string;
254
+ };
255
+ }>>;
256
+ monitoring?: {
257
+ enabled: boolean;
258
+ ruleNamespace?: string;
259
+ };
260
+ }
261
+ export interface CephCluster extends KubernetesResource {
262
+ spec: CephClusterSpec;
263
+ status?: CephClusterStatus;
264
+ }
265
+ export interface CephObjectPoolSpec {
266
+ deviceClass?: string;
267
+ failureDomain?: string;
268
+ replicated: {
269
+ size: number;
270
+ requireSafeReplicaSize?: boolean;
271
+ };
272
+ parameters?: {
273
+ compression_mode?: string;
274
+ };
275
+ }
276
+ export interface CephMetadataServer {
277
+ activeCount: number;
278
+ activeStandby?: boolean;
279
+ placement?: CephPlacementConfiguration;
280
+ resources: ResourceRequirements;
281
+ }
282
+ export interface CephFileSystem extends KubernetesResource {
283
+ spec: {
284
+ metadataPool?: any;
285
+ dataPools?: CephObjectPoolSpec[];
286
+ preservePoolsOnDelete?: boolean;
287
+ metadataServer?: CephMetadataServer;
288
+ };
289
+ status?: {
290
+ phase: string;
291
+ };
292
+ }
293
+ export interface CephBlockPool extends KubernetesResource {
294
+ spec: {
295
+ deviceClass?: string;
296
+ failureDomain: string;
297
+ replicated: {
298
+ size: number;
299
+ };
300
+ };
301
+ status?: any;
302
+ }
303
+ export interface CephObjectStore extends KubernetesResource {
304
+ spec: CephObjectStoreSpec;
305
+ }
306
+ export interface CephObjectStoreGateway {
307
+ type: string;
308
+ port: number;
309
+ instances: number;
310
+ placement: {
311
+ nodeAffinity: CephPlacementNodeAffinity;
312
+ };
313
+ annotations: unknown;
314
+ resources: {
315
+ limits: StringMap;
316
+ };
317
+ }
318
+ export interface CephObjectStoreSpec {
319
+ metadataPool?: CephObjectPoolSpec;
320
+ dataPool?: CephObjectPoolSpec;
321
+ preservePoolsOnDelete?: boolean;
322
+ gateway?: CephObjectStoreGateway;
323
+ }
324
+ export interface TopolvmNodeStorageStateClass {
325
+ className: string;
326
+ vgName: string;
327
+ deviceStates?: Array<{
328
+ name: string;
329
+ message?: string;
330
+ state: 'Online' | 'Offline';
331
+ }>;
332
+ state: 'Ready' | 'UnReady';
333
+ }
334
+ export interface TopolvmClusterStatus {
335
+ phase?: 'Ready' | 'Failure';
336
+ nodeStorageState?: Array<{
337
+ failClasses: TopolvmNodeStorageStateClass[];
338
+ successClasses: TopolvmNodeStorageStateClass[];
339
+ node: string;
340
+ phase: 'Ready' | 'Failure' | 'Unknown' | 'Pending' | '';
341
+ }>;
342
+ }
343
+ export type TopolvmDeviceType = 'disk' | 'loop' | 'lvm';
344
+ export declare enum TopolvmClusterStorageDeviceClassStatusEnum {
345
+ AVAILABLE = "available",
346
+ NOT_AVAILABLE = "not_available"
347
+ }
348
+ export interface TopolvmClusterSpecDeviceClassItem {
349
+ className: string;
350
+ default: boolean;
351
+ volumeGroup: string;
352
+ devices: Array<{
353
+ name: string;
354
+ type: TopolvmDeviceType;
355
+ }>;
356
+ }
357
+ export interface TopolvmClusterSpecDeviceClass {
358
+ nodeName: string;
359
+ classes: TopolvmClusterSpecDeviceClassItem[];
360
+ }
361
+ export interface TopolvmClusterV2Spec {
362
+ cleanup?: boolean;
363
+ topolvmVersion: string;
364
+ storage?: {
365
+ deviceClasses: TopolvmClusterSpecDeviceClass[];
366
+ };
367
+ }
368
+ export interface TopolvmClusterV2 extends KubernetesResource {
369
+ spec: TopolvmClusterV2Spec;
370
+ status?: TopolvmClusterStatus;
371
+ }
372
+ export declare enum HealthStatus {
373
+ GREEN = "green",
374
+ YELLOW = "yellow",
375
+ RED = "red"
376
+ }
377
+ export declare enum PoolState {
378
+ POOL_NOT_CREATED = "PoolNotCreated",
379
+ POOL_CREATED = "PoolCreated",
380
+ POOL_INITIALIZED = "PoolInitialized"
381
+ }
382
+ export interface MinioClusterStatus {
383
+ currentState: string;
384
+ healthStatus: HealthStatus;
385
+ drivesOnline: number;
386
+ pools: Array<{
387
+ ssName: string;
388
+ state: PoolState;
389
+ }>;
390
+ usage: {
391
+ capacity: number;
392
+ usage: number;
393
+ rawCapacity: number;
394
+ rawUsage: number;
395
+ };
396
+ }
397
+ export interface MinioClusterPool {
398
+ affinity: {
399
+ podAntiAffinity?: Affinity;
400
+ nodeAffinity?: Affinity;
401
+ };
402
+ name: string;
403
+ servers: number;
404
+ volumesPerServer: number;
405
+ volumeClaimTemplate: VolumeClaimTemplate;
406
+ tolerations?: Array<{
407
+ effect: string;
408
+ operator: string;
409
+ }>;
410
+ resources?: {
411
+ limits?: {
412
+ cpu: string;
413
+ memory: string;
414
+ };
415
+ requests?: {
416
+ cpu: string;
417
+ memory: string;
418
+ };
419
+ };
420
+ }
421
+ export interface MinioClusterSpec {
422
+ configuration: {
423
+ name: string;
424
+ };
425
+ credsSecret: {
426
+ name: string;
427
+ };
428
+ image?: string;
429
+ requestAutoCert: boolean;
430
+ pools: MinioClusterPool[];
431
+ externalCertSecret?: Array<{
432
+ name: string;
433
+ type: string;
434
+ }>;
435
+ sideCars?: {
436
+ resources: {
437
+ limits?: {
438
+ cpu: string;
439
+ memory: string;
440
+ };
441
+ requests?: {
442
+ cpu: string;
443
+ memory: string;
444
+ };
445
+ };
446
+ };
447
+ }
448
+ export interface MinioCluster extends KubernetesResource {
449
+ spec: MinioClusterSpec;
450
+ status?: MinioClusterStatus;
451
+ }
452
+ export {};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@alauda-fe/storage",
3
- "version": "0.0.9",
3
+ "version": "0.0.10",
4
4
  "peerDependencies": {
5
5
  "@alauda/ui": "^8.0.0",
6
6
  "@alauda-fe/i18n": "1.0.11",