2024-05-28 18:45:34 +02:00
|
|
|
import * as plugins from '../plugins.js';
|
|
|
|
import * as paths from '../paths.js';
|
|
|
|
import { Cloudly } from '../classes.cloudly.js';
|
2024-05-30 22:49:39 +02:00
|
|
|
import { logger } from '../logger.js';
|
2024-04-20 12:21:41 +02:00
|
|
|
|
2024-06-13 09:36:02 +02:00
|
|
|
import { Cluster } from './classes.cluster.js';
|
2024-10-16 14:35:38 +02:00
|
|
|
import { data } from '@serve.zone/interfaces';
|
2024-04-20 12:21:41 +02:00
|
|
|
|
|
|
|
export class ClusterManager {
|
|
|
|
public ready = plugins.smartpromise.defer();
|
|
|
|
|
|
|
|
public cloudlyRef: Cloudly;
|
|
|
|
public get db() {
|
|
|
|
return this.cloudlyRef.mongodbConnector.smartdataDb;
|
|
|
|
}
|
|
|
|
public typedrouter = new plugins.typedrequest.TypedRouter();
|
|
|
|
|
|
|
|
public CCluster = plugins.smartdata.setDefaultManagerForDoc(this, Cluster);
|
|
|
|
|
|
|
|
constructor(cloudlyRef: Cloudly) {
|
|
|
|
this.cloudlyRef = cloudlyRef;
|
|
|
|
this.cloudlyRef.typedrouter.addTypedRouter(this.typedrouter);
|
|
|
|
|
|
|
|
this.typedrouter.addTypedHandler<plugins.servezoneInterfaces.requests.cluster.IRequest_CreateCluster>(
|
|
|
|
new plugins.typedrequest.TypedHandler('createCluster', async (dataArg) => {
|
2024-08-25 14:29:26 +02:00
|
|
|
// TODO: guards
|
|
|
|
const cluster = await this.createCluster({
|
2024-04-20 12:21:41 +02:00
|
|
|
id: plugins.smartunique.uniSimple('cluster'),
|
|
|
|
data: {
|
2024-10-16 14:35:38 +02:00
|
|
|
userId: null, // this is created by the createCluster method
|
2024-04-20 12:21:41 +02:00
|
|
|
name: dataArg.clusterName,
|
|
|
|
acmeInfo: null,
|
|
|
|
cloudlyUrl: `https://${this.cloudlyRef.config.data.publicUrl}:${this.cloudlyRef.config.data.publicPort}/`,
|
|
|
|
servers: [],
|
|
|
|
sshKeys: [],
|
|
|
|
},
|
|
|
|
});
|
|
|
|
console.log(await cluster.createSavableObject());
|
|
|
|
this.cloudlyRef.serverManager.ensureServerInfrastructure();
|
|
|
|
return {
|
|
|
|
clusterConfig: await cluster.createSavableObject(),
|
|
|
|
};
|
2024-10-27 19:50:39 +01:00
|
|
|
}),
|
2024-04-20 12:21:41 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
this.typedrouter.addTypedHandler<plugins.servezoneInterfaces.requests.cluster.IRequest_GetAllClusters>(
|
|
|
|
new plugins.typedrequest.TypedHandler('getAllClusters', async (dataArg) => {
|
|
|
|
// TODO: do authentication here
|
|
|
|
const clusters = await this.getAllClusters();
|
|
|
|
return {
|
|
|
|
clusters: await Promise.all(
|
2024-10-27 19:50:39 +01:00
|
|
|
clusters.map((clusterArg) => clusterArg.createSavableObject()),
|
2024-04-20 12:21:41 +02:00
|
|
|
),
|
|
|
|
};
|
2024-10-27 19:50:39 +01:00
|
|
|
}),
|
2024-04-20 12:21:41 +02:00
|
|
|
);
|
2024-06-13 09:36:02 +02:00
|
|
|
|
|
|
|
// delete cluster
|
|
|
|
this.typedrouter.addTypedHandler<plugins.servezoneInterfaces.requests.cluster.IRequest_DeleteCluster>(
|
|
|
|
new plugins.typedrequest.TypedHandler('deleteCluster', async (reqDataArg, toolsArg) => {
|
2024-08-25 14:29:26 +02:00
|
|
|
await toolsArg.passGuards([this.cloudlyRef.authManager.adminIdentityGuard], reqDataArg);
|
2024-06-13 09:36:02 +02:00
|
|
|
await this.deleteCluster(reqDataArg.clusterId);
|
|
|
|
return {
|
|
|
|
success: true,
|
|
|
|
};
|
2024-10-27 19:50:39 +01:00
|
|
|
}),
|
2024-06-13 09:36:02 +02:00
|
|
|
);
|
2024-04-20 12:21:41 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public async init() {
|
|
|
|
// lets read the config folder
|
|
|
|
logger.log('info', 'config manager is now initializing');
|
|
|
|
this.ready.resolve();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* gets a cluster config by Name
|
|
|
|
*/
|
|
|
|
public async getClusterConfigBy_ServerIP() {
|
|
|
|
await this.ready.promise;
|
|
|
|
// TODO: implement getclusterConfigByServerIp
|
|
|
|
}
|
|
|
|
|
2024-10-16 14:35:38 +02:00
|
|
|
public async getClusterBy_UserId(userIdArg: string) {
|
2024-04-20 12:21:41 +02:00
|
|
|
await this.ready.promise;
|
|
|
|
|
|
|
|
return await Cluster.getInstance({
|
|
|
|
data: {
|
2024-10-16 14:35:38 +02:00
|
|
|
userId: userIdArg,
|
2024-04-20 12:21:41 +02:00
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2024-10-16 14:35:38 +02:00
|
|
|
public async getClusterBy_Identity(clusterIdentity: plugins.servezoneInterfaces.data.IIdentity) {
|
2024-04-20 12:21:41 +02:00
|
|
|
await this.ready.promise;
|
|
|
|
|
|
|
|
return await Cluster.getInstance({
|
|
|
|
data: {
|
2024-08-25 14:29:26 +02:00
|
|
|
userId: clusterIdentity.userId,
|
2024-04-20 12:21:41 +02:00
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* get config by id
|
|
|
|
*/
|
|
|
|
public async getConfigBy_ConfigID(configId: string) {
|
|
|
|
await this.ready.promise;
|
|
|
|
|
|
|
|
return await Cluster.getInstance({
|
|
|
|
id: configId,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* gets all cluster configs
|
|
|
|
*/
|
|
|
|
public async getAllClusters() {
|
|
|
|
await this.ready.promise;
|
|
|
|
|
|
|
|
return await Cluster.getInstances({});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2024-10-16 14:35:38 +02:00
|
|
|
* creates a cluster (and a new user for it) and saves it
|
2024-04-20 12:21:41 +02:00
|
|
|
* @param configName
|
|
|
|
* @param configObjectArg
|
|
|
|
*/
|
2024-08-25 14:29:26 +02:00
|
|
|
public async createCluster(configObjectArg: plugins.servezoneInterfaces.data.ICluster) {
|
|
|
|
// TODO: guards
|
|
|
|
// lets create the cluster user
|
2024-10-16 14:35:38 +02:00
|
|
|
const clusterUser = new this.cloudlyRef.authManager.CUser({
|
|
|
|
id: await this.cloudlyRef.authManager.CUser.getNewId(),
|
|
|
|
data: {
|
|
|
|
role: 'cluster',
|
|
|
|
type: 'machine',
|
|
|
|
tokens: [
|
|
|
|
{
|
|
|
|
expiresAt: Date.now() + 3600 * 1000 * 24 * 365,
|
|
|
|
assignedRoles: ['cluster'],
|
|
|
|
token: await this.cloudlyRef.authManager.createNewSecureToken(),
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
});
|
2024-08-25 14:29:26 +02:00
|
|
|
await clusterUser.save();
|
|
|
|
Object.assign(configObjectArg, {
|
|
|
|
userId: clusterUser.id,
|
|
|
|
});
|
|
|
|
const clusterInstance = await Cluster.fromConfigObject(configObjectArg);
|
2024-04-20 12:21:41 +02:00
|
|
|
await clusterInstance.save();
|
|
|
|
return clusterInstance;
|
|
|
|
}
|
2024-06-13 09:36:02 +02:00
|
|
|
|
|
|
|
public async deleteCluster(clusterId: string) {
|
|
|
|
await this.ready.promise;
|
|
|
|
const clusterInstance = await Cluster.getInstance({ id: clusterId });
|
|
|
|
await clusterInstance.delete();
|
|
|
|
}
|
2024-04-20 12:21:41 +02:00
|
|
|
}
|