fix: NixCache | use LonghornPVC construct for storage
This commit is contained in:
@@ -1,33 +1,23 @@
|
|||||||
import * as fs from "fs";
|
import * as fs from "fs";
|
||||||
import * as path from "path";
|
import * as path from "path";
|
||||||
import { Construct } from "constructs";
|
import { Construct } from "constructs";
|
||||||
import { PersistentVolumeClaimV1 } from "@cdktf/provider-kubernetes/lib/persistent-volume-claim-v1";
|
|
||||||
import { ConfigMapV1 } from "@cdktf/provider-kubernetes/lib/config-map-v1";
|
import { ConfigMapV1 } from "@cdktf/provider-kubernetes/lib/config-map-v1";
|
||||||
|
|
||||||
import { DeploymentV1 } from "@cdktf/provider-kubernetes/lib/deployment-v1";
|
import { DeploymentV1 } from "@cdktf/provider-kubernetes/lib/deployment-v1";
|
||||||
import { KubernetesProvider } from "@cdktf/provider-kubernetes/lib/provider";
|
import { KubernetesProvider } from "@cdktf/provider-kubernetes/lib/provider";
|
||||||
import { IngressRoute } from "../../utils";
|
|
||||||
import { ServiceV1 } from "@cdktf/provider-kubernetes/lib/service-v1";
|
import { ServiceV1 } from "@cdktf/provider-kubernetes/lib/service-v1";
|
||||||
|
|
||||||
|
import { IngressRoute, LonghornPvc } from "../../utils";
|
||||||
|
|
||||||
export class NixCache extends Construct {
|
export class NixCache extends Construct {
|
||||||
constructor(scope: Construct, id: string, kubernetes: KubernetesProvider) {
|
constructor(scope: Construct, id: string, provider: KubernetesProvider) {
|
||||||
super(scope, id);
|
super(scope, id);
|
||||||
|
|
||||||
const pvc = new PersistentVolumeClaimV1(this, "pvc", {
|
const pvc = new LonghornPvc(this, "pvc", {
|
||||||
provider: kubernetes,
|
provider,
|
||||||
metadata: {
|
name: "nix-cache",
|
||||||
name: "nix-cache",
|
namespace: "homelab",
|
||||||
namespace: "homelab",
|
accessModes: ["ReadWriteMany"],
|
||||||
},
|
size: "64Gi",
|
||||||
spec: {
|
|
||||||
storageClassName: "longhorn",
|
|
||||||
accessModes: ["ReadWriteMany"],
|
|
||||||
resources: {
|
|
||||||
requests: {
|
|
||||||
storage: "64Gi",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
});
|
});
|
||||||
|
|
||||||
const nginxConfig = fs.readFileSync(
|
const nginxConfig = fs.readFileSync(
|
||||||
@@ -36,7 +26,7 @@ export class NixCache extends Construct {
|
|||||||
);
|
);
|
||||||
|
|
||||||
const configMap = new ConfigMapV1(this, "config-map", {
|
const configMap = new ConfigMapV1(this, "config-map", {
|
||||||
provider: kubernetes,
|
provider,
|
||||||
metadata: {
|
metadata: {
|
||||||
name: "nix-cache",
|
name: "nix-cache",
|
||||||
namespace: "homelab",
|
namespace: "homelab",
|
||||||
@@ -47,7 +37,7 @@ export class NixCache extends Construct {
|
|||||||
});
|
});
|
||||||
|
|
||||||
new ServiceV1(this, "service", {
|
new ServiceV1(this, "service", {
|
||||||
provider: kubernetes,
|
provider,
|
||||||
metadata: {
|
metadata: {
|
||||||
name: "nix-cache",
|
name: "nix-cache",
|
||||||
namespace: "homelab",
|
namespace: "homelab",
|
||||||
@@ -68,7 +58,7 @@ export class NixCache extends Construct {
|
|||||||
});
|
});
|
||||||
|
|
||||||
new DeploymentV1(this, "deployment", {
|
new DeploymentV1(this, "deployment", {
|
||||||
provider: kubernetes,
|
provider,
|
||||||
metadata: {
|
metadata: {
|
||||||
name: "nix-cache",
|
name: "nix-cache",
|
||||||
namespace: "homelab",
|
namespace: "homelab",
|
||||||
@@ -108,7 +98,7 @@ export class NixCache extends Construct {
|
|||||||
{
|
{
|
||||||
name: "cache",
|
name: "cache",
|
||||||
persistentVolumeClaim: {
|
persistentVolumeClaim: {
|
||||||
claimName: pvc.metadata.name,
|
claimName: pvc.name,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -130,7 +120,7 @@ export class NixCache extends Construct {
|
|||||||
});
|
});
|
||||||
|
|
||||||
new IngressRoute(this, "ingress-route", {
|
new IngressRoute(this, "ingress-route", {
|
||||||
provider: kubernetes,
|
provider,
|
||||||
namespace: "homelab",
|
namespace: "homelab",
|
||||||
host: "nix.dogar.dev",
|
host: "nix.dogar.dev",
|
||||||
serviceName: "nix-cache",
|
serviceName: "nix-cache",
|
||||||
|
|||||||
Reference in New Issue
Block a user