diff --git a/dashboard/api/windc.py b/dashboard/api/windc.py index 16f289b..98b777d 100644 --- a/dashboard/api/windc.py +++ b/dashboard/api/windc.py @@ -51,19 +51,35 @@ def datacenters_get(request, datacenter_id): def datacenters_list(request): return windcclient(request).environments.list() +def datacenters_deploy(request, datacenter_id): + session_id = windcclient(request).sessions.list(datacenter_id)[0].id + return windcclient(request).sessions.deploy(datacenter_id, session_id) def services_create(request, datacenter, parameters): - return windcclient(request).services.create(datacenter, parameters) + LOG.critical("////////////////////////////////") + LOG.critical(parameters) + LOG.critical("////////////////////////////////") + session_id = windcclient(request).sessions.list(datacenter)[0].id + if parameters['service_type'] == 'active directory': + res = windcclient(request).activeDirectories.create(datacenter, session_id, parameters) + else: + res = windcclient(request).webServers.create(datacenter, session_id, parameters) + + return res -def services_list(request, datacenter): - LOG.critical("********************************") - LOG.critical(dir(windcclient(request))) - LOG.critical("********************************") +def services_list(request, datacenter_id): session_id = request.user.token.token['id'] services = [] - services += windcclient(request).activeDirectories.list(datacenter, session_id) - #services += windcclient(request).webServers.list(datacenter) + + sessions = windcclient(request).sessions.list(datacenter_id) + for s in sessions: + if s.state == 'open': + windcclient(request).sessions.delete(datacenter_id, s.id) + + session_id = windcclient(request).sessions.configure(datacenter_id).id + services = windcclient(request).activeDirectories.list(datacenter_id, session_id) + services += windcclient(request).webServers.list(datacenter_id, session_id) return services diff --git a/dashboard/windc/forms.py b/dashboard/windc/forms.py index 7340fb2..37e1751 100644 --- a/dashboard/windc/forms.py +++ b/dashboard/windc/forms.py @@ -38,9 +38,9 @@ LOG = logging.getLogger(__name__) class WizardFormServiceType(forms.Form): service = forms.ChoiceField(label=_("Service Type"), choices=[ - ('active directory', 'Active Directory'), - ('iis', 'Internet Information Services') - ]) + ('active directory', 'Active Directory'), + ('iis', 'Internet Information Services') + ]) class WizardFormConfiguration(forms.Form): @@ -59,21 +59,18 @@ class WizardFormADConfiguration(forms.Form): initial=1) adm_password = forms.CharField(widget=forms.PasswordInput, - label=_("Administrator password"), - required=False) + label=_("Administrator password"), required=False) recovery_password = forms.CharField(widget=forms.PasswordInput, - label=_("Recovery password"), - required=False) - + label=_("Recovery password"), required=False) + class WizardFormIISConfiguration(forms.Form): iis_name = forms.CharField(label=_("IIS Server Name"), required=False) - + adm_password = forms.CharField(widget=forms.PasswordInput, - label=_("Administrator password"), - required=False) + label=_("Administrator password"), required=False) iis_count = forms.IntegerField(label=_("IIS Servers Count"), required=True, @@ -83,14 +80,13 @@ class WizardFormIISConfiguration(forms.Form): iis_domain = forms.CharField(label=_("Member of the Domain"), required=False) - + domain_user_name = forms.CharField(label=_("Domain User Name"), - required=False) - + required=False) + domain_user_password = forms.CharField(widget=forms.PasswordInput, - label=_("Domain User Password"), - required=False) - + label=_("Domain User Password"), required=False) + class UpdateWinDC(forms.SelfHandlingForm): tenant_id = forms.CharField(widget=forms.HiddenInput) diff --git a/dashboard/windc/tables.py b/dashboard/windc/tables.py index a5c7b4d..e9564e4 100644 --- a/dashboard/windc/tables.py +++ b/dashboard/windc/tables.py @@ -102,6 +102,23 @@ class DeleteService(tables.BatchAction): ############## api.windc.services_delete(request, datacenter_id, service_id) + + +class DeployDataCenter(tables.BatchAction): + name = "deploy" + action_present = _("Deploy") + action_past = _("Deploy") + data_type_singular = _("Data Center") + data_type_plural = _("Data Center") + classes = ("btn-launch") + + def allowed(self, request, datum): + return True + + def action(self, request, datacenter_id): + #link = request.__dict__['META']['HTTP_REFERER'] + #datacenter_id = re.search('windc/(\S+)', link).group(0)[6:-1] + return api.windc.datacenters_deploy(request, datacenter_id) class EditService(tables.LinkAction): @@ -143,7 +160,8 @@ class WinDCTable(tables.DataTable): verbose_name = _("Windows Data Centers") row_class = UpdateRow table_actions = (CreateDataCenter,) - row_actions = (ShowDataCenterServices, DeleteDataCenter) + row_actions = (ShowDataCenterServices, DeleteDataCenter, + DeployDataCenter) STATUS_DISPLAY_CHOICES = ( diff --git a/dashboard/windc/templates/windc/_services_tabs.html b/dashboard/windc/templates/windc/_services_tabs.html index a00c4c3..1173703 100644 --- a/dashboard/windc/templates/windc/_services_tabs.html +++ b/dashboard/windc/templates/windc/_services_tabs.html @@ -7,6 +7,11 @@ {% block modal-header %}{% trans "Create Service" %}{% endblock %} {% block modal-body %} +
{% trans "Now you can set the parameters for Active Directory Service." %}
+{% trans "You can create few Active Directory instances, in this case will be created one Main Active Directory server and few Secondary Active Directory servers." %}
+{% trans "The DNS service will be automatically created on each Active Directory servers." %}
+ {% else %} +{% trans "Now you can set parameters for IIS Service." %}
+{% trans "The IIS Service - it is the server with complex IIS infrastructure, which included to the domain infrasructure." %}
+{% trans "Please, set the complex password for local administrator account." %}
+{% trans "Also, you can add this IIS server to the existing domain and configure credentials for domain user." %}
+ {% endif %} + + {% else %} +{% trans "Now you can select the type of the service." %}
+{% trans "The Active Directory Service allows to configure Domain Controllers with Active Directory and DNS infrastructure. You can create one Main Domain Controller and few Secondary Domain Controllers." %}
+{% trans "The Internet Information Services allows to configure IIS servers, which can be included to the existing domain infrastructure." %}
+ {% endif %} +