Commit 7bc6e462 by Sulyok Gabor

Machine handling fixes

parent f7a8b0d6
Pipeline #257 failed with stage
in 0 seconds
...@@ -114,19 +114,27 @@ class SettyController: ...@@ -114,19 +114,27 @@ class SettyController:
@staticmethod @staticmethod
def getMachineAvailableList(serviceId, used_hostnames, current_user): def getMachineAvailableList(serviceId, usedHostnames, current_user):
all_minions = []# SettyController.salthelper.getAllMinionsUngrouped() saltMinions = []#SettyController.salthelper.getAllMinionsUngrouped()
usedMachines = Machine.objects.filter(service=serviceId) savedMachines = Machine.objects.filter(service=serviceId)
user_instances = Instance.objects.filter(owner=current_user)
userMachines = [] savedHostNames = []
for machine in savedMachines:
savedHostNames.append( machine.hostname )
userInstances = Instance.objects.filter(owner=current_user)
userMachines = [] userMachines = []
for instance in user_instances: for instance in userInstances:
if instance.vm_name: if instance.vm_name:
print instance.vm_name
userMachines.append(instance.vm_name) userMachines.append(instance.vm_name)
return {'machinedata': userMachines} usedHostnamesByUser = set( savedHostNames + usedHostnames )
if not usedHostnamesByUser:
return {'machinedata':userMachines}#{'machinedata': [machineName for machineName in userMachines if machineName in saltMinions] }
availableInstanceNames = list( set(userMachines) - usedHostnamesByUser )
return {'machinedata': availableInstanceNames}#[ machineName for machineName in availableInstanceNames if machineName in saltMinions ]}
@staticmethod @staticmethod
def addMachine(hostname): def addMachine(hostname):
...@@ -135,12 +143,12 @@ class SettyController: ...@@ -135,12 +143,12 @@ class SettyController:
return {'error': 'already added or doesnt exists'} return {'error': 'already added or doesnt exists'}
except: except:
pass pass
if SettyController.salthelper.checkMinionExists(hostname): #if SettyController.salthelper.checkMinionExists(hostname):
machine = Machine.clone() machine = Machine.clone()
machine.hostname = hostname machine.hostname = hostname
return machine.getDataDictionary() return machine.getDataDictionary()
else: # else:
return {'error': 'already added or doesnt exists'} # return {'error': 'already added or doesnt exists'}
@staticmethod @staticmethod
def addServiceNode(elementTemplateId): def addServiceNode(elementTemplateId):
......
...@@ -152,9 +152,9 @@ class Machine(Element): # As a real machine ...@@ -152,9 +152,9 @@ class Machine(Element): # As a real machine
@staticmethod @staticmethod
def getInformation(): def getInformation():
return {'hostname': hostname.get_internal_type(), return {'hostname': Machine._meta.get_field('hostname').get_internal_type(),
'alias': alias.get_internal_type(), 'alias': Machine._meta.get_field('alias').get_internal_type(),
'description': description.get_internal_type()} 'description': Machine._meta.get_field('description').get_internal_type()}
def getDataDictionary(self): def getDataDictionary(self):
element_data = self.getDisplayData() element_data = self.getDisplayData()
......
...@@ -70,6 +70,7 @@ jsPlumb.ready(function() { ...@@ -70,6 +70,7 @@ jsPlumb.ready(function() {
}; };
var elementConnections = []; var elementConnections = [];
var elementIndex = 0; var elementIndex = 0;
var machineIndex = 0;
var dragContainerScroll = 0; var dragContainerScroll = 0;
var workspaceWidth = $("#dropContainer").width(); var workspaceWidth = $("#dropContainer").width();
var workspaceHeight = $("#dropContainer").height(); var workspaceHeight = $("#dropContainer").height();
...@@ -94,94 +95,67 @@ jsPlumb.ready(function() { ...@@ -94,94 +95,67 @@ jsPlumb.ready(function() {
} }
}; };
addInfo = function(title, info, type, object) { addMachineClicked = function( machineButton ){
machineHostname = $(machineButton.currentTarget).attr("data-hostname");
$.post("", {
event: "addMachine",
data: JSON.stringify({ "hostname": machineHostname } )
}, function(result) {
addMachine( result );
undoStack.splice(stackIndexer, 0, removeElement);
redoStack.splice(stackIndexer, 0, addElement);
objectStack.splice(stackIndexer, 0, newInstance);
stackSize++;
stackIndexer++;
});
}
addInfo = function(title, object) {
id = object.attr("id").split("_")[1]; id = object.attr("id").split("_")[1];
information = undefined; information = undefined;
$.post("", { $.post("", {
event: "getInformation", event: "getInformation",
data: JSON.stringify({ data: JSON.stringify({
"elementTemplateId": object.attr("id").split("_")[1] , "elementTemplateId": object.attr("data-hostname") ? "" : object.attr("id").split("_")[1] ,
"hostname": object.attr("hostname")} ) "hostname": object.attr("data-hostname")? object.attr("data-hostname") : "" } )
}, function(result) { }, function(result) {
$("#informationContainer").empty(); $("#informationContainer").empty();
switch(type){ $.each( result, function(fieldName, fieldType)
/*case "connection": {
div = form_group = $("<div class='form-group'></div>");
'<div class="row">' + label = $("<label></label>").attr("for",fieldName).append( fieldName );
'<div class="col-xs-12 text-center">' + switch( fieldType )
'<h4>' + title + '</h4>' + {
'</div>' + //#TODO: Gaben: handle additional types
'</div>&nbsp;' + case 'PositiveIntegerField':
'<div class="row">' + input = $("<input>").prop("type","number" ).prop("min",0).addClass("form-control");
'<div class="col-xs-12">' + value = object.attr( "data-"+ fieldName );
'<textarea class="form-control" rows="28" id="infoInput" placeholder="Config data"></textarea>' + if( value )
'</div>' + input.prop("value",value );
'</div>&nbsp;' + break;
'<div class="row">' + case 'TextField':
'<div class="col-xs-12 text-center">' + case 'CharField':
'<button id="removeConnection" class="btn btn-info">Remove connection</button>' + input = $("<input>").prop("type","text" ).addClass("form-control");
'</div>' + value = object.attr( "data-"+ fieldName );
'</div>'; if( value )
break;*/ input.prop("value",value );
case "element": break;
$.each( result, function(fieldName, fieldType) case 'BooleanField':
{ input = $("<input>").prop("type","checkbox" );
form_group = $("<div class='form-group'></div>"); break;
label = $("<label></label>").attr("for",fieldName).append( fieldName ); default:
switch( fieldType ) alert( "unknown field type: " + fieldType );
{ break;
//#TODO: Gaben: handle additional types }
case 'PositiveIntegerField':
input = $("<input>").prop("type","number" ).prop("min",0).addClass("form-control");
value = object.attr( "data-"+ fieldName );
if( value )
input.prop("value",value );
break;
case 'TextField':
case 'CharField':
input = $("<input>").prop("type","text" ).addClass("form-control");
value = object.attr( "data-"+ fieldName );
if( value )
input.prop("value",value );
break;
case 'BooleanField':
input = $("<input>").prop("type","checkbox" );
break;
default:
alert( "unknown field type: " + fieldType );
break;
}
input.attr("attribute-name", "data-" + fieldName );
input.prop("id", "input-data-" + fieldName)
form_group.append( label ); input.attr("attribute-name", "data-" + fieldName );
form_group.append( input ); input.prop("id", "input-data-" + fieldName)
$("#informationContainer").append( form_group )
} );
break;
/*case "elementTemplate":
div =
'<div class="row">' +
'<div class="col-xs-12 text-center">' +
'<h4>' + title + '</h4>' +
'</div>' +
'</div>&nbsp;' +
'<div class="row">' +
'<div class="col-xs-12">' +
'<textarea class="form-control" rows="28" id="infoInput" placeholder="Config data"></textarea>' +
'</div>' +
'</div>&nbsp;' +
'<div class="row">' +
'<div class="col-xs-12 text-center">' +
'<button id="addElementToWorkspace" class="btn btn-success">Add to workspace</button>' +
'</div>' +
'</div>';
break;*/
}
$("#infoInput").val(info); form_group.append( label );
form_group.append( input );
$("#informationContainer").append( form_group )
} );
$("#changeInformationDialog").modal('show'); $("#changeInformationDialog").modal('show');
...@@ -443,35 +417,6 @@ jsPlumb.ready(function() { ...@@ -443,35 +417,6 @@ jsPlumb.ready(function() {
return newInstance; return newInstance;
}; };
addMachine = function(idOrInstance, newId, newPositionY, endpoints, parameters, newPositionX) {
newInstance = "";
newInstance = $('<div>')
.prop("id", newId)
.prop("title", "Right click to delete")
.removeClass()
.addClass("element")
.attr("anchors", 0)
.attr("parameters", parameters)
.css("top", newPositionY)
.css("left", newPositionX);
$("#dropContainer").append(newInstance);
for (i = 0; i <= endpoints; i++) {
addEndpoint(newInstance);
}
jsPlumbInstance.draggable(jsPlumb.getSelector(".element"), {
containment: $("#dropContainer")
});
setServiceStatus("unsaved");
jsPlumbInstance.repaintEverything();
return newInstance;
}
removeElement = function(object) { removeElement = function(object) {
jsPlumbInstance.detachAllConnections(object); jsPlumbInstance.detachAllConnections(object);
jsPlumbInstance.remove(object.attr("id")); jsPlumbInstance.remove(object.attr("id"));
...@@ -529,15 +474,18 @@ jsPlumb.ready(function() { ...@@ -529,15 +474,18 @@ jsPlumb.ready(function() {
jsPlumbInstance.bind("dblclick", function(info) { jsPlumbInstance.bind("dblclick", function(info) {
info.setPaintStyle({strokeStyle:"red", lineWidth: 8}); info.setPaintStyle({strokeStyle:"red", lineWidth: 8});
addInfo($("#" + info.sourceId.split('_')[1]).attr("alt") + ' - ' + $("#" + info.targetId.split('_')[1]).attr("alt"), //addInfo($("#" + info.sourceId.split('_')[1]).attr("alt") + ' - ' + $("#" + info.targetId.split('_')[1]).attr("alt"),
info.parameters, // info.parameters,
"connection", // "connection",
info); // info);
}); });
jsPlumbInstance.draggable(jsPlumb.getSelector(".element"), { jsPlumbInstance.draggable(jsPlumb.getSelector(".element"), {
containment: $("#dropContainer") containment: $("#dropContainer")
}); });
jsPlumbInstance.draggable(jsPlumb.getSelector(".machine"), {
containment: $("#dropContainer")
});
/* Registering general events using JQuery. */ /* Registering general events using JQuery. */
...@@ -571,15 +519,18 @@ jsPlumb.ready(function() { ...@@ -571,15 +519,18 @@ jsPlumb.ready(function() {
}); });
/* ---------------------------------------- */ /* ---------------------------------------- */
$('body').on('dblclick', '.element', function() { $('body').on('dblclick', '.element', function() {
element = $(this); element = $(this);
element.addClass("elementSelected"); element.addClass("elementSelected");
addInfo(element.attr("alt"), addInfo(element.attr("alt"), element);
element.attr("parameters"), $(document).scrollTop(0);
"element", element); });
$('body').on('dblclick', '.machine', function() {
element = $(this);
element.addClass("elementSelected");
addInfo(element.attr("alt"), element);
$(document).scrollTop(0); $(document).scrollTop(0);
}); });
...@@ -596,6 +547,19 @@ jsPlumb.ready(function() { ...@@ -596,6 +547,19 @@ jsPlumb.ready(function() {
stackIndexer++; stackIndexer++;
}); });
$('body').on('contextmenu', '.machine', function(event) {
setServiceStatus("unsaved");
removeElement($(this));
undoStack.splice(stackIndexer, 0, addElement);
redoStack.splice(stackIndexer, 0, removeElement);
objectStack.splice(stackIndexer, 0, $(this));
nextStepConstraint = 0;
stackSize++;
stackIndexer++;
});
$('body').on('click', '#closeInfoPanel', function() { $('body').on('click', '#closeInfoPanel', function() {
$('#informationPanel').hide(); $('#informationPanel').hide();
$('#dragPanel').show(); $('#dragPanel').show();
...@@ -680,19 +644,37 @@ jsPlumb.ready(function() { ...@@ -680,19 +644,37 @@ jsPlumb.ready(function() {
clickEvent = 0; clickEvent = 0;
}); });
$('body').on('click', '#addMachineDialog', function() { $('body').on('click', '#showAddMachineDialog', function() {
// Here comes the ajax post of getMachineAvailableList usedHostnames = []
// posting usedhostnames $(".machine").each( function() {
// usedHostnames.push($(this).attr("data-hostname"))
// } );
// after it, appending obtained content to addmachinedialogbody
}); $.post("", {
event: "getMachineAvailableList",
data: JSON.stringify({ "usedHostnames": usedHostnames } )
}, function(result) {
$("#availableMachineListContainer").empty();
$.each( result.machinedata, function(key, hostname)
{
listItem = $("<button/>")//.class("list-group-item").data("hostname",hostname);
listItem.addClass("list-group-item").attr("data-hostname",hostname).attr("data-dismiss","modal").attr("type","button");
listItem.append( hostname );
listItem.on("click", {hostname: listItem}, addMachineClicked );
$("#availableMachineListContainer").append( listItem );
});
$('body').on('click', '.elementTemplateInfo', function() { $("#addMachineDialog").modal('show');
id = $(this).attr("element"); });
addInfo($("#" + id).attr("alt"), $("#" + id).attr("desc"), "elementTemplate", $("#" + id));
}); });
//$('body').on('click', '.elementTemplateInfo', function() {
// id = $(this).attr("element");
// addInfo($("#" + id).attr("alt"), $("#" + id).attr("desc"), "elementTemplate", $("#" + id));
//});
$('body').on('click', '#serviceName', function() { $('body').on('click', '#serviceName', function() {
$('#serviceName').hide(); $('#serviceName').hide();
$("#serviceNameEdit").css("display", "inline").val($(this).text()).select(); $("#serviceNameEdit").css("display", "inline").val($(this).text()).select();
...@@ -818,6 +800,7 @@ jsPlumb.ready(function() { ...@@ -818,6 +800,7 @@ jsPlumb.ready(function() {
serviceName = $("#serviceName").text(); serviceName = $("#serviceName").text();
connectionSet = []; connectionSet = [];
instanceSet = []; instanceSet = [];
machineSet = [];
$.each(elementConnections, function(index) { $.each(elementConnections, function(index) {
connectionSet.push({ connectionSet.push({
...@@ -834,7 +817,6 @@ jsPlumb.ready(function() { ...@@ -834,7 +817,6 @@ jsPlumb.ready(function() {
"displayId": $(item).prop("id") }; "displayId": $(item).prop("id") };
attributes = item.attributes attributes = item.attributes
$.each( attributes, function(key,attribute){ $.each( attributes, function(key,attribute){
if( attribute.name.indexOf("data-") != -1 ){ if( attribute.name.indexOf("data-") != -1 ){
basic_data[ attribute.name.substring( attribute.name.indexOf('-') + 1 ) ] = attribute.value || ""; basic_data[ attribute.name.substring( attribute.name.indexOf('-') + 1 ) ] = attribute.value || "";
} }
...@@ -843,13 +825,28 @@ jsPlumb.ready(function() { ...@@ -843,13 +825,28 @@ jsPlumb.ready(function() {
instanceSet.push( basic_data ); instanceSet.push( basic_data );
}); });
$.each($(".machine"), function( index, item ) {
basic_data = { "anchorNumber": $(item).attr("anchors"),
"positionLeft": $(item).position().left/workspaceWidth,
"positionTop": $(item).position().top/workspaceHeight,
"displayId": $(item).prop("id") };
attributes = item.attributes
$.each( attributes, function(key,attribute){
if( attribute.name.indexOf("data-") != -1 ){
basic_data[ attribute.name.substring( attribute.name.indexOf('-') + 1 ) ] = attribute.value || "";
}
});
machineSet.push( basic_data );
});
$.post("", { $.post("", {
event: "saveService", event: "saveService",
data: JSON.stringify({ data: JSON.stringify({
"serviceName": serviceName, "serviceName": serviceName,
"elementConnections": connectionSet, "elementConnections": connectionSet,
"serviceNodes": instanceSet, "serviceNodes": instanceSet,
"machines": []}) "machines": machineSet })
}, function(result) { }, function(result) {
addMessage(result.serviceName + gettext(" saved successfully."),"success"); addMessage(result.serviceName + gettext(" saved successfully."),"success");
setServiceStatus("saved"); setServiceStatus("saved");
...@@ -866,7 +863,7 @@ jsPlumb.ready(function() { ...@@ -866,7 +863,7 @@ jsPlumb.ready(function() {
$("#serviceName").text( result.serviceName ); $("#serviceName").text( result.serviceName );
$.each(result.serviceNodes, function(i, element) { $.each(result.serviceNodes, function(i, element) {
addElement2( element ); addElementOnLoad( element );
if (elementIndex < element.displayId.split('_')[0]) if (elementIndex < element.displayId.split('_')[0])
elementIndex = element.displayId.split('_')[0]; elementIndex = element.displayId.split('_')[0];
...@@ -874,15 +871,11 @@ jsPlumb.ready(function() { ...@@ -874,15 +871,11 @@ jsPlumb.ready(function() {
}); });
$.each(result.machines, function(i, element) { $.each(result.machines, function(i, element) {
addMachine(element.displayId.split('_')[1], addMachineOnLoad(element);
element.displayId,
(element.positionTop*workspaceHeight) + "px", if (machineIndex < element.displayId.split('_')[1])
element.anchorNumber, machineIndex = element.displayId.split('_')[1];
element.parameters, machineIndex++;
(element.positionLeft*workspaceWidth) + "px");
if (elementIndex < element.displayId.split('_')[0])
elementIndex = element.displayId.split('_')[0];
elementIndex++;
}); });
clickEvent = 1; clickEvent = 1;
...@@ -896,11 +889,87 @@ jsPlumb.ready(function() { ...@@ -896,11 +889,87 @@ jsPlumb.ready(function() {
}); });
}); });
addElement2 = function(elementData) { addMachine = function(elementData){
newInstance = $('<img id="machine_' + machineIndex + '"/>')
.prop("title", "Right click to delete")
.removeClass()
.attr("anchors", 0)
.addClass("machine");
var skippedVariables = ["anchorNumber", "displayId"]
$.each(elementData, function(key, value)
{
if (skippedVariables.indexOf(key) == -1 )
{
if (key === "positionTop")
newInstance.css("top", value * workspaceHeight);
else if(key === "positionLeft")
newInstance.css("left", value * workspaceWidth);
else
newInstance.attr("data-"+key, value);
}
});
$("#dropContainer").append(newInstance);
for (idx = 0; idx < 4; idx++)
addEndpoint(newInstance);
setServiceStatus("unsaved");
jsPlumbInstance.draggable(jsPlumb.getSelector(".machine"), {
containment: $("#dropContainer")
});
jsPlumbInstance.repaintEverything();
machineIndex++;
return newInstance;
}
addMachineOnLoad = function(elementData){
newInstance = $('<img id="' + elementData["displayId"] + '"/>')
.prop("title", "Right click to delete")
.removeClass()
.attr("anchors", 0)
.addClass("machine");
var skippedVariables = ["anchorNumber", "displayId"]
$.each(elementData, function(key, value)
{
if (skippedVariables.indexOf(key) == -1 )
{
if (key === "positionTop")
newInstance.css("top", value * workspaceHeight);
else if(key === "positionLeft")
newInstance.css("left", value * workspaceWidth);
else
newInstance.attr("data-"+key, value);
}
});
$("#dropContainer").append(newInstance);
for (idx = 0; idx < elementData["anchorNumber"]; idx++)
addEndpoint(newInstance);
setServiceStatus("unsaved");
jsPlumbInstance.draggable(jsPlumb.getSelector(".machine"), {
containment: $("#dropContainer")
});
jsPlumbInstance.repaintEverything();
return newInstance;
}
addElementOnLoad = function(elementData) {
templateId = elementData.displayId.split('_')[1] templateId = elementData.displayId.split('_')[1]
template = $(".elementTemplate").filter( "#" + templateId ); template = $(".elementTemplate").filter( "#" + templateId );
id = elementData.displayId.split('_')[0] //id = elementData.displayId.split('_')[0]
newInstance = $('<img id="' + elementData["displayId"] + '"/>') newInstance = $('<img id="' + elementData["displayId"] + '"/>')
.prop("title", "Right click to delete") .prop("title", "Right click to delete")
.removeClass() .removeClass()
......
...@@ -97,6 +97,33 @@ textarea { ...@@ -97,6 +97,33 @@ textarea {
z-index: 2000; z-index: 2000;
} }
.machine{
position: absolute;
left: 10px;
display: inline;
width: 75px;
height: 75px;
background: red;
border-radius: 8px;
border-color: black;
-webkit-border-radius: 8px;
border-style: solid;
border-width: 5px;
z-index: 40;
cursor: grab;
}
.machine:hover{
border: 5px solid #123456;
box-shadow: 2px 2px 19px #444;
-o-box-shadow: 2px 2px 19px #444;
-webkit-box-shadow: 2px 2px 19px #444;
-moz-box-shadow: 2px 2px 19px #fff;
opacity: 0.9;
filter: alpha(opacity=90);
z-index: 2000;
}
._jsPlumb_connector{ ._jsPlumb_connector{
z-index: 10; z-index: 10;
} }
......
...@@ -192,8 +192,11 @@ ...@@ -192,8 +192,11 @@
<h4 class="modal-title"><i class="fa fa-outdent"></i>&nbsp;{% trans 'Machines' %}</h4> <h4 class="modal-title"><i class="fa fa-outdent"></i>&nbsp;{% trans 'Machines' %}</h4>
</div> </div>
<div class="modal-body" id="addMachineDialogBody"> <div class="modal-body" id="addMachineDialogBody">
<div class="list-group" id="availableMachineListContainer">
</div>
</div> </div>
<div class="modal-footer"> <div class="modal-footer">
<div class="btn btn-primary" data-dismiss="modal"/>Mégsem</div>
</div> </div>
</div> </div>
</div> </div>
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or sign in to comment