mirror of
https://github.com/carlosedp/cluster-monitoring.git
synced 2025-01-20 00:08:50 +01:00
Add SMTP relay for Gmail
This commit is contained in:
parent
e48d911632
commit
abd76d847a
10
create_gmail_auth.sh
Executable file
10
create_gmail_auth.sh
Executable file
@ -0,0 +1,10 @@
|
||||
#!/bin/bash
|
||||
|
||||
echo "Please enter your Gmail account";
|
||||
read username;
|
||||
|
||||
echo "Please enter your Gmail password";
|
||||
read -s password;
|
||||
|
||||
echo "Creating secret"
|
||||
kubectl create secret generic smtp-account -n monitoring --from-literal=username=${username} --from-literal=password=${password}
|
57
smtp_server.jsonnet
Normal file
57
smtp_server.jsonnet
Normal file
@ -0,0 +1,57 @@
|
||||
local k = import 'ksonnet/ksonnet.beta.3/k.libsonnet';
|
||||
|
||||
local kp = (import 'kube-prometheus/kube-prometheus.libsonnet') +
|
||||
(import 'image_sources_versions.jsonnet') +
|
||||
{
|
||||
_config+:: {
|
||||
namespace: 'monitoring',
|
||||
},
|
||||
|
||||
smtpServer+:: {
|
||||
deployment:
|
||||
local deployment = k.apps.v1beta2.deployment;
|
||||
local container = k.apps.v1beta2.deployment.mixin.spec.template.spec.containersType;
|
||||
local containerPort = container.portsType;
|
||||
|
||||
local podLabels = { run: 'smtp-server' };
|
||||
|
||||
local smtpServer =
|
||||
container.new('smtp-server', $._config.imageRepos.smtpServer + ':' + $._config.versions.smtpServer) +
|
||||
container.withPorts(containerPort.newNamed('smtp', 25)) +
|
||||
container.withEnv([
|
||||
{
|
||||
name: 'GMAIL_USER',
|
||||
valueFrom: {
|
||||
secretKeyRef: { name: 'smtp-account', key: 'username' },
|
||||
},
|
||||
},
|
||||
{
|
||||
name: 'GMAIL_PASSWORD',
|
||||
valueFrom: {
|
||||
secretKeyRef: { name: 'smtp-account', key: 'password' },
|
||||
},
|
||||
},
|
||||
{name: 'DISABLE_IPV6',
|
||||
value: 'True'},
|
||||
{name: 'RELAY_DOMAINS', value: ':192.168.0.0/24:10.0.0.0/16'},
|
||||
]);
|
||||
|
||||
local c = [smtpServer];
|
||||
|
||||
deployment.new('smtp-server', 1, c, podLabels) +
|
||||
deployment.mixin.metadata.withNamespace($._config.namespace) +
|
||||
deployment.mixin.metadata.withLabels(podLabels) +
|
||||
deployment.mixin.spec.selector.withMatchLabels(podLabels),
|
||||
|
||||
service:
|
||||
local service = k.core.v1.service;
|
||||
local servicePort = k.core.v1.service.mixin.spec.portsType;
|
||||
local smtpServerPorts = servicePort.newNamed('smtp', 25, 'smtp');
|
||||
|
||||
service.new('smtp-server', $.smtpServer.deployment.spec.selector.matchLabels, smtpServerPorts) +
|
||||
service.mixin.metadata.withNamespace($._config.namespace) +
|
||||
service.mixin.metadata.withLabels({ 'run': 'smtp-server' })
|
||||
},
|
||||
};
|
||||
|
||||
{ ['smtp-server-' + name]: kp.smtpServer[name] for name in std.objectFields(kp.smtpServer) }
|
Loading…
Reference in New Issue
Block a user