X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=planetstack%2Fcore%2Fxoslib%2Fstatic%2Fjs%2Fxoslib%2Fxos-backbone.js;h=6a7b9d97165eeadb64ab6a6e129d36de0b6ff4e0;hb=ff96374247bc69d246eee900e50a571b66e307bf;hp=762a2b54ba17845ba01eb27ebcf2d7dae2e4f3f5;hpb=ceb262824337cffd6cf83f035849e32c8aa414e5;p=plstackapi.git diff --git a/planetstack/core/xoslib/static/js/xoslib/xos-backbone.js b/planetstack/core/xoslib/static/js/xoslib/xos-backbone.js index 762a2b5..6a7b9d9 100644 --- a/planetstack/core/xoslib/static/js/xoslib/xos-backbone.js +++ b/planetstack/core/xoslib/static/js/xoslib/xos-backbone.js @@ -319,18 +319,12 @@ if (! window.XOSLIB_LOADED ) { var url = this.urlRoot || ( models && models.length && models[0].urlRoot ); url && ( url += ( url.length > 0 && url.charAt( url.length - 1 ) === '/' ) ? '' : '/' ); - // Build a url to retrieve a set of models. This assume the last part of each model's idAttribute - // (set to 'resource_uri') contains the model's id. - if ( models && models.length ) { - var ids = _.map( models, function( model ) { - var parts = _.compact( model.id.split('/') ); - return parts[ parts.length - 1 ]; - }); - url += 'set/' + ids.join(';') + '/'; - } - url && ( url += "?no_hyperlinks=1" ); + if (this.currentUserCanSee) { + url && ( url += "¤t_user_can_see=1" ); + } + return url; }, @@ -364,6 +358,7 @@ if (! window.XOSLIB_LOADED ) { function define_model(lib, attrs) { modelName = attrs.modelName; modelClassName = modelName; + collectionClass = attrs.collectionClass || XOSCollection; collectionClassName = modelName + "Collection"; if (!attrs.addFields) { @@ -398,22 +393,24 @@ if (! window.XOSLIB_LOADED ) { if (!modelAttrs.defaults) { modelAttrs.defaults = get_defaults(modelName); } - console.log(modelName); - console.log(modelAttrs); // if ((typeof xosdefaults !== "undefined") && xosdefaults[modelName]) { // modelAttrs["defaults"] = xosdefaults[modelName]; // } if ((typeof xosvalidators !== "undefined") && xosvalidators[modelName]) { - modelAttrs["validators"] = xosvalidators[modelName]; + modelAttrs["validators"] = $.extend({}, xosvalidators[modelName], attrs["validators"] || {}); + } else if (attrs["validators"]) { + modelAttrs["validators"] = attrs["validators"]; + console.log(attrs); + console.log(modelAttrs); } lib[modelName] = XOSModel.extend(modelAttrs); collectionAttrs["model"] = lib[modelName]; - lib[collectionClassName] = XOSCollection.extend(collectionAttrs); + lib[collectionClassName] = collectionClass.extend(collectionAttrs); lib[collectionName] = new lib[collectionClassName](); lib.allCollectionNames.push(collectionName); @@ -475,11 +472,11 @@ if (! window.XOSLIB_LOADED ) { define_model(this, {urlRoot: SLIVER_API, relatedCollections: {"networkSlivers": "sliver"}, foreignCollections: ["slices", "deployments", "images", "nodes", "users", "flavors"], - foreignFields: {"creator": "users", "image": "images", "node": "nodes", "deploymentNetwork": "deployments", "slice": "slices", "flavor": "flavors"}, + foreignFields: {"creator": "users", "image": "images", "node": "nodes", "deployment": "deployments", "slice": "slices", "flavor": "flavors"}, modelName: "sliver", - listFields: ["backend_status", "id", "name", "instance_id", "instance_name", "slice", "deploymentNetwork", "image", "node", "flavor"], - addFields: ["slice", "deploymentNetwork", "flavor", "image", "node"], - detailFields: ["backend_status", "name", "instance_id", "instance_name", "slice", "deploymentNetwork", "flavor", "image", "node", "creator"], + listFields: ["backend_status", "id", "name", "instance_id", "instance_name", "slice", "deployment", "image", "node", "flavor"], + addFields: ["slice", "deployment", "flavor", "image", "node"], + detailFields: ["backend_status", "name", "instance_id", "instance_name", "slice", "deployment", "flavor", "image", "node", "creator"], preSave: function() { if (!this.attributes.name && this.attributes.slice) { this.attributes.name = xos.idToName(this.attributes.slice, "slices", "name"); } }, }); @@ -492,7 +489,7 @@ if (! window.XOSLIB_LOADED ) { inputType: {"enabled": "checkbox"}, modelName: "slice", xosValidate: function(attrs, options) { - errors = XOSModel.prototype.xosValidate(this, attrs, options); + errors = XOSModel.prototype.xosValidate.call(this, attrs, options); // validate that slice.name starts with site.login_base site = attrs.site || this.site; if ((site!=undefined) && (attrs.name!=undefined)) { @@ -555,7 +552,7 @@ if (! window.XOSLIB_LOADED ) { }); define_model(this, { urlRoot: DEPLOYMENT_API, - relatedCollections: {"nodes": "deployment", "slivers": "deploymentNetwork"}, + relatedCollections: {"nodes": "deployment", "slivers": "deployment"}, m2mFields: {"flavors": "flavors", "sites": "sites", "images": "images"}, modelName: "deployment", listFields: ["backend_status", "id", "name", "backend_type", "admin_tenant"], @@ -672,8 +669,9 @@ if (! window.XOSLIB_LOADED ) { modelName: "slicePlus", collectionName: "slicesPlus", defaults: extend_defaults("slice", {"network_ports": "", "site_allocation": []}), + validators: {"network_ports": ["portspec"]}, xosValidate: function(attrs, options) { - errors = XOSModel.prototype.xosValidate(this, attrs, options); + errors = XOSModel.prototype.xosValidate.call(this, attrs, options); // validate that slice.name starts with site.login_base site = attrs.site || this.site; if ((site!=undefined) && (attrs.name!=undefined)) { @@ -694,6 +692,11 @@ if (! window.XOSLIB_LOADED ) { detailFields: [], }); + /* by default, have slicePlus only fetch the slices the user can see */ + this.slicesPlus.currentUserCanSee = true; + + this.tenant = function() { return this.tenantview.models[0].attributes; }; + this.listObjects = function() { return this.allCollectionNames; }; this.getCollectionStatus = function() {