2018-01-22 13:01:38 -08:00
<!DOCTYPE html>
< html >
< head >
< meta charset = "utf-8" / >
< meta name = "viewport" content = "user-scalable=no, initial-scale=1, maximum-scale=1, minimum-scale=1, width=device-width, height=device-height" / >
< title > Cloudron Restore < / title >
2018-04-10 14:49:49 +02:00
< link id = "favicon" href = "/api/v1/cloudron/avatar" rel = "icon" type = "image/png" >
2018-01-22 13:01:38 -08:00
<!-- Theme CSS -->
2018-04-10 14:49:49 +02:00
< link type = "text/css" rel = "stylesheet" href = "/theme.css" >
2018-01-22 13:01:38 -08:00
<!-- Custom Fonts -->
2018-11-15 17:42:29 +01:00
< link type = "text/css" rel = "stylesheet" href = "/3rdparty/fontawesome/css/all.min.css" >
2018-01-22 13:01:38 -08:00
<!-- jQuery -->
2018-04-10 14:49:49 +02:00
< script type = "text/javascript" src = "/3rdparty/js/jquery.min.js" > < / script >
2018-01-22 13:01:38 -08:00
<!-- Bootstrap Core JavaScript -->
2018-04-10 14:49:49 +02:00
< script type = "text/javascript" src = "/3rdparty/js/bootstrap.min.js" > < / script >
2018-01-22 13:01:38 -08:00
<!-- Angularjs scripts -->
2018-04-10 14:49:49 +02:00
< script type = "text/javascript" src = "/3rdparty/js/angular.min.js" > < / script >
< script type = "text/javascript" src = "/3rdparty/js/angular-loader.min.js" > < / script >
< script type = "text/javascript" src = "/3rdparty/js/angular-md5.min.js" > < / script >
2019-01-07 17:23:26 +01:00
< script type = "text/javascript" src = "/3rdparty/js/angular-ui-notification.js" > < / script >
2018-04-10 14:49:49 +02:00
< script type = "text/javascript" src = "/3rdparty/js/autofill-event.js" > < / script >
2018-01-22 13:01:38 -08:00
<!-- Angular directives for tldjs -->
2018-04-10 14:49:49 +02:00
< script type = "text/javascript" src = "/3rdparty/js/tld.js" > < / script >
2018-01-22 13:01:38 -08:00
2019-11-11 11:07:52 -08:00
<!-- Angular directives for bootstrap https://angular - ui.github.io/bootstrap/ -->
< script type = "text/javascript" src = "/3rdparty/js/ui-bootstrap-tpls-1.3.3.min.js" > < / script >
2018-01-22 13:01:38 -08:00
<!-- Setup Application -->
2018-04-10 14:49:49 +02:00
< script type = "text/javascript" src = "/js/restore.js" > < / script >
2018-01-22 13:01:38 -08:00
< / head >
< body class = "setup" ng-app = "Application" ng-controller = "RestoreController" >
2019-09-06 00:14:05 +02:00
< a class = "offline-banner animateMe" ng-show = "client.offline" ng-cloak href = "https://cloudron.io/documentation/troubleshooting/" target = "_blank" > < i class = "fa fa-circle-notch fa-spin" > < / i > Cloudron is offline. Reconnecting...< / a >
2019-09-05 22:22:42 +02:00
2018-01-22 13:01:38 -08:00
< div class = "main-container ng-cloak text-center" ng-show = "busy" >
< div class = "row" >
< div class = "col-md-6 col-md-offset-3" >
2018-11-16 17:03:21 +01:00
< i class = "fa fa-circle-notch fa-spin fa-5x" > < / i > < br / >
2018-12-15 16:08:44 -08:00
< h3 > {{ message }} ...< / h3 >
2018-01-22 13:01:38 -08:00
< / div >
< / div >
< / div >
< div class = "main-container ng-cloak" ng-show = "initialized && !busy" >
< div class = "row" >
< div class = "col-md-6 col-md-offset-3" >
< div class = "card" style = "max-width: none; padding: 20px;" >
< form name = "configureBackupForm" role = "form" novalidate ng-submit = "restore()" autocomplete = "off" >
< div class = "row" >
< div class = "col-md-10 col-md-offset-1 text-center" >
< h2 > Cloudron Restore< / h2 >
< p > Provide the backup to restore from< / p >
< br / >
< / div >
< / div >
< div class = "row" >
2018-06-04 20:35:26 -07:00
< div class = "col-md-8 col-md-offset-2" >
2018-01-22 13:01:38 -08:00
< p class = "has-error text-center" ng-show = "error" > {{ error.generic }}< / p >
< div class = "form-group" >
2019-12-18 14:29:42 -08:00
< label class = "control-label" for = "storageProviderProvider" > Storage provider < sup > < a ng-href = "{{ config.webServerOrigin }}/documentation/backups/#storage-providers" class = "help" target = "_blank" > < i class = "fa fa-question-circle" > < / i > < / a > < / sup > < / label >
2018-01-22 13:01:38 -08:00
< select class = "form-control" id = "storageProviderProvider" ng-model = "provider" ng-options = "a.value as a.name for a in storageProvider" ng-change = clearForm() > < / select >
< / div >
<!-- Filesystem -->
< div class = "form-group" ng-class = "{ 'has-error': error.backupFolder }" ng-show = "provider === 'filesystem'" >
< label class = "control-label" for = "inputConfigureBackupFolder" > Local backup directory< / label >
< input type = "text" class = "form-control" ng-model = "backupFolder" id = "inputConfigureBackupFolder" name = "backupFolder" ng-disabled = "busy" placeholder = "Directory for backups" ng-required = "provider === 'filesystem'" >
< / div >
<!-- S3/Minio/SOS -->
< div class = "form-group" ng-class = "{ 'has-error': error.endpoint }" ng-show = "provider === 'minio' || provider === 's3-v4-compat'" >
< label class = "control-label" for = "inputConfigureBackupEndpoint" > Endpoint< / label >
< input type = "text" class = "form-control" ng-model = "endpoint" id = "inputConfigureBackupEndpoint" name = "endpoint" ng-disabled = "busy" placeholder = "URL of Minio/S3 Compatible" ng-required = "provider === 'minio' || provider === 's3-v4-compat'" >
< / div >
< div class = "checkbox" ng-show = "provider === 'minio' || provider === 's3-v4-compat'" >
< label >
< input type = "checkbox" ng-model = "acceptSelfSignedCerts" id = "inputConfigureBackupSelfSigned" >
Accept Self-signed certificate
< / input >
< / label >
< / div >
< div class = "form-group" ng-class = "{ 'has-error': error.bucket }" ng-show = "s3like(provider) || provider === 'gcs'" >
< label class = "control-label" for = "inputConfigureBackupBucket" > Bucket name< / label >
< input type = "text" class = "form-control" ng-model = "bucket" id = "inputConfigureBackupBucket" name = "bucket" ng-disabled = "busy" ng-required = "s3like(provider)" >
< / div >
< div class = "form-group" ng-class = "{ 'has-error': error.prefix }" ng-show = "s3like(provider) || provider === 'gcs'" >
< label class = "control-label" for = "inputConfigureBackupPrefix" > Prefix< / label >
< input type = "text" class = "form-control" ng-model = "prefix" id = "inputConfigureBackupPrefix" name = "prefix" ng-disabled = "busy" placeholder = "Prefix for backup file names" >
< / div >
< div class = "form-group" ng-class = "{ 'has-error': error.region }" ng-show = "provider === 's3'" >
2018-04-10 18:05:35 +02:00
< label class = "control-label" for = "inputConfigureBackupS3Region" > Region< / label >
< select class = "form-control" name = "region" id = "inputConfigureBackupS3Region" ng-model = "region" ng-options = "a.value as a.name for a in s3Regions" ng-disabled = "busy" ng-required = "provider === 's3'" > < / select >
2018-01-22 13:01:38 -08:00
< / div >
< div class = "form-group" ng-class = "{ 'has-error': error.region }" ng-show = "provider === 'digitalocean-spaces'" >
2018-04-10 18:05:35 +02:00
< label class = "control-label" for = "inputConfigureBackupDORegion" > Region< / label >
< select class = "form-control" name = "region" id = "inputConfigureBackupDORegion" ng-model = "endpoint" ng-options = "a.value as a.name for a in doSpacesRegions" ng-disabled = "busy" ng-required = "provider === 'digitalocean-spaces'" > < / select >
2018-01-22 13:01:38 -08:00
< / div >
2019-01-23 18:04:43 -08:00
< div class = "form-group" ng-class = "{ 'has-error': error.region }" ng-show = "provider === 'exoscale-sos'" >
< label class = "control-label" for = "inputConfigureBackupExoscaleRegion" > Region< / label >
< select class = "form-control" name = "region" id = "inputConfigureBackupExoscaleRegion" ng-model = "endpoint" ng-options = "a.value as a.name for a in exoscaleSosRegions" ng-disabled = "busy" ng-required = "provider === 'exoscale-sos'" > < / select >
< / div >
2019-07-30 10:42:18 -07:00
< div class = "form-group" ng-class = "{ 'has-error': error.region }" ng-show = "provider === 'wasabi'" >
< label class = "control-label" for = "inputConfigureBackupWasabiRegion" > Region< / label >
< select class = "form-control" name = "region" id = "inputConfigureBackupWasabiRegion" ng-model = "endpoint" ng-options = "a.value as a.name for a in wasabiRegions" ng-disabled = "busy" ng-required = "provider === 'wasabi'" > < / select >
< / div >
2019-06-21 11:06:50 -07:00
< div class = "form-group" ng-class = "{ 'has-error': error.region }" ng-show = "provider === 'scaleway-objectstorage'" >
< label class = "control-label" for = "inputConfigureBackupScalewayRegion" > Region< / label >
< select class = "form-control" name = "region" id = "inputConfigureBackupScalewayRegion" ng-model = "endpoint" ng-options = "a.value as a.name for a in scalewayRegions" ng-disabled = "busy" ng-required = "provider === 'scaleway-objectstorage'" > < / select >
< / div >
2018-01-22 13:01:38 -08:00
< div class = "form-group" ng-class = "{ 'has-error': error.accessKeyId }" ng-show = "s3like(provider)" >
< label class = "control-label" for = "inputConfigureBackupAccessKeyId" > Access key id< / label >
< input type = "text" class = "form-control" ng-model = "accessKeyId" id = "inputConfigureBackupAccessKeyId" name = "accessKeyId" ng-disabled = "busy" ng-required = "s3like(provider)" >
< / div >
< div class = "form-group" ng-class = "{ 'has-error': error.secretAccessKey }" ng-show = "s3like(provider)" >
< label class = "control-label" for = "inputConfigureBackupSecretAccessKey" > Secret access key< / label >
< input type = "text" class = "form-control" ng-model = "secretAccessKey" id = "inputConfigureBackupSecretAccessKey" name = "secretAccessKey" ng-disabled = "busy" ng-required = "s3like(provider)" >
< / div >
< div class = "form-group" ng-class = "{ 'has-error': error.gcsKeyInput }" ng-show = "provider === 'gcs'" >
< label class = "control-label" for = "gcsKeyInput" > Service Account Key< / label >
< div class = "input-group" >
< input type = "file" id = "gcsKeyFileInput" style = "display:none" / >
< input type = "text" class = "form-control" placeholder = "Service Account Key" ng-model = "gcsKey.keyFileName" id = "gcsKeyInput" name = "cert" onclick = "getElementById('gcsKeyFileInput').click();" style = "cursor: pointer;" ng-disabled = "busy" ng-required = "provider === 'gcs'" >
< span class = "input-group-addon" >
< i class = "fa fa-upload" onclick = "getElementById('gcsKeyFileInput').click();" > < / i >
< / span >
< / div >
< / div >
< div class = "form-group" ng-show = "provider !== 'noop'" >
< label class = "control-label" for = "storageFormat" > Storage Format< / label >
< select class = "form-control" id = "storageFormat" ng-change = "key = ''" ng-model = "format" ng-options = "a.value as a.name for a in formats" > < / select >
< / div >
< div class = "form-group" ng-class = "{ 'has-error': error.backupId }" >
< label class = "control-label" for = "inputConfigureBackupId" > Backup ID< / label >
< input type = "text" class = "form-control" ng-model = "backupId" name = "inputConfigureBackupId" placeholder = "Backup Id" required ng-disabled = "busy" >
< / div >
2019-09-05 11:38:55 -07:00
< div class = "form-group" ng-class = "{ 'has-error': error.key }" ng-show = "provider !== 'noop'" >
< label class = "control-label" for = "inputConfigureBackupKey" > Encryption key (optional)< / label >
< input type = "text" class = "form-control" ng-model = "key" id = "inputConfigureBackupKey" name = "prefix" ng-disabled = "busy" placeholder = "Passphrase used to encrypt the backups" >
< / div >
2018-01-22 13:01:38 -08:00
< input class = "ng-hide" type = "submit" ng-disabled = "configureBackupForm.$invalid" / >
2019-11-11 11:07:52 -08:00
< div uib-collapse = "!advancedVisible" >
< div class = "form-group" >
2019-12-18 14:29:42 -08:00
< label class = "control-label" > IP Configuration < sup > < a ng-href = "{{ config.webServerOrigin }}/documentation/networking/#ip-configuration" class = "help" target = "_blank" > < i class = "fa fa-question-circle" > < / i > < / a > < / sup > < / label >
2019-11-11 11:07:52 -08:00
< select class = "form-control" ng-model = "sysinfo.provider" ng-options = "a.value as a.name for a in sysinfoProvider" > < / select >
< / div >
<!-- Fixed -->
< div class = "form-group" ng-show = "sysinfo.provider === 'fixed'" ng-class = "{ 'has-error': error.ip }" >
< label class = "control-label" > IP Address< / label >
< input type = "text" class = "form-control" ng-model = "sysinfo.ip" name = "ip" ng-disabled = "sysinfo.busy" ng-required = "sysinfo.provider === 'fixed'" >
< p class = "has-error" ng-show = "error.ip" > {{ error.ip }}< / p >
< / div >
<!-- Network Interface -->
< div class = "form-group" ng-show = "sysinfo.provider === 'network-interface'" ng-class = "{ 'has-error': error.ifname }" >
< label class = "control-label" > Interface Name< / label >
< input type = "text" class = "form-control" ng-model = "sysinfo.ifname" name = "ifname" ng-disabled = "sysinfo.busy" ng-required = "sysinfo.provider === 'network-interface'" >
< p class = "has-error" ng-show = "error.ifname" > {{ error.ifname }}< / p >
< / div >
< / div >
< div class = "text-center" >
< a href = "" ng-click = "advancedVisible = true" ng-hide = "advancedVisible" > Advanced settings...< / a >
< a href = "" ng-click = "advancedVisible = false" ng-show = "advancedVisible" > Hide Advanced settings< / a >
< / div >
2018-01-22 13:01:38 -08:00
< / div >
< / div >
2018-06-04 20:35:26 -07:00
< br / >
2019-11-11 11:07:52 -08:00
2018-01-22 13:01:38 -08:00
< div class = "row" >
< div class = "col-md-12 text-center" >
2018-11-16 17:03:21 +01:00
< button type = "submit" class = "btn btn-primary" ng-disabled = "configureBackupForm.$invalid" / > < i class = "fa fa-circle-notch fa-spin" ng-show = "busy" > < / i > Restore< / button >
2018-01-22 13:01:38 -08:00
< / div >
< / div >
< / form >
< / div >
< / div >
< / div >
< / div >
< footer class = "text-center" >
2020-01-02 16:56:42 -08:00
< span class = "text-muted" > © 2020 < a href = "https://cloudron.io" target = "_blank" > Cloudron< / a > < / span >
2018-02-23 15:53:23 -08:00
< span class = "text-muted" > < a href = "https://forum.cloudron.io" target = "_blank" > Forum < i class = "fa fa-comments" > < / i > < / a > < / span >
2018-01-22 13:01:38 -08:00
< / footer >
< / body >
< / html >