SLA plugin: fixed template shown in dialog
authorJavier Garcia <javier.garcial@atos.net>
Fri, 18 Sep 2015 11:33:33 +0000 (13:33 +0200)
committerJavier García <javier.garcial.external@atos.net>
Fri, 18 Sep 2015 11:33:33 +0000 (13:33 +0200)
plugins/sladialog/static/js/sladialog.js
sla/slicetabsla.py

index a8f8244..01eb0af 100644 (file)
             this.listen_query(options.query_uuid);
             
             /* GUI setup and event binding */
             this.listen_query(options.query_uuid);
             
             /* GUI setup and event binding */
-
-            // call function
-            this.button_binding();
-
             // Get testbeds with sla and store them in localStorage
             this.get_testbeds_with_sla();
             // Get testbeds with sla and store them in localStorage
             this.get_testbeds_with_sla();
+
+            // call function
+            //this.button_binding();
         },
 
         get_testbeds_with_sla: function () {
         },
 
         get_testbeds_with_sla: function () {
         },
 
         get_sla_templates: function (testbeds) {
         },
 
         get_sla_templates: function (testbeds) {
+            var self = this;
 
             testbeds.forEach(function(testbed, index, array) {
 
 
             testbeds.forEach(function(testbed, index, array) {
 
-                if(testbed!="omf:netmode") { return } // TODO: remove
-
-                $.get('/sla/agreements/templates/' + testbed, function(slo) {
-
-                    $(".modal-body #sla_template").append(slo);
-
-                    var content =
-                    "<div id=" + testbed + " class='row' data-urns='[]' style='display: none'>" +
-                        "<div class='col-md-6'>" +
-                            "<p>Testbed <span class='provider'>" + testbed + "</span> offers the following SLA for its resources</p>" +
-                        "/div>" +
-                        "<div class='col-md-1'>" +
-                            "<button class='sla-info-button btn btn-default' data-toggle='modal' data-target='#sla_template_modal'>" +
-                            "<span class='glyphicon glyphicon-info-sign'></span>" +
-                                "Details" +
-                            "</button>" +
-                        "</div>" +
-                        "<div class='col-md-1'>" +
-                            "<button class='sla-accept-button btn btn-default' data-complete-text='Accepted' autocomplete='off'>" +
-                            "<span class='glyphicon glyphicon-ok'></span>" +
-                                "Accept" +
-                            "</button>" +
-                        "</div>" +
-                    "</div>";
-
-                    $("#sla_offers").append(content);
-                });
+                if(testbed=="omf:netmode") { // TODO: Remove
+
+                    $.ajax('/sla/agreements/templates/' + testbed)
+                     .always(function(data) {
+                        $(".modal-body #sla_template").html(data.responseText.replace(/<|>/g, ""));
+
+                        var content =
+                        "<div id=" + testbed.replace(/\.|:/g, "-") + " class='row' data-urns='[]' style='display: none'>" +
+                            "<div class='col-md-6'>" +
+                                "<p>Testbed <span class='provider'>" + testbed + "</span> offers the following SLA for its resources</p>" +
+                            "</div>" +
+                            "<div class='col-md-1'>" +
+                                "<button class='sla-info-button btn btn-default' data-toggle='modal' data-target='#sla_template_modal'>" +
+                                "<span class='glyphicon glyphicon-info-sign'></span>" +
+                                    "Details" +
+                                "</button>" +
+                            "</div>" +
+                            "<div class='col-md-1'>" +
+                                "<button class='sla-accept-button btn btn-default' data-complete-text='Accepted' autocomplete='off'>" +
+                                "<span class='glyphicon glyphicon-ok'></span>" +
+                                    "Accept" +
+                                "</button>" +
+                            "</div>" +
+                        "</div>";
+
+                        $("#sla_offers").append(content);
+
+                        self.button_binding();
+                    });
+                }
             });
         },
 
             });
         },
 
index 1e36fcf..cc26b25 100755 (executable)
@@ -250,11 +250,12 @@ class AgreementTemplates(FreeAccessView, ThemeView):
         #logger.debug("BBBBB templates: {}".format(templates))
 
         for template in templates:
         #logger.debug("BBBBB templates: {}".format(templates))
 
         for template in templates:
-            service_level_objectives.append(template.GuaranteeTerm.ServiceLevelObjective)
+            service_level_objectives.append(
+                [v.servicelevelobjective for v in template.guaranteeterms.values()])
 
 
-        #logger.debug("CCCCC slo: {}".format(service_level_objectives))
+        logger.debug("CCCCC slo: {}".format(service_level_objectives))
 
 
-        return HttpResponse(service_level_objectives, content_type="application/xml")
+        return HttpResponse(service_level_objectives, content_type="application/json", status=response.status_code)
 
 class CreateAgreement(LoginRequiredView, ThemeView):
     def post(self, request, *args, **kwargs):
 
 class CreateAgreement(LoginRequiredView, ThemeView):
     def post(self, request, *args, **kwargs):