service account
parent
33b8e149ac
commit
f64f0b01f7
|
|
@ -1280,6 +1280,7 @@ const kubernetes_utils_1 = __importDefault(__webpack_require__(92040));
|
|||
const async_wait_until_1 = __importDefault(__webpack_require__(41299));
|
||||
const kubernetes_job_spec_factory_1 = __importDefault(__webpack_require__(17203));
|
||||
const kubernetes_cleanup_cronjob_1 = __importDefault(__webpack_require__(82974));
|
||||
const kubernetes_service_account_1 = __importDefault(__webpack_require__(671));
|
||||
class Kubernetes {
|
||||
constructor(buildParameters) {
|
||||
this.buildId = '';
|
||||
|
|
@ -1289,6 +1290,7 @@ class Kubernetes {
|
|||
this.podName = '';
|
||||
this.containerName = '';
|
||||
this.cleanupCronJobName = '';
|
||||
this.serviceAccountName = '';
|
||||
this.kubeConfig = new k8s.KubeConfig();
|
||||
this.kubeConfig.loadFromDefault();
|
||||
this.kubeClient = this.kubeConfig.makeApiClient(k8s.CoreV1Api);
|
||||
|
|
@ -1307,8 +1309,10 @@ class Kubernetes {
|
|||
try {
|
||||
this.pvcName = `unity-builder-pvc-${buildUid}`;
|
||||
this.cleanupCronJobName = `unity-builder-cronjob-${buildUid}`;
|
||||
this.serviceAccountName = `service-account-${buildUid}`;
|
||||
yield kubernetes_storage_1.default.createPersistentVolumeClaim(buildParameters, this.pvcName, this.kubeClient, this.namespace);
|
||||
yield kubernetes_cleanup_cronjob_1.default.createCleanupCronJob(this.kubeClientBatchBeta, this.cleanupCronJobName, this.namespace);
|
||||
yield kubernetes_service_account_1.default.createServiceAccount(this.serviceAccountName, this.namespace, this.kubeClient);
|
||||
yield kubernetes_cleanup_cronjob_1.default.createCleanupCronJob(this.kubeClientBatchBeta, this.cleanupCronJobName, this.serviceAccountName, this.namespace);
|
||||
}
|
||||
catch (error) {
|
||||
throw error;
|
||||
|
|
@ -1436,7 +1440,7 @@ class KubernetesCleanupCronJob {
|
|||
yield api.deleteNamespacedCronJob('name', namespace);
|
||||
});
|
||||
}
|
||||
static createCleanupCronJob(kubeClientBatch, name, namespace) {
|
||||
static createCleanupCronJob(kubeClientBatch, name, serviceAccountName, namespace) {
|
||||
return __awaiter(this, void 0, void 0, function* () {
|
||||
try {
|
||||
const batchJob = new client_node_1.V1beta1CronJob();
|
||||
|
|
@ -1449,6 +1453,7 @@ class KubernetesCleanupCronJob {
|
|||
};
|
||||
const spec = {
|
||||
restartPolicy: 'Never',
|
||||
serviceAccountName,
|
||||
containers: [
|
||||
{
|
||||
name: 'main',
|
||||
|
|
@ -1781,6 +1786,65 @@ class KubernetesSecret {
|
|||
exports.default = KubernetesSecret;
|
||||
|
||||
|
||||
/***/ }),
|
||||
|
||||
/***/ 671:
|
||||
/***/ (function(__unused_webpack_module, exports, __webpack_require__) {
|
||||
|
||||
"use strict";
|
||||
|
||||
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
||||
if (k2 === undefined) k2 = k;
|
||||
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
||||
}) : (function(o, m, k, k2) {
|
||||
if (k2 === undefined) k2 = k;
|
||||
o[k2] = m[k];
|
||||
}));
|
||||
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
||||
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
||||
}) : function(o, v) {
|
||||
o["default"] = v;
|
||||
});
|
||||
var __importStar = (this && this.__importStar) || function (mod) {
|
||||
if (mod && mod.__esModule) return mod;
|
||||
var result = {};
|
||||
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
||||
__setModuleDefault(result, mod);
|
||||
return result;
|
||||
};
|
||||
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
||||
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
||||
return new (P || (P = Promise))(function (resolve, reject) {
|
||||
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
||||
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
||||
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
||||
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
||||
});
|
||||
};
|
||||
Object.defineProperty(exports, "__esModule", ({ value: true }));
|
||||
const k8s = __importStar(__webpack_require__(89679));
|
||||
class KubernetesServiceAccount {
|
||||
static createServiceAccount(serviceAccountName, namespace, kubeClient) {
|
||||
return __awaiter(this, void 0, void 0, function* () {
|
||||
const serviceAccount = new k8s.V1ServiceAccount();
|
||||
serviceAccount.apiVersion = 'v1';
|
||||
serviceAccount.kind = 'ServiceAccount';
|
||||
serviceAccount.metadata = {
|
||||
name: serviceAccountName,
|
||||
};
|
||||
serviceAccount.automountServiceAccountToken = false;
|
||||
try {
|
||||
yield kubeClient.createNamespacedServiceAccount(namespace, serviceAccount);
|
||||
}
|
||||
catch (error) {
|
||||
throw error;
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
exports.default = KubernetesServiceAccount;
|
||||
|
||||
|
||||
/***/ }),
|
||||
|
||||
/***/ 38941:
|
||||
|
|
|
|||
File diff suppressed because one or more lines are too long
|
|
@ -11,6 +11,7 @@ import KubernetesUtilities from './kubernetes-utils';
|
|||
import waitUntil from 'async-wait-until';
|
||||
import KubernetesJobSpecFactory from './kubernetes-job-spec-factory';
|
||||
import KubernetesCleanupCronJob from './kubernetes-cleanup-cronjob';
|
||||
import KubernetesServiceAccount from './kubernetes-service-account';
|
||||
|
||||
class Kubernetes implements RemoteBuilderProviderInterface {
|
||||
private kubeConfig: k8s.KubeConfig;
|
||||
|
|
@ -25,6 +26,7 @@ class Kubernetes implements RemoteBuilderProviderInterface {
|
|||
private podName: string = '';
|
||||
private containerName: string = '';
|
||||
private cleanupCronJobName: string = '';
|
||||
private serviceAccountName: string = '';
|
||||
private kubeClientBatchBeta: k8s.BatchV1beta1Api;
|
||||
|
||||
constructor(buildParameters: BuildParameters) {
|
||||
|
|
@ -49,15 +51,19 @@ class Kubernetes implements RemoteBuilderProviderInterface {
|
|||
try {
|
||||
this.pvcName = `unity-builder-pvc-${buildUid}`;
|
||||
this.cleanupCronJobName = `unity-builder-cronjob-${buildUid}`;
|
||||
this.serviceAccountName = `service-account-${buildUid}`;
|
||||
await KubernetesStorage.createPersistentVolumeClaim(
|
||||
buildParameters,
|
||||
this.pvcName,
|
||||
this.kubeClient,
|
||||
this.namespace,
|
||||
);
|
||||
|
||||
await KubernetesServiceAccount.createServiceAccount(this.serviceAccountName, this.namespace, this.kubeClient);
|
||||
await KubernetesCleanupCronJob.createCleanupCronJob(
|
||||
this.kubeClientBatchBeta,
|
||||
this.cleanupCronJobName,
|
||||
this.serviceAccountName,
|
||||
this.namespace,
|
||||
);
|
||||
} catch (error) {
|
||||
|
|
|
|||
|
|
@ -4,7 +4,12 @@ class KubernetesCleanupCronJob {
|
|||
static async cleanup(api: BatchV1beta1Api, name: string, namespace: string) {
|
||||
await api.deleteNamespacedCronJob('name', namespace);
|
||||
}
|
||||
static async createCleanupCronJob(kubeClientBatch: BatchV1beta1Api, name: string, namespace: string) {
|
||||
static async createCleanupCronJob(
|
||||
kubeClientBatch: BatchV1beta1Api,
|
||||
name: string,
|
||||
serviceAccountName: string,
|
||||
namespace: string,
|
||||
) {
|
||||
try {
|
||||
const batchJob = new V1beta1CronJob();
|
||||
batchJob.kind = 'CronJob';
|
||||
|
|
@ -16,6 +21,7 @@ class KubernetesCleanupCronJob {
|
|||
};
|
||||
const spec = {
|
||||
restartPolicy: 'Never',
|
||||
serviceAccountName,
|
||||
containers: [
|
||||
{
|
||||
name: 'main',
|
||||
|
|
|
|||
|
|
@ -0,0 +1,21 @@
|
|||
import { CoreV1Api } from '@kubernetes/client-node';
|
||||
import * as k8s from '@kubernetes/client-node';
|
||||
|
||||
class KubernetesServiceAccount {
|
||||
static async createServiceAccount(serviceAccountName: string, namespace: string, kubeClient: CoreV1Api) {
|
||||
const serviceAccount = new k8s.V1ServiceAccount();
|
||||
serviceAccount.apiVersion = 'v1';
|
||||
serviceAccount.kind = 'ServiceAccount';
|
||||
serviceAccount.metadata = {
|
||||
name: serviceAccountName,
|
||||
};
|
||||
serviceAccount.automountServiceAccountToken = false;
|
||||
try {
|
||||
await kubeClient.createNamespacedServiceAccount(namespace, serviceAccount);
|
||||
} catch (error) {
|
||||
throw error;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
export default KubernetesServiceAccount;
|
||||
Loading…
Reference in New Issue