Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Split off actions pulling in ogc-schemas into a separate file #1336

Merged
merged 1 commit into from
Dec 12, 2016
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions web/client/actions/__tests__/layers-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -33,9 +33,9 @@ var {
removeLayer,
showSettings,
hideSettings,
updateSettings,
getLayerCapabilities
updateSettings
} = require('../layers');
var {getLayerCapabilities} = require('../layerCapabilities');

describe('Test correctness of the layers actions', () => {
it('test layer properties change action', (done) => {
Expand Down
101 changes: 101 additions & 0 deletions web/client/actions/layerCapabilities.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,101 @@
/**
* Copyright 2015, GeoSolutions Sas.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree.
*/

const {updateNode} = require('./layers');
const WMS = require('../api/WMS');
const WFS = require('../api/WFS');
const WCS = require('../api/WCS');

const _ = require('lodash');

function getDescribeLayer(url, layer, options) {
return (dispatch /* , getState */) => {
return WMS.describeLayer(url, layer.name, options).then((describeLayer) => {
if (describeLayer && describeLayer.owsType === "WFS") {
return WFS.describeFeatureType(url, describeLayer.name).then((describeFeatureType) => {
// TODO move the management of this geometryType in the proper components, getting the describeFeatureType entry:
let types = _.get(describeFeatureType, "complexType[0].complexContent.extension.sequence.element");
let geometryType = _.head(types && types.filter( elem => (elem.name === "the_geom" || elem.type.prefix.indexOf("gml") === 0)));
geometryType = geometryType && geometryType.type.localPart;
describeLayer.geometryType = geometryType && geometryType.split("PropertyType")[0];
return dispatch(updateNode(layer.id, "id", {describeLayer, describeFeatureType}));
}).catch(() => {
return dispatch(updateNode(layer.id, "id", {describeLayer: describeLayer || {"error": "no describe feature found"}}));
});
} else if ( describeLayer && describeLayer.owsType === "WCS" ) {
WCS.describeCoverage(url, describeLayer.name).then((describeCoverage) => {
// TODO move the management of this bands in the proper components, getting the describeFeatureType entry:
let axis = _.get(describeCoverage, "wcs:CoverageDescriptions.wcs:CoverageDescription.wcs:Range.wcs:Field.wcs:Axis.wcs:AvailableKeys.wcs:Key");
if (axis && typeof axis === "string") {
describeLayer.bands = [1 + ""];
} else {
describeLayer.bands = axis.map((el, index) => ((index + 1) + "")); // array of 1 2 3 because the sld do not recognize the name
}

dispatch(updateNode(layer.id, "id", {describeLayer, describeCoverage}));
}).catch(() => {
return dispatch(updateNode(layer.id, "id", {describeLayer: describeLayer || {"error": "no describe coverage found"}}));
});
}
return dispatch(updateNode(layer.id, "id", {describeLayer: describeLayer || {"error": "no describe Layer found"}}));

});
};
}

function getLayerCapabilities(layer, options) {
// geoserver's specific. TODO parse layer.capabilitiesURL.
let reqUrl = layer.url;
let urlParts = reqUrl.split("/geoserver/");
if (urlParts.length === 2) {
let layerParts = layer.name.split(":");
if (layerParts.length === 2) {
reqUrl = urlParts[0] + "/geoserver/" + layerParts [0] + "/" + layerParts[1] + "/" + urlParts[1];
}
}
return (dispatch) => {
// TODO, look ad current cached capabilities;
dispatch(updateNode(layer.id, "id", {
capabilitiesLoading: true
}));
return WMS.getCapabilities(reqUrl, options).then((capabilities) => {
let layers = _.get(capabilities, "capability.layer.layer");
let layerCapability;

layerCapability = _.head(layers.filter( ( capability ) => {
if (layer.name.split(":").length === 2 && capability.name && capability.name.split(":").length === 2 ) {
return layer.name === capability.name;
} else if (capability.name && capability.name.split(":").length === 2) {
return (layer.name === capability.name.split(":")[1]);
} else if (layer.name.split(":").length === 2) {
return layer.name.split(":")[1] === capability.name;
}
return layer.name === capability.name;
}));
if (layerCapability) {
dispatch(updateNode(layer.id, "id", {
capabilities: layerCapability,
capabilitiesLoading: null,
boundingBox: layerCapability.latLonBoundingBox,
availableStyles: layerCapability.style && (Array.isArray(layerCapability.style) ? layerCapability.style : [layerCapability.style])
}));
}
// return dispatch(updateNode(layer.id, "id", {capabilities: capabilities || {"error": "no describe Layer found"}}));

}).catch((error) => {
dispatch(updateNode(layer.id, "id", {capabilitiesLoading: null, capabilities: {error: "error getting capabilities", details: error}} ));

// return dispatch(updateNode(layer.id, "id", {capabilities: capabilities || {"error": "no describe Layer found"}}));

});
};
}

module.exports = {
getDescribeLayer, getLayerCapabilities
};
92 changes: 0 additions & 92 deletions web/client/actions/layers.js
Original file line number Diff line number Diff line change
Expand Up @@ -22,13 +22,6 @@ const SHOW_SETTINGS = 'SHOW_SETTINGS';
const HIDE_SETTINGS = 'HIDE_SETTINGS';
const UPDATE_SETTINGS = 'UPDATE_SETTINGS';

// const DESCRIBE_LAYER_LOADED = 'DESCRIBE_LAYER_LOADED';
// const DESCRIBE_LAYER_LOAD_ERROR = 'DESCRIBE_LAYER_LOAD_ERROR';
const WMS = require('../api/WMS');
const WFS = require('../api/WFS');
const WCS = require('../api/WCS');
const _ = require('lodash');

function showSettings(node, nodeType, options) {
return {
type: SHOW_SETTINGS,
Expand Down Expand Up @@ -149,93 +142,8 @@ function invalidLayer(layerType, options) {
};
}

function getDescribeLayer(url, layer, options) {
return (dispatch /* , getState */) => {
return WMS.describeLayer(url, layer.name, options).then((describeLayer) => {
if (describeLayer && describeLayer.owsType === "WFS") {
return WFS.describeFeatureType(url, describeLayer.name).then((describeFeatureType) => {
// TODO move the management of this geometryType in the proper components, getting the describeFeatureType entry:
let types = _.get(describeFeatureType, "complexType[0].complexContent.extension.sequence.element");
let geometryType = _.head(types && types.filter( elem => (elem.name === "the_geom" || elem.type.prefix.indexOf("gml") === 0)));
geometryType = geometryType && geometryType.type.localPart;
describeLayer.geometryType = geometryType && geometryType.split("PropertyType")[0];
return dispatch(updateNode(layer.id, "id", {describeLayer, describeFeatureType}));
}).catch(() => {
return dispatch(updateNode(layer.id, "id", {describeLayer: describeLayer || {"error": "no describe feature found"}}));
});
} else if ( describeLayer && describeLayer.owsType === "WCS" ) {
WCS.describeCoverage(url, describeLayer.name).then((describeCoverage) => {
// TODO move the management of this bands in the proper components, getting the describeFeatureType entry:
let axis = _.get(describeCoverage, "wcs:CoverageDescriptions.wcs:CoverageDescription.wcs:Range.wcs:Field.wcs:Axis.wcs:AvailableKeys.wcs:Key");
if (axis && typeof axis === "string") {
describeLayer.bands = [1 + ""];
} else {
describeLayer.bands = axis.map((el, index) => ((index + 1) + "")); // array of 1 2 3 because the sld do not recognize the name
}

dispatch(updateNode(layer.id, "id", {describeLayer, describeCoverage}));
}).catch(() => {
return dispatch(updateNode(layer.id, "id", {describeLayer: describeLayer || {"error": "no describe coverage found"}}));
});
}
return dispatch(updateNode(layer.id, "id", {describeLayer: describeLayer || {"error": "no describe Layer found"}}));

});
};
}

function getLayerCapabilities(layer, options) {
// geoserver's specific. TODO parse layer.capabilitiesURL.
let reqUrl = layer.url;
let urlParts = reqUrl.split("/geoserver/");
if (urlParts.length === 2) {
let layerParts = layer.name.split(":");
if (layerParts.length === 2) {
reqUrl = urlParts[0] + "/geoserver/" + layerParts [0] + "/" + layerParts[1] + "/" + urlParts[1];
}
}
return (dispatch) => {
// TODO, look ad current cached capabilities;
dispatch(updateNode(layer.id, "id", {
capabilitiesLoading: true
}));
return WMS.getCapabilities(reqUrl, options).then((capabilities) => {
let layers = _.get(capabilities, "capability.layer.layer");
let layerCapability;

layerCapability = _.head(layers.filter( ( capability ) => {
if (layer.name.split(":").length === 2 && capability.name && capability.name.split(":").length === 2 ) {
return layer.name === capability.name;
} else if (capability.name && capability.name.split(":").length === 2) {
return (layer.name === capability.name.split(":")[1]);
} else if (layer.name.split(":").length === 2) {
return layer.name.split(":")[1] === capability.name;
}
return layer.name === capability.name;
}));
if (layerCapability) {
dispatch(updateNode(layer.id, "id", {
capabilities: layerCapability,
capabilitiesLoading: null,
boundingBox: layerCapability.latLonBoundingBox,
availableStyles: layerCapability.style && (Array.isArray(layerCapability.style) ? layerCapability.style : [layerCapability.style])
}));
}
// return dispatch(updateNode(layer.id, "id", {capabilities: capabilities || {"error": "no describe Layer found"}}));

}).catch((error) => {
dispatch(updateNode(layer.id, "id", {capabilitiesLoading: null, capabilities: {error: "error getting capabilities", details: error}} ));

// return dispatch(updateNode(layer.id, "id", {capabilities: capabilities || {"error": "no describe Layer found"}}));

});
};
}


module.exports = {changeLayerProperties, changeGroupProperties, toggleNode, sortNode, removeNode, invalidLayer,
updateNode, layerLoading, layerLoad, layerError, addLayer, removeLayer, showSettings, hideSettings, updateSettings,
getDescribeLayer, getLayerCapabilities,
CHANGE_LAYER_PROPERTIES, CHANGE_GROUP_PROPERTIES, TOGGLE_NODE, SORT_NODE,
REMOVE_NODE, UPDATE_NODE, LAYER_LOADING, LAYER_LOAD, LAYER_ERROR, ADD_LAYER, REMOVE_LAYER,
SHOW_SETTINGS, HIDE_SETTINGS, UPDATE_SETTINGS, INVALID_LAYER
Expand Down
3 changes: 2 additions & 1 deletion web/client/plugins/Styler.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,8 @@ const {getWindowSize} = require('../utils/AgentUtils');
const {setVectorLayer} = require('../actions/vectorstyler');
const {setRasterLayer} = require('../actions/rasterstyler');
const {toggleControl} = require('../actions/controls');
const {getDescribeLayer, getLayerCapabilities, changeLayerProperties} = require('../actions/layers');
const {changeLayerProperties} = require('../actions/layers');
const {getDescribeLayer, getLayerCapabilities} = require('../actions/layerCapabilities');
const {saveLayerDefaultStyle, reset} = require('../actions/styler');

const {layersSelector} = require('../selectors/layers');
Expand Down