forked from vmware-archive/kubeless
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathnats.jsonnet
77 lines (64 loc) · 2.57 KB
/
nats.jsonnet
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
local k = import "ksonnet.beta.1/k.libsonnet";
local container = k.core.v1.container;
local deployment = k.apps.v1beta1.deployment;
local serviceAccount = k.core.v1.serviceAccount;
local objectMeta = k.core.v1.objectMeta;
local namespace = "kubeless";
local controller_account_name = "controller-acct";
local crd = [
{
apiVersion: "apiextensions.k8s.io/v1beta1",
kind: "CustomResourceDefinition",
metadata: objectMeta.name("natstriggers.kubeless.io"),
spec: {group: "kubeless.io", version: "v1beta1", scope: "Namespaced", names: {plural: "natstriggers", singular: "natstrigger", kind: "NATSTrigger"}},
description: "CRD object for NATS trigger type",
},
];
local controllerContainer =
container.default("nats-trigger-controller", "bitnami/nats-trigger-controller:latest") +
container.imagePullPolicy("IfNotPresent");
local kubelessLabel = {kubeless: "nats-trigger-controller"};
local controllerAccount =
serviceAccount.default(controller_account_name, namespace);
local controllerDeployment =
deployment.default("nats-trigger-controller", controllerContainer, namespace) +
{metadata+:{labels: kubelessLabel}} +
{spec+: {selector: {matchLabels: kubelessLabel}}} +
{spec+: {template+: {spec+: {serviceAccountName: controllerAccount.metadata.name}}}} +
{spec+: {template+: {metadata: {labels: kubelessLabel}}}};
local controller_roles = [
{
apiGroups: [""],
resources: ["services", "configmaps"],
verbs: ["get", "list"],
},
{
apiGroups: ["kubeless.io"],
resources: ["functions", "natstriggers"],
verbs: ["get", "list", "watch", "update", "delete"],
},
];
local clusterRole(name, rules) = {
apiVersion: "rbac.authorization.k8s.io/v1beta1",
kind: "ClusterRole",
metadata: objectMeta.name(name),
rules: rules,
};
local clusterRoleBinding(name, role, subjects) = {
apiVersion: "rbac.authorization.k8s.io/v1beta1",
kind: "ClusterRoleBinding",
metadata: objectMeta.name(name),
subjects: [{kind: s.kind, namespace: s.metadata.namespace, name: s.metadata.name} for s in subjects],
roleRef: {kind: role.kind, apiGroup: "rbac.authorization.k8s.io", name: role.metadata.name},
};
local controllerClusterRole = clusterRole(
"nats-controller-deployer", controller_roles);
local controllerClusterRoleBinding = clusterRoleBinding(
"nats-controller-deployer", controllerClusterRole, [controllerAccount]
);
{
controller: k.util.prune(controllerDeployment),
crd: k.util.prune(crd),
controllerClusterRole: k.util.prune(controllerClusterRole),
controllerClusterRoleBinding: k.util.prune(controllerClusterRoleBinding),
}