2024-05-28 18:45:34 +02:00
|
|
|
import * as plugins from '../plugins.js';
|
|
|
|
import { Cloudly } from '../classes.cloudly.js';
|
2024-06-13 09:36:02 +02:00
|
|
|
import { Cluster } from '../manager.cluster/classes.cluster.js';
|
|
|
|
import { Server } from './classes.server.js';
|
|
|
|
import { CurlFresh } from './classes.curlfresh.js';
|
2024-04-20 12:21:41 +02:00
|
|
|
|
|
|
|
export class CloudlyServerManager {
|
|
|
|
public cloudlyRef: Cloudly;
|
|
|
|
public typedRouter = new plugins.typedrequest.TypedRouter();
|
2024-06-13 09:36:02 +02:00
|
|
|
public curlfreshInstance = new CurlFresh(this);
|
2024-04-20 12:21:41 +02:00
|
|
|
|
|
|
|
public hetznerAccount: plugins.hetznercloud.HetznerAccount;
|
|
|
|
|
|
|
|
public get db() {
|
|
|
|
return this.cloudlyRef.mongodbConnector.smartdataDb;
|
|
|
|
}
|
|
|
|
public CServer = plugins.smartdata.setDefaultManagerForDoc(this, Server);
|
|
|
|
|
|
|
|
constructor(cloudlyRefArg: Cloudly) {
|
|
|
|
this.cloudlyRef = cloudlyRefArg;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* is used be serverconfig module on the server to get the actual server config
|
|
|
|
*/
|
|
|
|
this.typedRouter.addTypedHandler(
|
|
|
|
new plugins.typedrequest.TypedHandler<plugins.servezoneInterfaces.requests.config.IRequest_Any_Cloudly_GetServerConfig>(
|
|
|
|
'getServerConfig',
|
|
|
|
async (requestData) => {
|
|
|
|
const serverId = requestData.serverId;
|
|
|
|
const server = await this.CServer.getInstance({
|
|
|
|
id: serverId,
|
2024-10-27 19:50:39 +01:00
|
|
|
});
|
2024-04-20 12:21:41 +02:00
|
|
|
return {
|
|
|
|
configData: await server.createSavableObject(),
|
|
|
|
};
|
2024-10-27 19:50:39 +01:00
|
|
|
},
|
|
|
|
),
|
2024-04-20 12:21:41 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public async start() {
|
2024-10-27 19:50:39 +01:00
|
|
|
this.hetznerAccount = new plugins.hetznercloud.HetznerAccount(
|
|
|
|
this.cloudlyRef.config.data.hetznerToken,
|
|
|
|
);
|
2024-04-20 12:21:41 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public async stop() {}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* creates the server infrastructure on hetzner
|
|
|
|
* ensures that there are exactly the reources that are needed
|
|
|
|
* no more, no less
|
|
|
|
*/
|
|
|
|
public async ensureServerInfrastructure() {
|
|
|
|
// get all clusters
|
|
|
|
const allClusters = await this.cloudlyRef.clusterManager.getAllClusters();
|
|
|
|
for (const cluster of allClusters) {
|
|
|
|
// get existing servers
|
|
|
|
const servers = await this.getServersByCluster(cluster);
|
|
|
|
|
|
|
|
// if there is no server, create one
|
|
|
|
if (servers.length === 0) {
|
|
|
|
const server = await this.hetznerAccount.createServer({
|
|
|
|
name: plugins.smartunique.uniSimple('server'),
|
|
|
|
location: 'nbg1',
|
|
|
|
type: 'cpx41',
|
|
|
|
labels: {
|
|
|
|
clusterId: cluster.id,
|
|
|
|
priority: '1',
|
2024-06-13 09:36:02 +02:00
|
|
|
},
|
2024-10-27 19:50:39 +01:00
|
|
|
userData: await this.curlfreshInstance.getServerUserData(),
|
2024-04-20 12:21:41 +02:00
|
|
|
});
|
|
|
|
const newServer = await Server.createFromHetznerServer(server);
|
|
|
|
console.log(`cluster created new server for cluster ${cluster.id}`);
|
|
|
|
} else {
|
2024-10-27 19:50:39 +01:00
|
|
|
console.log(
|
|
|
|
`cluster ${cluster.id} already has servers. Making sure that they actually exist in the real world...`,
|
|
|
|
);
|
2024-04-20 12:21:41 +02:00
|
|
|
// if there is a server, make sure that it exists
|
|
|
|
for (const server of servers) {
|
|
|
|
const hetznerServer = await this.hetznerAccount.getServersByLabel({
|
2024-10-27 19:50:39 +01:00
|
|
|
clusterId: cluster.id,
|
2024-04-20 12:21:41 +02:00
|
|
|
});
|
|
|
|
if (!hetznerServer) {
|
|
|
|
console.log(`server ${server.id} does not exist in the real world. Creating it now...`);
|
|
|
|
const hetznerServer = await this.hetznerAccount.createServer({
|
|
|
|
name: plugins.smartunique.uniSimple('server'),
|
|
|
|
location: 'nbg1',
|
|
|
|
type: 'cpx41',
|
|
|
|
labels: {
|
|
|
|
clusterId: cluster.id,
|
|
|
|
priority: '1',
|
2024-10-27 19:50:39 +01:00
|
|
|
},
|
2024-04-20 12:21:41 +02:00
|
|
|
});
|
|
|
|
const newServer = await Server.createFromHetznerServer(hetznerServer);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public async getServersByCluster(clusterArg: Cluster) {
|
|
|
|
const results = await this.CServer.getInstances({
|
|
|
|
data: {
|
|
|
|
assignedClusterId: clusterArg.id,
|
2024-10-27 19:50:39 +01:00
|
|
|
},
|
2024-04-20 12:21:41 +02:00
|
|
|
});
|
|
|
|
return results;
|
|
|
|
}
|
|
|
|
}
|