2014-12-26 21:54:36 +00:00
< div class = "config-setup-tool-element" >
2015-01-05 18:01:32 +00:00
< div class = "quay-spinner" ng-if = "!config" > < / div >
2015-01-05 20:18:01 +00:00
< div ng-show = "config && config['SERVER_HOSTNAME']" >
2015-01-08 20:58:35 +00:00
< form id = "configform" name = "configform" >
2015-01-05 18:01:32 +00:00
<!-- Basic Configuration -->
< div class = "co-panel" >
< div class = "co-panel-heading" >
< i class = "fa fa-gears" > < / i > Basic Configuration
2014-12-26 21:54:36 +00:00
< / div >
2015-01-05 18:01:32 +00:00
< div class = "co-panel-body" >
2014-12-26 21:54:36 +00:00
< table class = "config-table" >
< tr >
2015-01-05 18:01:32 +00:00
< td > Enterprise Logo URL:< / td >
2014-12-26 21:54:36 +00:00
< td >
2015-01-05 18:01:32 +00:00
< span class = "config-string-field" binding = "config.ENTERPRISE_LOGO_URL"
2015-01-05 20:18:01 +00:00
placeholder="http://example.com/logo.png">< / span >
2015-01-05 18:01:32 +00:00
< div class = "help-text" >
2015-01-05 20:18:01 +00:00
Enter the full URL to your company's logo.
2015-01-05 18:01:32 +00:00
< / div >
< / td >
< td >
2015-01-05 20:18:01 +00:00
< img class = "registry-logo-preview" ng-src = "{{ config.ENTERPRISE_LOGO_URL }}" >
2014-12-26 21:54:36 +00:00
< / td >
< / tr >
2015-01-05 18:01:32 +00:00
< tr >
< td class = "non-input" > Contact Information:< / td >
< td colspan = "2" >
2015-01-05 22:10:01 +00:00
< span class = "config-contacts-field" binding = "config.CONTACT_INFO" > < / span >
2015-01-05 18:01:32 +00:00
< div class = "help-text" style = "margin-top: 10px;" >
Information to show in the Contact Page. If none specified, CoreOS contact information
is displayed.
< / div >
< / td >
< / tr >
2014-12-26 21:54:36 +00:00
< tr >
2015-01-05 18:01:32 +00:00
< td > User Creation:< / td >
2015-01-05 20:18:01 +00:00
< td colspan = "2" >
2015-01-05 18:01:32 +00:00
< div class = "co-checkbox" >
< input id = "ftuc" type = "checkbox" ng-model = "config.FEATURE_USER_CREATION" >
2015-01-05 20:18:01 +00:00
< label for = "ftuc" > Enable Open User Creation< / label >
2015-01-05 18:01:32 +00:00
< / div >
< div class = "help-text" >
2015-01-05 20:18:01 +00:00
If enabled, user accounts can be created by anyone.
Users can always be created in the users panel under this superuser view.
2015-01-05 18:01:32 +00:00
< / div >
2014-12-26 21:54:36 +00:00
< / td >
< / tr >
2015-01-05 18:01:32 +00:00
< / table >
< / div >
< / div >
<!-- Server Configuration -->
< div class = "co-panel" >
< div class = "co-panel-heading" >
< i class = "fa fa-cloud" > < / i > Server Configuration
< / div >
< div class = "co-panel-body" >
< table class = "config-table" >
< tr >
2015-01-05 20:18:01 +00:00
< td > Server Hostname:< / td >
2014-12-26 21:54:36 +00:00
< td >
2015-01-05 18:01:32 +00:00
< span class = "config-string-field" binding = "config.SERVER_HOSTNAME"
placeholder="Hostname (and optional port if non-standard)">< / span >
< div class = "help-text" >
The HTTP host (and optionally the port number if a non-standard HTTP/HTTPS port) of the location
where the registry will be accessible on the network
< / div >
2014-12-26 21:54:36 +00:00
< / td >
< / tr >
2015-01-05 18:01:32 +00:00
< tr >
< td > SSL:< / td >
2014-12-26 21:54:36 +00:00
< td >
2015-01-05 18:01:32 +00:00
< div class = "co-checkbox" >
< input id = "enable-ssl" type = "checkbox" ng-model = "config.PREFERRED_URL_SCHEME"
ng-true-value="https" ng-false-value="http">
< label for = "enable-ssl" > Enable SSL< / label >
< / div >
< div class = "help-text" style = "margin-bottom: 10px" >
A valid SSL certificate and private key files are required to use this option.
< / div >
2015-01-08 20:58:35 +00:00
< table class = "config-table" ng-if = "config.PREFERRED_URL_SCHEME == 'https'" >
2015-01-05 18:01:32 +00:00
< tr >
< td class = "non-input" > Certificate:< / td >
< td >
< span class = "config-file-field" filename = "ssl.cert" > < / span >
< div class = "help-text" >
The certificate must be in PEM format.
< /div
< / td >
< / tr >
< tr >
< td class = "non-input" > Private key:< / td >
< td >
< span class = "config-file-field" filename = "ssl.key" > < / span >
< / td >
< / tr >
< / table >
2014-12-26 21:54:36 +00:00
< / td >
< / tr >
2015-01-05 18:01:32 +00:00
< / table >
< / div >
< / div >
2014-12-26 21:54:36 +00:00
2015-01-05 18:01:32 +00:00
<!-- Redis -->
< div class = "co-panel" >
< div class = "co-panel-heading" >
< img src = "/static/img/redis-small.png" > redis
< / div >
< div class = "co-panel-body" >
< div class = "description" >
< p > A < a href = "http://redis.io" target = "_blank" > redis< / a > key-value store is required for real-time events and build logs.< / p >
< / div >
< table class = "config-table" >
< tr >
2015-01-05 20:18:01 +00:00
< td > Redis Hostname:< / td >
2014-12-26 21:54:36 +00:00
< td >
2015-01-05 20:18:01 +00:00
< span class = "config-string-field" binding = "mapped.redis.host"
2015-01-05 18:01:32 +00:00
placeholder="The redis server hostname">< / span >
2014-12-26 21:54:36 +00:00
< / td >
< / tr >
2015-01-05 18:01:32 +00:00
< tr >
< td > Redis port:< / td >
2014-12-26 21:54:36 +00:00
< td >
2015-01-05 18:01:32 +00:00
< span class = "config-numeric-field" binding = "mapped.redis.port" default-value = "6379" > < / span >
< div class = "help-text" >
Access to this port and hostname must be allowed from all hosts running
the enterprise registry
< / div >
2014-12-26 21:54:36 +00:00
< / td >
< / tr >
2015-01-05 18:01:32 +00:00
< tr >
< td > Redis password:< / td >
2014-12-26 21:54:36 +00:00
< td >
2015-01-05 20:18:01 +00:00
< input class = "form-control" type = "password" ng-model = "mapped.redis.password"
placeholder="Optional password for connecting to redis">
2014-12-26 21:54:36 +00:00
< / td >
< / tr >
2015-01-05 18:01:32 +00:00
< / table >
< / div >
< / div > <!-- /Redis -->
<!-- Registry Storage -->
< div class = "co-panel" >
< div class = "co-panel-heading" >
< i class = "fa fa-download" > < / i > Registry Storage
< / div >
< div class = "co-panel-body" >
< div class = "description" >
< p >
Registry images can be stored either locally or in a remote storage system.
< strong > A remote storage system is required for high-avaliability systems.< / strong >
< / p >
< table class = "config-table" >
< tr >
< td class = "non-input" > Storage Engine:< / td >
< td >
< select ng-model = "config.DISTRIBUTED_STORAGE_CONFIG.local[0]" >
< option value = "LocalStorage" > Locally mounted directory< / option >
< option value = "S3Storage" > Amazon S3< / option >
< option value = "GoogleCloudStorage" > Google Cloud Storage< / option >
< option value = "RadosGWStorage" > Ceph Object Gateway (RADOS)< / option >
< / select >
< / td >
< / tr >
2015-01-07 21:20:51 +00:00
<!-- Fields -->
< tr ng-repeat = "field in STORAGE_CONFIG_FIELDS[config.DISTRIBUTED_STORAGE_CONFIG.local[0]]" >
< td > {{ field.title }}:< / td >
2015-01-05 18:01:32 +00:00
< td >
< span class = "config-string-field"
2015-01-07 21:20:51 +00:00
binding="config.DISTRIBUTED_STORAGE_CONFIG.local[1][field.name]"
placeholder="{{ field.placeholder }}"
ng-if="field.kind == 'text'">< / span >
< div class = "co-checkbox" ng-if = "field.kind == 'bool'" >
< input id = "dsc-{{ field.name }}" type = "checkbox"
ng-model="config.DISTRIBUTED_STORAGE_CONFIG.local[1][field.name]">
< label for = "dsc-{{ field.name }}" > {{ field.placeholder }}< / label >
2015-01-05 18:01:32 +00:00
< / div >
2015-01-07 21:20:51 +00:00
< div class = "help-text" ng-if = "field.help_url" >
See < a href = "{{ field.help_url }}" target = "_blank" > Documentation< / a > for more information
2015-01-05 18:01:32 +00:00
< / div >
< / td >
< / tr >
< / table >
< / div >
< / div >
< / div >
<!-- E - mail -->
< div class = "co-panel" >
< div class = "co-panel-heading" >
< i class = "fa fa-envelope" > < / i > E-mail
< / div >
< div class = "co-panel-body" >
< div class = "description" >
< p > Valid e-mail server configuration is required for notification e-mails and the ability of
users to reset their passwords.< / p >
< / div >
< div class = "co-checkbox" >
< input id = "ftmail" type = "checkbox" ng-model = "config.FEATURE_MAILING" >
< label for = "ftmail" > Enable E-mails< / label >
< / div >
2015-01-08 20:58:35 +00:00
< table class = "config-table" ng-if = "config.FEATURE_MAILING" >
2015-01-05 18:01:32 +00:00
< tr >
< td > SMTP Server:< / td >
2014-12-26 21:54:36 +00:00
< td >
2015-01-05 18:01:32 +00:00
< span class = "config-string-field" binding = "config.MAIL_SERVER"
placeholder="SMTP server for sending e-mail">< / span >
2014-12-26 21:54:36 +00:00
< / td >
< / tr >
2015-01-05 18:01:32 +00:00
< tr >
< td > SMTP Server Port:< / td >
2014-12-26 21:54:36 +00:00
< td >
2015-01-05 18:01:32 +00:00
< span class = "config-numeric-field" binding = "config.MAIL_PORT"
default-value="587">< / span >
2014-12-26 21:54:36 +00:00
< / td >
< / tr >
2015-01-05 18:01:32 +00:00
< tr >
< td > TLS:< / td >
2014-12-26 21:54:36 +00:00
< td >
2015-01-05 18:01:32 +00:00
< div class = "co-checkbox" >
< input id = "mut" type = "checkbox" ng-model = "config.MAIL_USE_TLS" >
< label for = "mut" > Use TLS< / label >
2014-12-26 21:54:36 +00:00
< / div >
< / td >
< / tr >
2015-01-05 18:01:32 +00:00
< tr >
< td > Mail Sender:< / td >
2014-12-26 21:54:36 +00:00
< td >
2015-01-05 18:01:32 +00:00
< span class = "config-string-field" binding = "config.DEFAULT_MAIL_SENDER"
placeholder="E-mail address">< / span >
< div class = "help-text" >
E-mail address from which all e-mails are sent. If not specified,
< code > support@quay.io< / code > will be used.
< / div >
2014-12-26 21:54:36 +00:00
< / td >
< / tr >
2015-01-05 18:01:32 +00:00
< tr >
< td > Authentication:< / td >
2014-12-26 21:54:36 +00:00
< td >
2015-01-05 18:01:32 +00:00
< div class = "co-checkbox" >
< input id = "uma" type = "checkbox" ng-model = "config.MAIL_USE_AUTH" >
< label for = "uma" > Requires Authentication< / label >
< / div >
2015-01-08 20:58:35 +00:00
< table class = "config-table" ng-if = "config.MAIL_USE_AUTH" >
2015-01-05 18:01:32 +00:00
< tr >
< td > Username:< / td >
< td >
< span class = "config-string-field" binding = "config.MAIL_USERNAME"
placeholder="Username for authentication">< / span >
< / td >
< / tr >
< tr >
< td > Password:< / td >
< td >
2015-01-07 21:20:51 +00:00
< input class = "form-control" type = "password"
ng-model="config.MAIL_PASSWORD"
2015-01-05 18:01:32 +00:00
placeholder="Password for authentication">< / span >
< / td >
< / tr >
< / table >
2014-12-26 21:54:36 +00:00
< / td >
< / tr >
2015-01-05 18:01:32 +00:00
< / table >
2014-12-26 21:54:36 +00:00
< / div >
2015-01-05 18:01:32 +00:00
< / div > <!-- /E - mail -->
2014-12-26 21:54:36 +00:00
2015-01-05 18:01:32 +00:00
<!-- Authentication -->
< div class = "co-panel" >
< div class = "co-panel-heading" >
< i class = "fa fa-users" > < / i > Authentication
2014-12-26 21:54:36 +00:00
< / div >
2015-01-05 18:01:32 +00:00
< div class = "co-panel-body" >
< div class = "description" >
< p >
Authentication for the registry can be handled by either the registry itself or LDAP.
External authentication providers (such as Github) can be used on top of this choice.
< / p >
< / div >
2014-12-26 21:54:36 +00:00
2015-01-05 18:01:32 +00:00
< table class = "config-table" >
< tr >
< td class = "non-input" > Authentication:< / td >
< td >
< select ng-model = "config.AUTHENTICATION_TYPE" >
< option value = "Database" > Local Database< / option >
< option value = "LDAP" > LDAP< / option >
< / select >
< / td >
< / tr >
< / table >
2014-12-26 21:54:36 +00:00
2015-01-08 20:58:35 +00:00
< table class = "config-table" ng-if = "config.AUTHENTICATION_TYPE == 'LDAP'" >
2015-01-05 18:01:32 +00:00
< tr >
< td > LDAP URI:< / td >
< td > < span class = "config-string-field" binding = "config.LDAP_URI" > < / span > < / td >
< / tr >
< tr >
< td > Administrator DN:< / td >
< td > < span class = "config-string-field" binding = "config.LDAP_ADMIN_DN" > < / span > < / td >
< / tr >
< tr >
< td > Base DN:< / td >
< td > < span class = "config-list-field" item-title = "DN" binding = "config.LDAP_BASE_DN" > < / span > < / td >
< / tr >
< tr >
< td > Administrator Password:< / td >
< td > < span class = "config-string-field" binding = "config.LDAP_ADMIN_PASSWD" > < / span > < / td >
< / tr >
< tr >
< td > E-mail Attribute:< / td >
< td > < span class = "config-string-field" binding = "config.LDAP_EMAIL_ATTR" > < / span > < / td >
< / tr >
< tr >
< td > UID Attribute:< / td >
< td > < span class = "config-string-field" binding = "config.LDAP_UID_ATTR" > < / span > < / td >
< / tr >
< tr >
< td > User RDN:< / td >
< td > < span class = "config-list-field" item-title = "RDN" binding = "config.LDAP_USER_RDN" > < / span > < / td >
< / tr >
< / table >
2014-12-26 21:54:36 +00:00
< / div >
2015-01-05 18:01:32 +00:00
< / div > <!-- /Authentication -->
2014-12-26 21:54:36 +00:00
2015-01-05 18:01:32 +00:00
<!-- Github Authentication -->
< div class = "co-panel" >
< div class = "co-panel-heading" >
< i class = "fa fa-github" > < / i > Github (Enterprise) Authentication
2014-12-26 21:54:36 +00:00
< / div >
2015-01-05 18:01:32 +00:00
< div class = "co-panel-body" >
< div class = "description" >
< p >
If enabled, users can use Github or Github Enterprise to authenticate to the registry.
< / p >
< p >
< strong > Note:< / strong > A registered Github (Enterprise) OAuth application is required.
View instructions on how to
< a href = "https://coreos.com/docs/enterprise-registry/github-auth/" target = "_blank" >
Create an OAuth Application in GitHub
< / a >
< / p >
< / div >
< div class = "co-checkbox" >
< input id = "ftghl" type = "checkbox" ng-model = "config.FEATURE_GITHUB_LOGIN" >
< label for = "ftghl" > Enable Github Authentication< / label >
< / div >
2015-01-08 20:58:35 +00:00
< table class = "config-table" ng-if = "config.FEATURE_GITHUB_LOGIN" >
2015-01-05 18:01:32 +00:00
< tr >
2015-01-05 20:18:01 +00:00
< td > Github:< / td >
2015-01-05 18:01:32 +00:00
< td >
2015-01-05 20:18:01 +00:00
< select ng-model = "mapped.GITHUB_LOGIN_KIND" >
< option value = "hosted" > Github.com< / option >
< option value = "enterprise" > Github Enterprise< / option >
< / select >
2015-01-05 18:01:32 +00:00
< / td >
< / tr >
2015-01-08 20:58:35 +00:00
< tr ng-if = "mapped.GITHUB_LOGIN_KIND == 'enterprise'" >
2015-01-05 20:18:01 +00:00
< td > Github Endpoint:< / td >
2015-01-05 18:01:32 +00:00
< td >
2015-01-08 18:26:24 +00:00
< span class = "config-string-field"
binding="config.GITHUB_LOGIN_CONFIG.GITHUB_ENDPOINT"
placeholder="https://my.githubserver"
pattern="https?://([a-zA-Z0-9]+\.?\/?)+">
2015-01-05 18:01:32 +00:00
< / span >
< div class = "help-text" >
2015-01-08 18:26:24 +00:00
The Github Enterprise endpoint. Must start with http:// or https://.
2015-01-05 18:01:32 +00:00
< / div >
< / td >
< / tr >
< tr >
< td > OAuth Client ID:< / td >
< td >
< span class = "config-string-field" binding = "config.GITHUB_LOGIN_CONFIG.CLIENT_ID" >
< / span >
< / td >
< / tr >
< tr >
< td > OAuth Client Secret:< / td >
< td >
< span class = "config-string-field" binding = "config.GITHUB_LOGIN_CONFIG.CLIENT_SECRET" >
< / span >
< / td >
< / tr >
< / table >
2014-12-26 21:54:36 +00:00
< / div >
2015-01-05 18:01:32 +00:00
< / div > <!-- /Github Authentication -->
2014-12-26 21:54:36 +00:00
2015-01-05 18:01:32 +00:00
<!-- Google Authentication -->
< div class = "co-panel" >
< div class = "co-panel-heading" >
< i class = "fa fa-google" > < / i > Google Authentication
2014-12-26 21:54:36 +00:00
< / div >
2015-01-05 18:01:32 +00:00
< div class = "co-panel-body" >
< div class = "description" >
< p >
If enabled, users can use Google to authenticate to the registry.
< / p >
< p >
< strong > Note:< / strong > A registered Google OAuth application is required.
Visit the
< a href = "https://console.developers.google.com" target = "_blank" >
Google Developer Console
< / a >
to register an application.
< / p >
< / div >
< div class = "co-checkbox" >
< input id = "ftgoa" type = "checkbox" ng-model = "config.FEATURE_GOOGLE_LOGIN" >
< label for = "ftgoa" > Enable Google Authentication< / label >
< / div >
2015-01-08 20:58:35 +00:00
< table class = "config-table" ng-if = "config.FEATURE_GOOGLE_LOGIN" >
2015-01-05 18:01:32 +00:00
< tr >
< td > OAuth Client ID:< / td >
< td >
< span class = "config-string-field" binding = "config.GOOGLE_LOGIN_CONFIG.CLIENT_ID" >
< / span >
< / td >
< / tr >
< tr >
< td > OAuth Client Secret:< / td >
< td >
< span class = "config-string-field" binding = "config.GOOGLE_LOGIN_CONFIG.CLIENT_SECRET" >
< / span >
< / td >
< / tr >
< / table >
2015-01-07 21:20:51 +00:00
< / div >
< / div > <!-- /Google Authentication -->
2014-12-26 21:54:36 +00:00
2015-01-07 21:20:51 +00:00
<!-- Build Support -->
< div class = "co-panel" >
< div class = "co-panel-heading" >
< i class = "fa fa-tasks" > < / i > Dockerfile Build Support
< / div >
< div class = "co-panel-body" >
< div class = "description" >
If enabled, users can submit Dockerfiles to be built and pushed by the Enterprise Registry.
< / div >
2014-12-26 21:54:36 +00:00
2015-01-07 21:20:51 +00:00
< div class = "co-checkbox" >
< input id = "ftbs" type = "checkbox" ng-model = "config.FEATURE_BUILD_SUPPORT" >
< label for = "ftbs" > Enable Dockerfile Build< / label >
< / div >
< div ng-if = "config.FEATURE_BUILD_SUPPORT" style = "margin-top: 10px" >
< strong > Note: Build workers are required for this feature.< / strong >
See < a href = "https://coreos.com/docs/enterprise-registry/build-support/" target = "_blank" > Adding Build Workers< / a > for instructions on how to setup build workers.
2015-01-05 18:01:32 +00:00
< / div >
2014-12-26 21:54:36 +00:00
< / div >
2015-01-07 21:20:51 +00:00
< / div > <!-- /Build Support -->
2014-12-26 21:54:36 +00:00
2015-01-05 18:01:32 +00:00
<!-- Github Trigger -->
2015-01-08 20:58:35 +00:00
< div class = "co-panel" ng-if = "config.FEATURE_BUILD_SUPPORT" style = "margin-top: 20px;" >
2015-01-05 18:01:32 +00:00
< div class = "co-panel-heading" >
< i class = "fa fa-github" > < / i > Github (Enterprise) Build Triggers
2014-12-26 21:54:36 +00:00
< / div >
2015-01-05 18:01:32 +00:00
< div class = "co-panel-body" >
< div class = "description" >
< p >
If enabled, users can setup Github or Github Enterprise triggers to invoke Registry builds.
< / p >
< p >
< strong > Note:< / strong > A registered Github (Enterprise) OAuth application (< strong > separate from Github Authentication< / strong > ) is required.
View instructions on how to
< a href = "https://coreos.com/docs/enterprise-registry/github-auth/" target = "_blank" >
Create an OAuth Application in GitHub
< / a >
< / p >
< / div >
< div class = "co-checkbox" >
< input id = "ftgb" type = "checkbox" ng-model = "config.FEATURE_GITHUB_BUILD" >
< label for = "ftgb" > Enable Github Triggers< / label >
< / div >
2015-01-08 20:58:35 +00:00
< table class = "config-table" ng-if = "config.FEATURE_GITHUB_BUILD" >
2015-01-05 18:01:32 +00:00
< tr >
2015-01-05 20:18:01 +00:00
< td > Github:< / td >
2015-01-05 18:01:32 +00:00
< td >
2015-01-05 20:18:01 +00:00
< select ng-model = "mapped.GITHUB_TRIGGER_KIND" >
< option value = "hosted" > Github.com< / option >
< option value = "enterprise" > Github Enterprise< / option >
< / select >
2015-01-05 18:01:32 +00:00
< / td >
< / tr >
2015-01-08 20:58:35 +00:00
< tr ng-if = "mapped.GITHUB_TRIGGER_KIND == 'enterprise'" >
2015-01-05 20:18:01 +00:00
< td > Github Endpoint:< / td >
2015-01-05 18:01:32 +00:00
< td >
2015-01-08 18:26:24 +00:00
< span class = "config-string-field"
binding="config.GITHUB_TRIGGER_CONFIG.GITHUB_ENDPOINT"
placeholder="https://my.githubserver"
pattern="https?://([a-zA-Z0-9]+\.?\/?)+">
2015-01-05 18:01:32 +00:00
< / span >
< div class = "help-text" >
2015-01-08 18:26:24 +00:00
The Github Enterprise endpoint. Must start with http:// or https://.
2015-01-05 18:01:32 +00:00
< / div >
< / td >
< / tr >
< tr >
< td > OAuth Client ID:< / td >
< td >
< span class = "config-string-field" binding = "config.GITHUB_TRIGGER_CONFIG.CLIENT_ID" >
< / span >
< / td >
< / tr >
< tr >
< td > OAuth Client Secret:< / td >
< td >
< span class = "config-string-field" binding = "config.GITHUB_TRIGGER_CONFIG.CLIENT_SECRET" >
< / span >
< / td >
< / tr >
< / table >
2014-12-26 21:54:36 +00:00
< / div >
2015-01-05 18:01:32 +00:00
< / div > <!-- /Github Trigger -->
2015-01-08 20:58:35 +00:00
< / form >
2015-01-07 21:20:51 +00:00
<!-- Save Bar -->
< div class = "cor-floating-bottom-bar" >
< button class = "btn" ng-class = "mapped.$hasChanges ? 'btn-primary' : 'btn-success'"
2015-01-08 20:58:35 +00:00
ng-click="checkValidateAndSave()" ng-show="configform.$valid">
2015-01-07 21:20:51 +00:00
< i class = "fa fa-lg" ng-class = "mapped.$hasChanges ? 'fa-dot-circle-o' : 'fa-check-circle'" > < / i >
< span ng-if = "mapped.$hasChanges" > Save Configuration Changes< / span >
< span ng-if = "!mapped.$hasChanges" > Configuration Saved< / span >
< / button >
2015-01-08 20:58:35 +00:00
< button class = "btn btn-warning" ng-click = "checkValidateAndSave()" ng-show = "!configform.$valid"
ng-click="checkValidateAndSave()">
< i class = "fa fa-lg fa-sort" > < / i >
{{ configform.$error['required'].length }} configuration field< span ng-show = "configform.$error['required'].length != 1" > s< / span > remaining
< / button >
2015-01-07 21:20:51 +00:00
< / div >
<!-- Modal message dialog -->
< div class = "modal fade initial-setup-modal" id = "validateAndSaveModal" >
< div class = "modal-dialog" >
< div class = "modal-content" >
< div class = "modal-header" >
< h4 class = "modal-title"
ng-show="mapped.$hasChanges & & validationStatus(validating) == 'validating'">
2015-01-08 20:27:49 +00:00
Validating Configuration...
2015-01-07 21:20:51 +00:00
< / h4 >
< h4 class = "modal-title"
ng-show="mapped.$hasChanges & & validationStatus(validating) == 'failed'">
< i class = "fa fa-warning" > < / i > Configuration Validation Failed
< / h4 >
< h4 class = "modal-title"
ng-show="mapped.$hasChanges & & validationStatus(validating) == 'success'">
< i class = "fa fa-check-circle" > < / i > Configuration Validation Succeeded!
< / h4 >
< h4 class = "modal-title" ng-show = "!mapped.$hasChanges" >
Configuration Changes Saved
< / h4 >
< / div >
< div class = "modal-body" ng-show = "!mapped.$hasChanges" >
< div class = "verified" >
< i class = "fa fa-check-circle" > < / i > Configuration Changes Saved
< / div >
< p > Your configuration changes have been saved and will be applied the next time the < span class = "registry-title" > < / span > container is restarted.< / p >
< p >
< strong >
It is highly recommended that you restart your container now and test these changes!
< / strong >
< / p >
< / div >
< div class = "modal-body" ng-show = "mapped.$hasChanges" >
< div class = "service-verification" >
< div class = "service-verification-row" ng-repeat = "serviceInfo in validating" >
< span class = "quay-spinner" ng-show = "serviceInfo.status == 'validating'" > < / span >
< i class = "fa fa-lg fa-check-circle" ng-show = "serviceInfo.status == 'success'" > < / i >
< i class = "fa fa-lg fa-warning" ng-show = "serviceInfo.status == 'error'" > < / i >
< span class = "service-title" > {{ serviceInfo.service.title }}< / span >
< div class = "service-verification-error" ng-show = "serviceInfo.status == 'error'" > {{ serviceInfo.errorMessage }}< / div >
< / div >
< / div >
< / div >
< div class = "modal-footer" ng-show = "!mapped.$hasChanges" >
< button class = "btn btn-default" data-dismiss = "modal" >
Close
< / button >
< / div >
< div class = "modal-footer" ng-show = "mapped.$hasChanges" >
< span ng-show = "validating.length == 0" > Please Wait...< / span >
2015-01-08 20:27:49 +00:00
< button class = "btn btn-default"
ng-show="validationStatus(validating) == 'validating'"
ng-click="cancelValidation()">
Stop Validating
< / button >
2015-01-07 21:20:51 +00:00
< button class = "btn btn-primary"
ng-show="validationStatus(validating) == 'success'"
ng-click="saveConfiguration()"
ng-disabled="savingConfiguration">
< i class = "fa fa-upload" style = "margin-right: 10px;" > < / i > Save Configuration
< / button >
< button class = "btn btn-default"
ng-show="validationStatus(validating) == 'failed'"
data-dismiss="modal">
Continue Editing Configuration
< / button >
< / div >
< / div > <!-- /.modal - content -->
< / div > <!-- /.modal - dialog -->
< / div > <!-- /.modal -->
2015-01-05 18:01:32 +00:00
< / div >
2014-12-26 21:54:36 +00:00
< / div >