gitea
Зеркало из https://github.com/go-gitea/gitea
1#!/bin/bash
2
3if [ ! -d /data/ssh ]; then
4mkdir -p /data/ssh
5fi
6
7if [ ! -f /data/ssh/ssh_host_ed25519_key ]; then
8echo "Generating /data/ssh/ssh_host_ed25519_key..."
9ssh-keygen -t ed25519 -f /data/ssh/ssh_host_ed25519_key -N "" > /dev/null
10fi
11
12if [ ! -f /data/ssh/ssh_host_rsa_key ]; then
13echo "Generating /data/ssh/ssh_host_rsa_key..."
14ssh-keygen -t rsa -b 3072 -f /data/ssh/ssh_host_rsa_key -N "" > /dev/null
15fi
16
17if [ ! -f /data/ssh/ssh_host_ecdsa_key ]; then
18echo "Generating /data/ssh/ssh_host_ecdsa_key..."
19ssh-keygen -t ecdsa -b 256 -f /data/ssh/ssh_host_ecdsa_key -N "" > /dev/null
20fi
21
22if [ -e /data/ssh/ssh_host_ed25519_cert ]; then
23SSH_ED25519_CERT=${SSH_ED25519_CERT:-"/data/ssh/ssh_host_ed25519_cert"}
24fi
25
26if [ -e /data/ssh/ssh_host_rsa_cert ]; then
27SSH_RSA_CERT=${SSH_RSA_CERT:-"/data/ssh/ssh_host_rsa_cert"}
28fi
29
30if [ -e /data/ssh/ssh_host_ecdsa_cert ]; then
31SSH_ECDSA_CERT=${SSH_ECDSA_CERT:-"/data/ssh/ssh_host_ecdsa_cert"}
32fi
33
34if [ -d /etc/ssh ]; then
35SSH_PORT=${SSH_PORT:-"22"} \
36SSH_LISTEN_PORT=${SSH_LISTEN_PORT:-"${SSH_PORT}"} \
37SSH_ED25519_CERT="${SSH_ED25519_CERT:+"HostCertificate "}${SSH_ED25519_CERT}" \
38SSH_RSA_CERT="${SSH_RSA_CERT:+"HostCertificate "}${SSH_RSA_CERT}" \
39SSH_ECDSA_CERT="${SSH_ECDSA_CERT:+"HostCertificate "}${SSH_ECDSA_CERT}" \
40SSH_MAX_STARTUPS="${SSH_MAX_STARTUPS:+"MaxStartups "}${SSH_MAX_STARTUPS}" \
41SSH_MAX_SESSIONS="${SSH_MAX_SESSIONS:+"MaxSessions "}${SSH_MAX_SESSIONS}" \
42SSH_INCLUDE_FILE="${SSH_INCLUDE_FILE:+"Include "}${SSH_INCLUDE_FILE}" \
43SSH_LOG_LEVEL=${SSH_LOG_LEVEL:-"INFO"} \
44envsubst < /etc/templates/sshd_config > /etc/ssh/sshd_config
45
46chmod 0644 /etc/ssh/sshd_config
47fi
48
49chown root:root /data/ssh/*
50chmod 0700 /data/ssh
51chmod 0600 /data/ssh/*
52