@atomist/sdm
Version:
Atomist Software Delivery Machine SDK
62 lines (54 loc) • 2.12 kB
text/typescript
/*
* Copyright © 2020 Atomist, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import * as k8s from "@kubernetes/client-node";
import { KubernetesResourceRequest } from "./request";
import { upsertRole } from "./role";
import { upsertRoleBinding } from "./roleBinding";
import { upsertServiceAccount } from "./serviceAccount";
/**
* Package the RBAC resource specs.
*/
export interface RbacResources {
role?: k8s.V1Role | k8s.V1ClusterRole;
roleBinding?: k8s.V1RoleBinding | k8s.V1ClusterRoleBinding;
serviceAccount?: k8s.V1ServiceAccount;
}
/**
* Create requested RBAC resources if they do not exist. If
* `req.roleSpec` is truthy, the service account, role, and binding
* are created. If `req.roleSpect` is falsey but
* `req.serviceAccountSpec` is truthy, only the service account is
* created. If any of the RBAC resources exist and their
* corresponding partial spec is provided in `req`, the resource is
* patched.
*
* @param req Kuberenetes application request
* @return Kubernetes RBAC resource specs that were created or patched, some may be undefined
*/
export async function upsertRbac(req: KubernetesResourceRequest): Promise<RbacResources> {
if (req.roleSpec && !req.serviceAccountSpec) {
req.serviceAccountSpec = {};
}
const resources: RbacResources = {};
if (req.serviceAccountSpec) {
resources.serviceAccount = await upsertServiceAccount(req);
}
if (req.roleSpec) {
resources.role = await upsertRole(req);
resources.roleBinding = await upsertRoleBinding(req);
}
return resources;
}