sascha@2614: package de.intevation.flys.artifacts.services; sascha@2614: sascha@2615: import java.util.List; sascha@2615: sascha@2614: import de.intevation.artifactdatabase.DefaultService; sascha@2614: sascha@2614: import de.intevation.artifacts.CallMeta; sascha@2614: import de.intevation.artifacts.GlobalContext; sascha@2614: import de.intevation.artifacts.Service; sascha@2614: sascha@2615: import de.intevation.flys.artifacts.model.FixingsFilterBuilder; sascha@2615: import de.intevation.flys.artifacts.model.FixingsOverview; sascha@2615: import de.intevation.flys.artifacts.model.FixingsColumn; sascha@2615: import de.intevation.flys.artifacts.model.FixingsColumnFactory; sascha@2615: import de.intevation.flys.artifacts.model.FixingsOverviewFactory; sascha@2615: sascha@2615: import de.intevation.flys.artifacts.model.FixingsOverview.Fixing; sascha@2615: sascha@2615: import de.intevation.flys.backend.SessionHolder; sascha@2615: sascha@2614: import org.apache.log4j.Logger; sascha@2614: sascha@2614: import org.w3c.dom.Document; sascha@2615: import org.w3c.dom.Element; sascha@2615: import org.w3c.dom.NodeList; sascha@2614: sascha@2614: public class FixingsKMChartService sascha@2614: extends DefaultService sascha@2614: { sascha@2614: private static final Logger log = sascha@2614: Logger.getLogger(FixingsKMChartService.class); sascha@2614: sascha@2615: public static final byte [] EMPTY = { sascha@2614: (byte)0x89, (byte)0x50, (byte)0x4e, (byte)0x47, sascha@2614: (byte)0x0d, (byte)0x0a, (byte)0x1a, (byte)0x0a, sascha@2614: (byte)0x00, (byte)0x00, (byte)0x00, (byte)0x0d, sascha@2614: (byte)0x49, (byte)0x48, (byte)0x44, (byte)0x52, sascha@2615: (byte)0x00, (byte)0x00, (byte)0x00, (byte)0x01, sascha@2615: (byte)0x00, (byte)0x00, (byte)0x00, (byte)0x01, sascha@2615: (byte)0x08, (byte)0x00, (byte)0x00, (byte)0x00, sascha@2615: (byte)0x00, (byte)0x3a, (byte)0x7e, (byte)0x9b, sascha@2615: (byte)0x55, (byte)0x00, (byte)0x00, (byte)0x00, sascha@2614: (byte)0x01, (byte)0x73, (byte)0x52, (byte)0x47, sascha@2614: (byte)0x42, (byte)0x00, (byte)0xae, (byte)0xce, sascha@2614: (byte)0x1c, (byte)0xe9, (byte)0x00, (byte)0x00, sascha@2614: (byte)0x00, (byte)0x09, (byte)0x70, (byte)0x48, sascha@2614: (byte)0x59, (byte)0x73, (byte)0x00, (byte)0x00, sascha@2614: (byte)0x0b, (byte)0x13, (byte)0x00, (byte)0x00, sascha@2614: (byte)0x0b, (byte)0x13, (byte)0x01, (byte)0x00, sascha@2614: (byte)0x9a, (byte)0x9c, (byte)0x18, (byte)0x00, sascha@2614: (byte)0x00, (byte)0x00, (byte)0x07, (byte)0x74, sascha@2614: (byte)0x49, (byte)0x4d, (byte)0x45, (byte)0x07, sascha@2615: (byte)0xdc, (byte)0x04, (byte)0x04, (byte)0x10, sascha@2615: (byte)0x30, (byte)0x15, (byte)0x7d, (byte)0x77, sascha@2615: (byte)0x36, (byte)0x0b, (byte)0x00, (byte)0x00, sascha@2615: (byte)0x00, (byte)0x08, (byte)0x74, (byte)0x45, sascha@2615: (byte)0x58, (byte)0x74, (byte)0x43, (byte)0x6f, sascha@2615: (byte)0x6d, (byte)0x6d, (byte)0x65, (byte)0x6e, sascha@2615: (byte)0x74, (byte)0x00, (byte)0xf6, (byte)0xcc, sascha@2615: (byte)0x96, (byte)0xbf, (byte)0x00, (byte)0x00, sascha@2615: (byte)0x00, (byte)0x0a, (byte)0x49, (byte)0x44, sascha@2615: (byte)0x41, (byte)0x54, (byte)0x08, (byte)0xd7, sascha@2615: (byte)0x63, (byte)0xf8, (byte)0x0f, (byte)0x00, sascha@2615: (byte)0x01, (byte)0x01, (byte)0x01, (byte)0x00, sascha@2615: (byte)0x1b, (byte)0xb6, (byte)0xee, (byte)0x56, sascha@2615: (byte)0x00, (byte)0x00, (byte)0x00, (byte)0x00, sascha@2615: (byte)0x49, (byte)0x45, (byte)0x4e, (byte)0x44, sascha@2615: (byte)0xae, (byte)0x42, (byte)0x60, (byte)0x82 sascha@2615: }; sascha@2615: sascha@2615: private static final Output empty() { sascha@2615: return new Output(EMPTY, "image/png"); sascha@2615: } sascha@2614: sascha@2614: @Override sascha@2614: public Service.Output process( sascha@2614: Document data, sascha@2614: GlobalContext globalContext, sascha@2614: CallMeta callMeta sascha@2614: ) { sascha@2614: log.debug("FixingsKMChartService.process"); sascha@2615: sascha@2615: SessionHolder.acquire(); sascha@2615: try { sascha@2615: return doProcess(data, globalContext, callMeta); sascha@2615: } sascha@2615: finally { sascha@2615: SessionHolder.HOLDER.get().close(); sascha@2615: SessionHolder.release(); sascha@2615: } sascha@2615: } sascha@2615: sascha@2615: protected Service.Output doProcess( sascha@2615: Document data, sascha@2615: GlobalContext globalContext, sascha@2615: CallMeta callMeta sascha@2615: ) { sascha@2615: NodeList rivers = data.getElementsByTagName("river"); sascha@2615: NodeList kms = data.getElementsByTagName("km"); sascha@2615: sascha@2615: if (rivers.getLength() == 0 || kms.getLength() == 0) { sascha@2615: log.warn("Missing river and/or km."); sascha@2615: return empty(); sascha@2615: } sascha@2615: sascha@2615: String river = ((Element)rivers.item(0)).getAttribute("name"); sascha@2615: String kmS = ((Element)kms .item(0)).getAttribute("value"); sascha@2615: sascha@2615: if (river.length() == 0 || kmS.length() == 0) { sascha@2615: log.warn("River and/or km empty string."); sascha@2615: return empty(); sascha@2615: } sascha@2615: sascha@2615: double km; sascha@2615: try { sascha@2615: km = Double.parseDouble(kmS); sascha@2615: } sascha@2615: catch (NumberFormatException nfe) { sascha@2615: log.warn("Km '" + kmS + " is not a valid number."); sascha@2615: return empty(); sascha@2615: } sascha@2615: sascha@2615: FixingsOverview overview = FixingsOverviewFactory.getOverview(river); sascha@2615: sascha@2615: if (overview == null) { sascha@2615: log.warn("No overview found for river '" + river + "'"); sascha@2615: return empty(); sascha@2615: } sascha@2615: sascha@2615: FixingsFilterBuilder ffb = new FixingsFilterBuilder(data); sascha@2615: sascha@2615: List columns = overview.filter( sascha@2615: ffb.getRange(), sascha@2615: ffb.getFilter()); sascha@2615: sascha@2615: for (Fixing.Column column: columns) { sascha@2615: FixingsColumn columnData = sascha@2615: FixingsColumnFactory.INSTANCE.getColumnData(column); sascha@2615: if (columnData == null) { sascha@2615: continue; sascha@2615: } sascha@2615: } sascha@2615: // TODO: Implement chart generation! sascha@2615: sascha@2615: return empty(); sascha@2614: } sascha@2614: } sascha@2614: // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :