Mercurial > dive4elements > river
view flys-artifacts/doc/conf/meta-data.xml @ 1154:24b87650136f
Fix ArrayIndexOutOfBounds in certain cases.
flys-artifacts/trunk@2685 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Felix Wolfsteller <felix.wolfsteller@intevation.de> |
---|---|
date | Fri, 09 Sep 2011 12:37:52 +0000 |
parents | 94df49614d92 |
children | dd59431d648f |
line wrap: on
line source
<?xml version="1.0" encoding="UTF-8" standalone="yes"?> <dc:template xmlns:dc="http://www.intevation.org/2011/Datacage"> <datacage> <dc:choose> <dc:comment> User specific part ------------------ </dc:comment> <dc:when test="dc:contains($parameters, 'user-id')"> <old_calculations> <dc:context connection="user"> <dc:statement>SELECT u.id AS user_id, c.id AS collection_id FROM collections c JOIN users u ON c.user_id = u.id WHERE u.gid = CAST(${user-id} AS uuid) ORDER BY c.creation DESC </dc:statement> <dc:elements> <dc:context> <dc:statement>SELECT id AS a_id, state AS a_state, gid AS a_gid, creation AS a_creation FROM master_artifacts m WHERE collection_id = ${collection_id} AND gid <> CAST(${artifact-id} AS uuid) AND EXISTS ( SELECT id FROM artifact_data WHERE artifact_id = m.id AND k = 'river' AND v = ${river}) </dc:statement> <dc:elements> <dc:choose> <dc:when test="dc:contains($artifact-outs, 'longitudinal_section')"> <dc:context> <dc:statement>SELECT id AS out_id FROM outs WHERE artifact_id = ${a_id} AND name = 'longitudinal_section' </dc:statement> <dc:elements> <dc:context> <dc:statement>SELECT name AS facet_name, num as facet_num, description AS facet_description FROM facets WHERE out_id = ${out_id} ORDER BY num ASC, name DESC </dc:statement> <longitudinal_section_columns> <dc:attribute name="description" value="${river} ${a_creation}"/> <dc:elements> <dc:element name="${facet_name}"> <dc:attribute name="description" value="${facet_description}"/> <dc:attribute name="ids" value="${facet_num}"/> <dc:attribute name="factory" value="winfo"/> <dc:attribute name="artifact-id" value="${a_gid}"/> <dc:attribute name="out" value="longitudinal_section"/> </dc:element> </dc:elements> </longitudinal_section_columns> </dc:context> </dc:elements> </dc:context> </dc:when> </dc:choose> </dc:elements> </dc:context> </dc:elements> </dc:context> </old_calculations> </dc:when> <dc:comment> System specific part -------------------- </dc:comment> <dc:otherwise> <dc:context connection="system"> <dc:statement> SELECT id AS river_id, name as river_name FROM rivers WHERE lower(name) LIKE lower(${river}) </dc:statement> <dc:elements> <river> <dc:attribute name="name" value="${river_name}"/> <dc:attribute name="db-id" value="${river_id}"/> <dc:if test="dc:contains($artifact-outs, 'computed_discharge_curve')"> <discharge-table-nn> <discharge-table-gauge> <dc:context> <dc:statement> SELECT id AS gauge_id, name AS gauge_name FROM gauges WHERE river_id = ${river_id} </dc:statement> <dc:elements> <gauge> <dc:attribute name="name" value="${gauge_name}"/> <dc:attribute name="db-id" value="${gauge_id}"/> <dc:context> <dc:statement> SELECT description AS gauge_desc, d.id AS discharge_id, ti.start_time AS g_start, ti.stop_time AS g_stop FROM discharge_tables d JOIN time_intervals ti ON d.time_interval_id = ti.id WHERE d.gauge_id = ${gauge_id} AND d.kind = 1 </dc:statement> <dc:elements> <historical> <dc:attribute name="name" value="${gauge_desc}"/> <dc:attribute name="from" value="${g_start}"/> <dc:attribute name="to" value="${g_stop}"/> <dc:attribute name="db-id" value="${discharge_id}"/></historical> </dc:elements> </dc:context> </gauge> </dc:elements> </dc:context> </discharge-table-gauge> <fixations> <dc:attribute name="id" value="fixations-${river_id}"/> <dc:context> <dc:statement> SELECT id AS fix_id, description AS fix_description FROM wsts WHERE kind = 2 AND river_id = ${river_id} </dc:statement> <dc:elements> <fixation> <dc:attribute name="name" value="${fix_description}"/> <dc:attribute name="db-id" value="${fix_id}"/> <columns> <dc:context> <dc:statement> SELECT id AS fix_column_id, name AS fix_column_name FROM wst_columns WHERE wst_id = ${fix_id} ORDER by position </dc:statement> <dc:elements> <column> <dc:attribute name="name" value="${fix_column_name}"/> <dc:attribute name="db-id" value="${fix_column_id}"/></column> </dc:elements> </dc:context> </columns> </fixation> </dc:elements> </dc:context> </fixations> <flood-protections> <dc:attribute name="id" value="flood-protections-${river_id}"/> <dc:context> <dc:statement> SELECT id AS prot_id, description AS prot_description FROM wsts WHERE kind = 5 AND river_id = ${river_id} </dc:statement> <dc:elements> <flood-protection> <dc:attribute name="name" value="${prot_description}"/> <dc:attribute name="db-id" value="${prot_id}"/> <columns> <dc:context> <dc:statement> SELECT id AS prot_column_id, name AS prot_column_name FROM wst_columns WHERE wst_id = ${prot_id} ORDER by position </dc:statement> <dc:elements> <column> <dc:attribute name="name" value="${prot_column_name}"/> <dc:attribute name="db-id" value="${prot_column_id}"/></column> </dc:elements> </dc:context> </columns> </flood-protection> </dc:elements> </dc:context> </flood-protections> <flood-water-marks> <dc:attribute name="id" value="flood-water-marks-${river_id}"/> <dc:context> <dc:statement> SELECT id AS fw_id, description AS fw_description FROM wsts WHERE kind = 4 AND river_id = ${river_id} </dc:statement> <dc:elements> <flood-water-mark> <dc:attribute name="name" value="${fw_description}"/> <dc:attribute name="db-id" value="${fw_id}"/> <columns> <dc:context> <dc:statement> SELECT id AS fw_column_id, name AS fw_column_name FROM wst_columns WHERE wst_id = ${fw_id} ORDER by position </dc:statement> <dc:elements> <column> <dc:attribute name="name" value="${fw_column_name}"/> <dc:attribute name="db-id" value="${fw_column_id}"/></column> </dc:elements> </dc:context> </columns> </flood-water-mark> </dc:elements> </dc:context> </flood-water-marks> <water-levels> <dc:attribute name="id" value="water-levels-${river_id}"/> <dc:context> <dc:statement> SELECT id AS wl_id, description AS wl_description FROM wsts WHERE kind = 0 AND river_id = ${river_id} </dc:statement> <dc:elements> <water-level> <dc:attribute name="name" value="${wl_description}"/> <dc:attribute name="db-id" value="${wl_id}"/> <columns> <dc:context> <dc:statement> SELECT id AS wl_column_id, name AS wl_column_name FROM wst_columns WHERE wst_id = ${wl_id} ORDER by position </dc:statement> <dc:elements> <column> <dc:attribute name="name" value="${wl_column_name}"/> <dc:attribute name="db-id" value="${wl_column_id}"/></column> </dc:elements> </dc:context> </columns> </water-level> </dc:elements> </dc:context> </water-levels> <extra-longitudinal-sections> <dc:attribute name="id" value="extra-longitudinal-sections-${river_id}"/> <dc:context> <dc:statement> SELECT id AS els_id, description AS els_description FROM wsts WHERE kind = 1 AND river_id = ${river_id} </dc:statement> <dc:elements> <extra-longitudinal-section> <dc:attribute name="name" value="${els_description}"/> <dc:attribute name="db-id" value="${els_id}"/> <columns> <dc:context> <dc:statement> SELECT id AS els_column_id, name AS els_column_name FROM wst_columns WHERE wst_id = ${els_id} ORDER by position </dc:statement> <dc:elements> <column> <dc:attribute name="name" value="${els_column_name}"/> <dc:attribute name="db-id" value="${els_column_id}"/></column> </dc:elements> </dc:context> </columns> </extra-longitudinal-section> </dc:elements> </dc:context> </extra-longitudinal-sections> </discharge-table-nn> </dc:if> <dc:if test="dc:contains($artifact-outs, 'computed_discharge_curve')"> <computed-discharge-curve> <mainvalue> <dc:attribute name="factory" value="mainvalue"/> <dc:attribute name="db-ids" value="${river_id}"/> </mainvalue> </computed-discharge-curve> </dc:if> <dc:if test="dc:contains($artifact-outs, 'longitudinal_section')"> <longitudinal-section> <dc:call-macro name="longitudinal_section-recommended"/> <fixations><dc:attribute name="ref" value="fixations-${river_id}"/></fixations> <flood-protections><dc:attribute name="ref" value="flood-protections-${river_id}"/></flood-protections> <flood-water-marks><dc:attribute name="ref" value="flood-water-marks-${river_id}"/></flood-water-marks> <water-levels><dc:attribute name="ref" value="water-levels-${river_id}"/></water-levels> <extra-longitudinal-sections><dc:attribute name="ref" value="extra-longitudinal-sections-${river_id}"/></extra-longitudinal-sections> </longitudinal-section> <dc:macro name="longitudinal_section-recommended"> <annotation> <dc:attribute name="factory" value="annotations"/> <dc:attribute name="ids" value="${river_id}"/> </annotation> </dc:macro> </dc:if> <dc:if test="dc:contains($artifact-outs, 'floodmap')"> <floodmap> <dc:choose> <dc:when test="dc:contains($parameters, 'recommended')"> <dc:call-macro name="flood-map-recommended"/> </dc:when> <dc:otherwise> <dc:call-macro name="flood-map-complete"/> </dc:otherwise> </dc:choose> </floodmap> <dc:macro name="flood-map-recommended"> <dc:comment> FIXME: Following two macros look identical to me. </dc:comment> <kilometrage> <riveraxis> <dc:attribute name="factory" value="riveraxis"/> <dc:attribute name="ids" value="${river_id}"/> </riveraxis> </kilometrage> <rastermap> <background> <dc:attribute name="factory" value="wmsbackground"/> <dc:attribute name="ids" value="${river_id}"/> </background> </rastermap> </dc:macro> <dc:macro name="flood-map-complete"> <kilometrage> <riveraxis> <dc:attribute name="factory" value="riveraxis"/> <dc:attribute name="ids" value="${river_id}"/> </riveraxis> </kilometrage> <rastermap> <background> <dc:attribute name="factory" value="wmsbackground"/> <dc:attribute name="ids" value="${river_id}"/> </background> </rastermap> </dc:macro> </dc:if> </river> </dc:elements> </dc:context> </dc:otherwise> </dc:choose> </datacage> </dc:template>