feat: initial prototype

This commit is contained in:
2026-02-13 15:52:13 +07:00
parent 134351b326
commit e8dbefde43
140 changed files with 12390 additions and 1369 deletions

82
k8s/backend-rbac.yaml Normal file
View File

@@ -0,0 +1,82 @@
apiVersion: v1
kind: ServiceAccount
metadata:
name: minikura-backend
namespace: minikura
---
apiVersion: rbac.authorization.k8s.io/v1
kind: Role
metadata:
name: minikura-backend-role
namespace: minikura
rules:
# Pods - read access and log access
- apiGroups: [""]
resources: ["pods"]
verbs: ["get", "list", "watch"]
- apiGroups: [""]
resources: ["pods/log"]
verbs: ["get", "list"]
# Pods - exec and attach access for terminal connections
- apiGroups: [""]
resources: ["pods/exec", "pods/attach"]
verbs: ["create", "get"]
# Services - read access
- apiGroups: [""]
resources: ["services"]
verbs: ["get", "list", "watch"]
# ConfigMaps - read access
- apiGroups: [""]
resources: ["configmaps"]
verbs: ["get", "list", "watch"]
# Deployments and StatefulSets - read access
- apiGroups: ["apps"]
resources: ["deployments", "statefulsets"]
verbs: ["get", "list", "watch"]
# Ingresses - read access
- apiGroups: ["networking.k8s.io"]
resources: ["ingresses"]
verbs: ["get", "list", "watch"]
# Custom Resources - read access
- apiGroups: ["minikura.kirameki.cafe"]
resources: ["minecraftservers", "reverseproxyservers"]
verbs: ["get", "list", "watch"]
---
apiVersion: rbac.authorization.k8s.io/v1
kind: RoleBinding
metadata:
name: minikura-backend-rolebinding
namespace: minikura
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: Role
name: minikura-backend-role
subjects:
- kind: ServiceAccount
name: minikura-backend
namespace: minikura
---
# ClusterRole for cluster-scoped resources (nodes)
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
name: minikura-backend-clusterrole
rules:
# Nodes - read access for getting node IPs
- apiGroups: [""]
resources: ["nodes"]
verbs: ["get", "list"]
---
# ClusterRoleBinding to grant the ServiceAccount access to cluster-scoped resources
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
name: minikura-backend-clusterrolebinding
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: ClusterRole
name: minikura-backend-clusterrole
subjects:
- kind: ServiceAccount
name: minikura-backend
namespace: minikura

48
k8s/rbac/dev-rbac.yaml Normal file
View File

@@ -0,0 +1,48 @@
apiVersion: v1
kind: ServiceAccount
metadata:
name: minikura-dev
namespace: minikura
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
name: minikura-dev-role
rules:
- apiGroups: [""]
resources: ["services", "pods", "nodes"]
verbs: ["get", "list", "watch"]
- apiGroups: [""]
resources: ["pods/log"]
verbs: ["get", "list"]
- apiGroups: ["apps"]
resources: ["deployments", "statefulsets"]
verbs: ["get", "list", "watch"]
- apiGroups: ["networking.k8s.io"]
resources: ["ingresses"]
verbs: ["get", "list", "watch"]
- apiGroups: ["minikura.kirameki.cafe"]
resources: ["minecraftservers", "reverseproxyservers"]
verbs: ["get", "list", "watch"]
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
name: minikura-dev-rolebinding
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: ClusterRole
name: minikura-dev-role
subjects:
- kind: ServiceAccount
name: minikura-dev
namespace: minikura
---
apiVersion: v1
kind: Secret
metadata:
name: minikura-dev-token
namespace: minikura
annotations:
kubernetes.io/service-account.name: minikura-dev
type: kubernetes.io/service-account-token

View File

@@ -0,0 +1,55 @@
apiVersion: v1
kind: ServiceAccount
metadata:
name: minikura-operator
namespace: minikura
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
name: minikura-operator-role
rules:
- apiGroups: [""]
resources: ["services", "pods", "persistentvolumeclaims", "configmaps"]
verbs: ["get", "list", "watch", "create", "update", "patch", "delete"]
- apiGroups: [""]
resources: ["pods/log"]
verbs: ["get", "list"]
- apiGroups: [""]
resources: ["nodes"]
verbs: ["get", "list"]
- apiGroups: ["apps"]
resources: ["deployments", "statefulsets"]
verbs: ["get", "list", "watch", "create", "update", "patch", "delete"]
- apiGroups: ["networking.k8s.io"]
resources: ["ingresses"]
verbs: ["get", "list", "watch", "create", "update", "patch", "delete"]
- apiGroups: ["apiextensions.k8s.io"]
resources: ["customresourcedefinitions"]
verbs: ["get", "list", "watch", "create", "update", "patch", "delete"]
- apiGroups: ["minikura.kirameki.cafe"]
resources: ["minecraftservers", "reverseproxyservers"]
verbs: ["get", "list", "watch", "create", "update", "patch", "delete"]
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
name: minikura-operator-rolebinding
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: ClusterRole
name: minikura-operator-role
subjects:
- kind: ServiceAccount
name: minikura-operator
namespace: minikura
---
# Secret to hold the service account token
apiVersion: v1
kind: Secret
metadata:
name: minikura-operator-token
namespace: minikura
annotations:
kubernetes.io/service-account.name: minikura-operator
type: kubernetes.io/service-account-token