72 lines
1.7 KiB
TypeScript
72 lines
1.7 KiB
TypeScript
import { Construct } from "constructs";
|
|
import { Manifest } from "@cdktf/provider-kubernetes/lib/manifest";
|
|
import { KubernetesProvider } from "@cdktf/provider-kubernetes/lib/provider";
|
|
|
|
export interface IngressRouteTcpOptions {
|
|
provider: KubernetesProvider;
|
|
|
|
/** Namespace where the IngressRouteTCP will be created */
|
|
namespace: string;
|
|
|
|
/** EntryPoint name (e.g., "ssh", "mc25565", "postgres", etc.) */
|
|
entryPoint: string;
|
|
|
|
/** Backend service name */
|
|
serviceName: string;
|
|
|
|
/** Backend service port */
|
|
servicePort: number;
|
|
|
|
/**
|
|
* Match rule.
|
|
* Default is `HostSNI(\`*\`)` which is correct for most TCP services.
|
|
*/
|
|
match?: string;
|
|
|
|
/** Name override (CR name) */
|
|
name?: string;
|
|
}
|
|
|
|
export class IngressRouteTcp extends Construct {
|
|
public readonly manifest: Manifest;
|
|
|
|
constructor(scope: Construct, id: string, opts: IngressRouteTcpOptions) {
|
|
super(scope, id);
|
|
|
|
const name =
|
|
opts.name ??
|
|
`tcp-${opts.entryPoint}-${opts.serviceName}`.replace(
|
|
/[^a-zA-Z0-9-]/g,
|
|
"",
|
|
);
|
|
|
|
const matchRule = opts.match ?? "HostSNI(`*`)";
|
|
|
|
this.manifest = new Manifest(this, name, {
|
|
provider: opts.provider,
|
|
manifest: {
|
|
apiVersion: "traefik.io/v1alpha1",
|
|
kind: "IngressRouteTCP",
|
|
metadata: {
|
|
name,
|
|
namespace: opts.namespace,
|
|
},
|
|
spec: {
|
|
entryPoints: [opts.entryPoint],
|
|
routes: [
|
|
{
|
|
match: matchRule,
|
|
services: [
|
|
{
|
|
name: opts.serviceName,
|
|
port: opts.servicePort,
|
|
},
|
|
],
|
|
},
|
|
],
|
|
},
|
|
},
|
|
});
|
|
}
|
|
}
|