config_panel.toml 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. version = "1.0"
  2. [main]
  3. name = "Auto-configuration"
  4. [main.vpn]
  5. name = ""
  6. optional = false
  7. [main.vpn.status]
  8. ask = "The status of your VPN is unknown."
  9. type = "alert"
  10. style = "info"
  11. [main.vpn.service_enabled]
  12. ask = "Enable VPN"
  13. type = "boolean"
  14. help = "If disabled, the VPN service will not automatically be started at boot."
  15. [main.vpn.doc]
  16. ask.en = "VPNclient only interfaces with *dedicated, public IP VPNs accepting inbound traffic*, preferably with an associated `.cube` (or `.ovpn/.conf`) configuration file. Checkout the [list of known compatible providers](https://yunohost.org/providers/vpn) for more info."
  17. ask.fr = "VPNclient est prévu pour fonctionner avec des *VPN dédiés et à IP publique qui acceptent le traffic entrant*, et de préférence avec un fichier de configuration `.cube` (ou `.ovpn/.conf`) associé. Consultez [la liste des fournisseurs connus et compatibles](https://yunohost.org/providers/vpn) pour plus d'infos."
  18. type = "alert"
  19. style = "info"
  20. [main.vpn.config_file]
  21. ask = "Configuration file"
  22. type = "file"
  23. accept = [".cube", ".ovpn", ".conf", "application/json", "text/plain"]
  24. help = ".cube file recommended, .ovpn file accepted"
  25. bind = "/etc/openvpn/client.conf"
  26. redact = true
  27. [main.vpn.config_template]
  28. type = "file"
  29. bind = "/etc/openvpn/client.conf.tpl"
  30. redact = true
  31. optional = true
  32. visible = false
  33. [main.vpn.cube_file]
  34. type = "file"
  35. bind = "/etc/openvpn/client.cube"
  36. redact = true
  37. optional = true
  38. visible = false
  39. [main.vpn.ovpn_file]
  40. type = "file"
  41. bind = "/etc/openvpn/client.ovpn"
  42. redact = true
  43. optional = true
  44. visible = false
  45. [main.auth]
  46. name = "Authentication"
  47. optional = true
  48. visible = 'config_file && ((match(config_file,"^\s*ca\s") && ! match(config_file,"^\s*<ca>")) || (match(config_file,"^\s*cert\s") && ! match(config_file,"^\s*<cert>")) || (match(config_file,"^\s*key\s") && ! match(config_file,"^\s*<key>")) || (match(config_file,"^\s*tls-auth\s") && ! match(config_file,"^\s*<tls-auth>")) || match(config_file,"^\s*auth-user-pass(\s.*)?$"))'
  49. [main.auth.crt_server_ca]
  50. ask = "Update Server CA"
  51. type = "file"
  52. bind = "/etc/openvpn/keys/ca-server.crt"
  53. visible = 'config_file && match(config_file,"^\s*ca\s") && ! match(config_file,"^\s*<ca>")'
  54. [main.auth.crt_client]
  55. ask = "Update Client Certificate"
  56. type = "file"
  57. bind = "/etc/openvpn/keys/user.crt"
  58. visible = 'config_file && match(config_file,"^\s*cert\s") && ! match(config_file,"^\s*<cert>")'
  59. [main.auth.crt_client_key]
  60. ask = "Update Client Key"
  61. type = "file"
  62. help = "This file begins with -----BEGIN PRIVATE KEY-----"
  63. bind = "/etc/openvpn/keys/user.key"
  64. visible = 'config_file && match(config_file,"^\s*key\s") && ! match(config_file,"^\s*<key>")'
  65. redact = true
  66. [main.auth.login_user]
  67. ask = "Username"
  68. type = "string"
  69. example = "camille"
  70. pattern.regexp = '^[a-zA-Z0-9_\-\\\.@]+$'
  71. pattern.error = "OpenVPN accept only alphabetic chars and -_\\.@"
  72. visible = 'config_file && match(config_file,"^\s*auth-user-pass\s")'
  73. [main.auth.login_passphrase]
  74. ask = "Password"
  75. type = "password"
  76. visible = 'config_file && match(config_file,"^\s*auth-user-pass(\s.*)?$")'
  77. [main.auth.crt_client_ta]
  78. ask = "TLS Auth shared secret"
  79. type = "file"
  80. example = "ta.key"
  81. help = "Some servers have an additional protection agains Deny of Service attack. If you have no tls-auth key in your ovpn, skip this question."
  82. bind = "/etc/openvpn/keys/user_ta.key"
  83. visible = 'config_file && match(config_file,"^\s*tls-auth\s") && ! match(config_file,"^\s*<tls-auth>")'
  84. redact = true
  85. [advanced]
  86. name = "DNS & IPv6"
  87. [advanced.dns]
  88. name = "DNS"
  89. [advanced.dns.dns_method]
  90. ask = "DNS resolvers"
  91. type = "select"
  92. choices.yunohost = "Default DNS resolvers from YunoHost"
  93. choices.custom = "Use custom DNS resolvers"
  94. [advanced.dns.nameservers]
  95. ask = "Custom DNS resolvers"
  96. type = "tags"
  97. optional = true
  98. visible = "dns_method == 'custom'"
  99. pattern.regexp = "^([0-9.]{7,15}|[0-9a-fA-F:]+)$"
  100. pattern.error = "Not an ip"
  101. [advanced.ipv6]
  102. name = "IPv6"
  103. [advanced.ipv6.ip6_net]
  104. ask = "IPv6 prefix"
  105. type = "string"
  106. optional = true
  107. example = "2001:db8:42::"
  108. pattern.regexp = "^[0-9a-fA-F:]+$"
  109. pattern.error = "Please provide a valid IPv6 Prefix"
  110. [advanced.ipv6.ip6_addr]
  111. ask = "IPv6"
  112. type = "string"
  113. optional = true
  114. example = "2001:db8:42::2"
  115. help = "If no IPv6 address is pushed directly by your VPN provider, you can indicate a specific IP to use here."
  116. pattern.regexp = "^[0-9a-fA-F:]+$"
  117. pattern.error = "Please provide a valid IPv6"