install.fairie/system/usr/local/etc/sftpgo/private_sftpgo.json.tmpl

436 lines
12 KiB
Cheetah
Raw Normal View History

2023-08-03 23:05:20 -07:00
{{- $baseDomain := (join (join .host.hostname ".") .host.domain) -}}
{{- if eq .host.qubes true -}}
{{- $baseDomain := (join (join .host.hostname "-qube.") .host.domain) -}}
{{- end -}}
2023-07-08 23:46:28 -07:00
{
2023-12-24 18:22:44 -08:00
"common": {
"idle_timeout": 15,
"upload_mode": 0,
"actions": {
"execute_on": [],
"execute_sync": [],
"hook": ""
},
"setstat_mode": 0,
"temp_path": "",
"proxy_protocol": 0,
"proxy_allowed": [],
"startup_hook": "",
"post_connect_hook": "",
"post_disconnect_hook": "",
"data_retention_hook": "",
"max_total_connections": 0,
"max_per_host_connections": 20,
"whitelist_file": "",
"allow_self_connections": 0,
"defender": {
"enabled": true,
"driver": "memory",
"ban_time": 30,
"ban_time_increment": 50,
"threshold": 15,
"score_invalid": 2,
"score_valid": 1,
"score_limit_exceeded": 3,
"observation_time": 30,
"entries_soft_limit": 100,
"entries_hard_limit": 150,
"safelist_file": "",
"blocklist_file": "",
"safelist": [],
"blocklist": []
},
"rate_limiters": [
{
"average": 0,
"period": 1000,
"burst": 1,
"type": 2,
"protocols": [
"SSH",
"FTP",
"DAV",
"HTTP"
],
"allow_list": [],
"generate_defender_events": false,
2023-07-08 23:46:28 -07:00
"entries_soft_limit": 100,
2023-12-24 18:22:44 -08:00
"entries_hard_limit": 150
}
]
},
"acme": {
"domains": [
"sftp.{{ $baseDomain }}"
],
"email": "{{ .user.cloudflare.username }}",
"key_type": "4096",
"certs_path": "certs",
"ca_endpoint": "https://acme-v02.api.letsencrypt.org/directory",
"renew_days": 30,
"http01_challenge": {
"port": 80,
"proxy_header": "",
"webroot": ""
2023-07-08 23:46:28 -07:00
},
2023-12-24 18:22:44 -08:00
"tls_alpn01_challenge": {
"port": 0
}
},
"sftpd": {
"bindings": [
{
"port": 2022,
"address": "",
"apply_proxy_config": true
}
],
"max_auth_tries": 0,
"banner": "",
"host_keys": [],
"host_certificates": [],
"host_key_algorithms": [],
"moduli": [],
"kex_algorithms": [],
"ciphers": [],
"macs": [],
"trusted_user_ca_keys": [],
"revoked_user_certs_file": "",
"login_banner_file": "/usr/local/etc/sftpgo/banner",
"enabled_ssh_commands": [
"md5sum",
"sha1sum",
"sha256sum",
"cd",
"pwd",
"scp"
],
"keyboard_interactive_authentication": false,
"keyboard_interactive_auth_hook": "",
"password_authentication": true,
"folder_prefix": ""
},
"ftpd": {
"bindings": [
{
"port": 0,
"address": "",
"apply_proxy_config": true,
"tls_mode": 0,
"certificate_file": "",
"certificate_key_file": "",
"min_tls_version": 12,
"force_passive_ip": "",
"passive_ip_overrides": [],
"client_auth_type": 0,
"tls_cipher_suites": [],
"passive_connections_security": 0,
"active_connections_security": 0,
"debug": false
2023-12-05 22:58:56 -08:00
}
2023-12-24 18:22:44 -08:00
],
"banner": "",
"banner_file": "",
"active_transfers_port_non_20": true,
"passive_port_range": {
"start": 50000,
"end": 50100
2023-07-08 23:46:28 -07:00
},
2023-12-24 18:22:44 -08:00
"disable_active_mode": false,
"enable_site": false,
"hash_support": 0,
"combine_support": 0,
"certificate_file": "",
"certificate_key_file": "",
"ca_certificates": [],
"ca_revocation_lists": []
},
"webdavd": {
"bindings": [
{
"port": 0,
"address": "",
"enable_https": false,
"certificate_file": "",
"certificate_key_file": "",
"min_tls_version": 12,
"client_auth_type": 0,
"tls_cipher_suites": [],
"prefix": "",
"proxy_allowed": [],
"client_ip_proxy_header": "",
"client_ip_header_depth": 0,
"disable_www_auth_header": false
}
],
"certificate_file": "",
"certificate_key_file": "",
"ca_certificates": [],
"ca_revocation_lists": [],
"cors": {
"enabled": false,
"allowed_origins": [],
"allowed_methods": [],
"allowed_headers": [],
"exposed_headers": [],
"allow_credentials": false,
"max_age": 0,
"options_passthrough": false,
"options_success_status": 0,
"allow_private_network": false
2023-12-23 03:08:39 -08:00
},
2023-12-24 18:22:44 -08:00
"cache": {
"users": {
"expiration_time": 0,
"max_size": 50
2023-12-05 22:58:56 -08:00
},
2023-12-24 18:22:44 -08:00
"mime_types": {
"enabled": true,
"max_size": 1000
}
}
},
"data_provider": {
"driver": "sqlite",
2024-04-25 23:34:27 -07:00
"name": "/usr/local/etc/sftpgo/sftpgo.db",
2023-12-24 18:22:44 -08:00
"host": "",
"port": 0,
"username": "",
"password": "",
"sslmode": 0,
"disable_sni": false,
"target_session_attrs": "",
"root_cert": "",
"client_cert": "",
"client_key": "",
"connection_string": "",
"sql_tables_prefix": "",
"track_quota": 2,
"delayed_quota_update": 0,
"pool_size": 0,
"users_base_dir": "/usr/local/var/sftpgo/data",
"actions": {
"execute_on": [],
"execute_for": [],
"hook": ""
2023-12-05 22:58:56 -08:00
},
2023-12-24 18:22:44 -08:00
"external_auth_hook": "",
"external_auth_scope": 0,
"pre_login_hook": "",
"post_login_hook": "",
"post_login_scope": 0,
"check_password_hook": "",
"check_password_scope": 0,
"password_hashing": {
"bcrypt_options": {
"cost": 10
2023-12-05 22:58:56 -08:00
},
2023-12-24 18:22:44 -08:00
"argon2_options": {
"memory": 65536,
"iterations": 1,
"parallelism": 2
},
"algo": "bcrypt"
},
"password_validation": {
"admins": {
"min_entropy": 0
},
"users": {
"min_entropy": 0
2023-07-08 23:46:28 -07:00
}
},
2023-12-24 18:22:44 -08:00
"password_caching": true,
"update_mode": 0,
"create_default_admin": true,
"naming_rules": 1,
"is_shared": 0,
"node": {
2023-07-08 23:46:28 -07:00
"host": "",
"port": 0,
2023-12-24 18:22:44 -08:00
"proto": "http"
},
"backups_path": "backups"
},
"httpd": {
"bindings": [
{
"port": 11101,
"address": "",
"enable_web_admin": true,
"enable_web_client": true,
"enable_rest_api": true,
"enabled_login_methods": 0,
"enable_https": false,
"certificate_file": "",
"certificate_key_file": "",
"min_tls_version": 12,
"client_auth_type": 0,
"tls_cipher_suites": [],
"proxy_allowed": [],
"client_ip_proxy_header": "",
"client_ip_header_depth": 0,
"hide_login_url": 0,
"render_openapi": true,
"web_client_integrations": [],
"oidc": {
"client_id": "",
"client_secret": "",
"config_url": "",
"redirect_base_url": "",
"scopes": [
"openid",
"profile",
"email"
],
"username_field": "",
"role_field": "",
"implicit_roles": false,
"custom_fields": [],
"insecure_skip_signature_check": false,
"debug": false
2023-07-08 23:46:28 -07:00
},
2023-12-24 18:22:44 -08:00
"security": {
"enabled": false,
"allowed_hosts": [],
"allowed_hosts_are_regex": false,
"hosts_proxy_headers": [],
"https_redirect": false,
"https_host": "",
"https_proxy_headers": [],
"sts_seconds": 0,
"sts_include_subdomains": false,
"sts_preload": false,
"content_type_nosniff": false,
"content_security_policy": "",
"permissions_policy": "",
"cross_origin_opener_policy": "",
"expect_ct_header": ""
2023-07-08 23:46:28 -07:00
},
2023-12-24 18:22:44 -08:00
"branding": {
"web_admin": {
"name": "",
"short_name": "",
"favicon_path": "/usr/local/etc/branding/favicon.ico",
"logo_path": "/usr/local/etc/branding/logo-color-256x256.png",
"login_image_path": "/usr/local/etc/branding/logo-color-900x900.png",
"disclaimer_name": "",
"disclaimer_path": "",
"default_css": "",
"extra_css": []
2023-12-23 03:08:39 -08:00
},
2023-12-24 18:22:44 -08:00
"web_client": {
"name": "",
"short_name": "",
"favicon_path": "/usr/local/etc/branding/favicon.ico",
"logo_path": "/usr/local/etc/branding/logo-color-256x256.png",
"login_image_path": "/usr/local/etc/branding/logo-color-900x900.png",
"disclaimer_name": "",
"disclaimer_path": "",
"default_css": "",
"extra_css": []
2023-07-08 23:46:28 -07:00
}
}
}
2023-12-24 18:22:44 -08:00
],
"templates_path": "templates",
"static_files_path": "static",
"openapi_path": "openapi",
"web_root": "",
"certificate_file": "",
"certificate_key_file": "",
"ca_certificates": [],
"ca_revocation_lists": [],
"signing_passphrase": "",
"token_validation": 0,
"max_upload_file_size": 1048576000,
"cors": {
"enabled": false,
"allowed_origins": [],
"allowed_methods": [],
"allowed_headers": [],
"exposed_headers": [],
"allow_credentials": false,
"max_age": 0,
"options_passthrough": false,
"options_success_status": 0,
"allow_private_network": false
2023-07-08 23:46:28 -07:00
},
2023-12-24 18:22:44 -08:00
"setup": {
"installation_code": "",
"installation_code_hint": "Installation code"
2023-07-08 23:46:28 -07:00
},
2023-12-24 18:22:44 -08:00
"hide_support_link": true
},
"telemetry": {
"bind_port": 57500,
"bind_address": "127.0.0.1",
"enable_profiler": false,
"auth_user_file": "",
"certificate_file": "",
"certificate_key_file": "",
"min_tls_version": 12,
"tls_cipher_suites": []
},
"http": {
"timeout": 20,
"retry_wait_min": 2,
"retry_wait_max": 30,
"retry_max": 3,
"ca_certificates": [],
"certificates": [],
"skip_tls_verify": false,
"headers": []
},
"command": {
"timeout": 30,
"env": [],
"commands": []
},
"kms": {
"secrets": {
"url": "",
"master_key": "",
"master_key_path": ""
}
},
"mfa": {
"totp": [
2023-12-05 22:58:56 -08:00
{
2024-05-20 18:46:40 -07:00
"name": "Install Doctor",
"issuer": "Install Doctor - SFTPGo",
2023-12-24 18:22:44 -08:00
"algo": "sha1"
2023-12-05 22:58:56 -08:00
}
]
2023-12-24 18:22:44 -08:00
},
"smtp": {
2024-01-02 17:40:12 -08:00
"host": "{{ .host.smtp.host }}",
"port": {{ .host.smtp.port }},
"from": "{{ .host.smtp.from }}",
"user": "{{ .host.smtp.user }}",
2023-12-24 18:22:44 -08:00
"password": "{{ if (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "SENDGRID_API_KEY")) }}{{ includeTemplate "secrets/SENDGRID_API_KEY" | decrypt | trim }}{{ else }}{{ env "SENDGRID_API_KEY" }}{{ end }}",
"auth_type": 0,
"encryption": 1,
"domain": "",
"templates_path": "templates"
},
"plugins": [
{
"cmd": "/usr/local/bin/sftpgo-plugin-auth",
"type": "auth",
"auth_options": {
"scope": 1
},
"args": [
"serve",
"--ldap-url=ldap://ldap.jumpcloud.com:389",
"--ldap-base-dn=ou=Users,o={{ if (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "JUMPCLOUD_ORG_ID")) }}{{ includeTemplate "secrets/JUMPCLOUD_ORG_ID" | decrypt | trim }}{{ else }}{{ env "JUMPCLOUD_ORG_ID" }}{{ end }},dc=jumpcloud,dc=com",
"--ldap-bind-dn=uid={{ if (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "JUMPCLOUD_BINDDN_USER")) }}{{ includeTemplate "secrets/JUMPCLOUD_BINDDN_USER" | decrypt | trim }}{{ else }}{{ env "JUMPCLOUD_BINDDN_USER" }}{{ end }},ou=Users,o={{ if (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "JUMPCLOUD_ORG_ID")) }}{{ includeTemplate "secrets/JUMPCLOUD_ORG_ID" | decrypt | trim }}{{ else }}{{ env "JUMPCLOUD_ORG_ID" }}{{ end }},dc=jumpcloud,dc=com",
"--ldap-password={{ if (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "JUMPCLOUD_BINDDN_PASSWORD")) }}{{ includeTemplate "secrets/JUMPCLOUD_BINDDN_PASSWORD" | decrypt | trim }}{{ else }}{{ env "JUMPCLOUD_BINDDN_PASSWORD" }}{{ end }}",
"--ldap-search-query=(objectClass=inetOrgPerson)"
],
"auto_mtls": true
}
]
}