Files
web-installer/install.html
hael e0f4ee5917
All checks were successful
continuous-integration/drone/push Build is passing
LOCAL_BACKEND default no
2025-03-12 08:42:59 +01:00

237 lines
8.2 KiB
HTML

<!doctype html>
<html lang="en">
<head>
<!-- Required meta tags -->
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
<title>INSTALLER TOOL</title>
<!-- Bootstrap CSS -->
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@4.2.1/dist/css/bootstrap.min.css" integrity="sha384-GJzZqFGwb1QTTN6wy59ffF1BuGJpLSa9DkKMp0DgiMDm4iYMj70gZWKYbI706tWS" crossorigin="anonymous">
<!-- Custom styles for this template -->
<link href="installer.css?t=3" rel="stylesheet">
</head>
<body id="installer" class="text-center">
<div class="container-fluid">
<div class="col-md-12">
<form class="form-install" action="install.php" method="post">
<h1>No any previous deployed environment found</h1>
<fieldset>
<legend>Base settings</legend>
<div class="row">
<div class="mb-3">
<label for="user_auth">User auth (homeguard) enable?</label>
<select class="custom-select d-block w-100" name="USER_AUTH" id="user_auth">
<option value="yes">Yes</option>
<option value="no" selected>No</option>
</select>
</div>
</div>
<div id="div_user_auth" class="hidden">
<div class="row">
<div class="mb-3">
<label for="auth_username">Username:</label>
<input type="text" class="form-control" name="AUTH_USERNAME" id="auth_username" value="" maxlength="20" size="20">
</div>
</div>
<div class="row">
<div class="mb-3">
<label for="auth_password">Password:</label>
<input type="text" class="form-control" name="AUTH_PASSWORD" id="auth_password" value="" maxlength="20" size="20">
</div>
</div>
<div class="row">
<div class="mb-3">
<label for="auth_role">Role:</label>
<select class="custom-select d-block w-100" name="AUTH_ROLE" id="auth_role">
<option value="admin">Admin</option>
</select>
</div>
</div>
</div>
<div class="row">
<div class="mb-3">
<label for="vpn">Proxy enable?</label>
<select class="custom-select d-block w-100" name="VPN_PROXY" id="vpn">
<option value="yes">Yes</option>
<option value="no" selected>No</option>
</select>
</div>
</div>
<div id="div_vpn" class="hidden">
<div class="row">
<div class="mb-3">
<label for="vpn_domain">Please add domain url to download the VPN hash from (default: https://portal.safebox.network):</label>
<input type="text" class="form-control" name="VPN_DOMAIN" id="vpn_domain" value="https://portal.safebox.network">
<div class="invalid-feedback">
Please enter a valid domain.
</div>
</div>
</div>
<div class="row">
<div class="mb-3">
<label for="vpn_pass">Please type in the generated VPN passkey (8 digits):</label>
<input type="text" class="form-control" name="VPN_PASS" id="vpn_pass" value="" maxlength="8" size="10">
</div>
</div>
<div class="row">
<div class="mb-3">
<label for="letsencrypt_mail">Please add the letsencrypt mail address:</label>
<input type="email" class="form-control" name="LETSENCRYPT_MAIL" id="letsencrypt_mail" value="">
<div class="invalid-feedback">
Please enter a valid email.
</div>
</div>
</div>
<div class="row">
<div class="mb-3">
<label for="letsencrypt_servername">Please add letsencrypt server name (default is letsencrypt but you can add zerossl too):</label>
<input type="text" class="form-control" name="LETSENCRYPT_SERVERNAME" id="letsencrypt_servername" value="letsencrypt">
</div>
</div>
</div>
<div class="row">
<div class="mb-3">
<label for="disagnostic">Diagnostic mode enable?</label>
<select class="custom-select d-block w-100" name="DIAGNOSTIC" id="disagnostic">
<option value="yes">Yes</option>
<option value="no" selected>No</option>
</select>
</div>
</div>
</fieldset>
<fieldset>
<legend><a href="javascript:void()" id="advanced">Advanced settings</a></legend>
<div id="advanced_div" style="display:none">
<div class="row">
<div class="mb-3">
<label for="registry">Please fill in the docker registry name (default:safebox):</label>
<input type="registry" class="form-control" name="DOCKER_REGISTRY_URL" id="registry" value="safebox" required>
<div class="invalid-feedback">
Please enter a valid registry url.
</div>
</div>
</div>
<div class="row">
<div class="mb-3">
<label for="smarthost">Smarthost proxy?</label>
<select class="custom-select d-block w-100" name="SMARTHOST_PROXY" id="smarthost">
<option value="yes" selected>Yes</option>
<option value="no">No</option>
</select>
</div>
</div>
<div id="div_smarthost">
<div class="row">
<div class="mb-3">
<label for="domain">Please fill in the domain name</label>
<input type="domain" class="form-control" name="DOMAIN" id="domain" value="localhost">
<div class="invalid-feedback">
Please enter a valid domain.
</div>
</div>
</div>
<div class="row">
<div class="mb-3">
<label for="local_backend">Would you like to run local backend?</label>
<select class="custom-select d-block w-100" name="LOCAL_BACKEND" id="local_backend">
<option value="yes">Yes</option>
<option value="no" selected>No</option>
</select>
</div>
</div>
</div>
<div class="row">
<div class="mb-3">
<label for="localproxy">Local proxy?</label>
<select class="custom-select d-block w-100" name="LOCAL_PROXY" id="localproxy">
<option value="yes" selected>Yes</option>
<option value="no">No</option>
</select>
</div>
</div>
<div class="row">
<div class="mb-3">
<label for="cron">Cron?</label>
<select class="custom-select d-block w-100" name="CRON" id="cron">
<option value="yes">Yes</option>
<option value="no">No</option>
</select>
</div>
</div>
</div>
</fieldset>
<br>
<button class="btn btn-lg btn-primary btn-block" type="submit">Start install</button>
</form>
</div>
</div>
<br>
<br>
<!-- Optional JavaScript -->
<!-- jQuery first, then Popper.js, then Bootstrap JS -->
<script src="https://code.jquery.com/jquery-3.7.1.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/popper.js@1.14.6/dist/umd/popper.min.js" integrity="sha384-wHAiFfRlMFy6i5SRaxvfOCifBUQy1xHdJ/yoi7FRNXMRBu5WHdZYu1hA6ZOblgut" crossorigin="anonymous"></script>
<script src="https://cdn.jsdelivr.net/npm/bootstrap@4.2.1/dist/js/bootstrap.min.js" integrity="sha384-B0UglyR+jN6CkvvICOB2joaf5I4l3gm9GU6Hc1og6Ls7i6U/mkkaduKaBhlAXv9k" crossorigin="anonymous"></script>
<script>
jQuery(document).ready(function(){
jQuery('#advanced').click(function() {
jQuery('#advanced_div').toggle();
});
jQuery('select#smarthost').change(function() {
if (jQuery(this).val()=='yes') jQuery('#div_smarthost').show();
else jQuery('#div_smarthost').hide();
if (jQuery("#smarthost").val()=='no' && jQuery("#localproxy").val()=='yes') {
alert("Warning! Local proxy will not work without smarthost proxy service.");
}
});
jQuery('select#user_auth').click(function() {
if (jQuery(this).val()=='yes') jQuery('#div_user_auth').show();
else jQuery('#div_user_auth').hide();
});
jQuery('select#vpn').click(function() {
if (jQuery(this).val()=='yes') jQuery('#div_vpn').show();
else jQuery('#div_vpn').hide();
});
jQuery('select#discovery').click(function() {
if (jQuery(this).val()=='yes') jQuery('#div_discover').show();
else jQuery('#div_discover').hide();
});
jQuery('select#additionals').click(function() {
if (jQuery(this).val()=='yes') jQuery('#div_additionals').show();
else jQuery('#div_additionals').hide();
});
jQuery('select#nextcloud').click(function() {
if (jQuery(this).val()=='Y') jQuery('#div_nextcloud').show();
else jQuery('#div_nextcloud').hide();
});
jQuery('select#bitwarden').click(function() {
if (jQuery(this).val()=='Y') jQuery('#div_bitwarden').show();
else jQuery('#div_bitwarden').hide();
});
jQuery('select#bitwarden_smtp').click(function() {
if (jQuery(this).val()=='3') jQuery('#div_bitwarden_smtp').show();
else jQuery('#div_bitwarden_smtp').hide();
});
jQuery('select#guacamole').click(function() {
if (jQuery(this).val()=='Y') jQuery('#div_guacamole').show();
else jQuery('#div_guacamole').hide();
});
jQuery('select#smtp_server').click(function() {
if (jQuery(this).val()=='Y') jQuery('#div_smtp_server').show();
else jQuery('#div_smtp_server').hide();
});
jQuery('select#roundcube').click(function() {
if (jQuery(this).val()=='Y') jQuery('#div_roundcube').show();
else jQuery('#div_roundcube').hide();
});
});
</script>
</body>
</html>