gitea源码

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. #!/bin/bash
  2. if [ ! -d /data/ssh ]; then
  3. mkdir -p /data/ssh
  4. fi
  5. if [ ! -f /data/ssh/ssh_host_ed25519_key ]; then
  6. echo "Generating /data/ssh/ssh_host_ed25519_key..."
  7. ssh-keygen -t ed25519 -f /data/ssh/ssh_host_ed25519_key -N "" > /dev/null
  8. fi
  9. if [ ! -f /data/ssh/ssh_host_rsa_key ]; then
  10. echo "Generating /data/ssh/ssh_host_rsa_key..."
  11. ssh-keygen -t rsa -b 3072 -f /data/ssh/ssh_host_rsa_key -N "" > /dev/null
  12. fi
  13. if [ ! -f /data/ssh/ssh_host_ecdsa_key ]; then
  14. echo "Generating /data/ssh/ssh_host_ecdsa_key..."
  15. ssh-keygen -t ecdsa -b 256 -f /data/ssh/ssh_host_ecdsa_key -N "" > /dev/null
  16. fi
  17. if [ -e /data/ssh/ssh_host_ed25519_cert ]; then
  18. SSH_ED25519_CERT=${SSH_ED25519_CERT:-"/data/ssh/ssh_host_ed25519_cert"}
  19. fi
  20. if [ -e /data/ssh/ssh_host_rsa_cert ]; then
  21. SSH_RSA_CERT=${SSH_RSA_CERT:-"/data/ssh/ssh_host_rsa_cert"}
  22. fi
  23. if [ -e /data/ssh/ssh_host_ecdsa_cert ]; then
  24. SSH_ECDSA_CERT=${SSH_ECDSA_CERT:-"/data/ssh/ssh_host_ecdsa_cert"}
  25. fi
  26. # In case someone wants to sign the `{keyname}.pub` key by `ssh-keygen -s ca -I identity ...` to
  27. # make use of the ssh-key certificate authority feature (see ssh-keygen CERTIFICATES section),
  28. # the generated key file name is `{keyname}-cert.pub`
  29. if [ -e /data/ssh/ssh_host_ed25519_key-cert.pub ]; then
  30. SSH_ED25519_CERT=${SSH_ED25519_CERT:-"/data/ssh/ssh_host_ed25519_key-cert.pub"}
  31. fi
  32. if [ -e /data/ssh/ssh_host_rsa_key-cert.pub ]; then
  33. SSH_RSA_CERT=${SSH_RSA_CERT:-"/data/ssh/ssh_host_rsa_key-cert.pub"}
  34. fi
  35. if [ -e /data/ssh/ssh_host_ecdsa_key-cert.pub ]; then
  36. SSH_ECDSA_CERT=${SSH_ECDSA_CERT:-"/data/ssh/ssh_host_ecdsa_key-cert.pub"}
  37. fi
  38. if [ -d /etc/ssh ]; then
  39. SSH_PORT=${SSH_PORT:-"22"} \
  40. SSH_LISTEN_PORT=${SSH_LISTEN_PORT:-"${SSH_PORT}"} \
  41. SSH_ED25519_CERT="${SSH_ED25519_CERT:+"HostCertificate "}${SSH_ED25519_CERT}" \
  42. SSH_RSA_CERT="${SSH_RSA_CERT:+"HostCertificate "}${SSH_RSA_CERT}" \
  43. SSH_ECDSA_CERT="${SSH_ECDSA_CERT:+"HostCertificate "}${SSH_ECDSA_CERT}" \
  44. SSH_MAX_STARTUPS="${SSH_MAX_STARTUPS:+"MaxStartups "}${SSH_MAX_STARTUPS}" \
  45. SSH_MAX_SESSIONS="${SSH_MAX_SESSIONS:+"MaxSessions "}${SSH_MAX_SESSIONS}" \
  46. SSH_INCLUDE_FILE="${SSH_INCLUDE_FILE:+"Include "}${SSH_INCLUDE_FILE}" \
  47. SSH_LOG_LEVEL=${SSH_LOG_LEVEL:-"INFO"} \
  48. envsubst < /etc/templates/sshd_config > /etc/ssh/sshd_config
  49. chmod 0644 /etc/ssh/sshd_config
  50. fi
  51. chown root:root /data/ssh/*
  52. chmod 0700 /data/ssh
  53. chmod 0600 /data/ssh/*