Skip to content

GSIP 131

Jody Garnett edited this page Aug 10, 2015 · 16 revisions

GSIP 131 - Style Generation for all formats

Overview

Promote org.geoserver.importer.StyleGenerator to a core class and add support for generating styles of all formats (SLD, CSS, ...).

Proposed By

Torben Barsballe

Assigned to Release

This proposal is for GeoServer 2.8-beta.

State

  • Under Discussion
  • In Progress
  • Completed
  • Rejected
  • Deferred

Motivation

Style Generation is a useful utility that has so far been limited to SLD styles generated by the importer extension. This change would allow core GeoServer methods to access this functionality, and extend style generation to support all formats. One potential future use case is the ability to generate a default style when creating a new style in geoserver (Either through the Web UI, the REST API, or programatically). One particular benifit is the ability to generate default CSS styles. Currently, SLD styles cannot be converted to CSS, and there is no code that generates CSS styles - all styles must be written by hand (or copied from the documentation). While importer will retain its current functionality, this also opens up the potential to generate non-SLD defualt styles during an import, in cases where other formats are preffered.

Proposal

API Change

Move org.geoserver.importer.StyleGenerator and associated tests (StyleGeneratorTest) and resources (template_point.sld, template_line.sld, template_polygon.sld, template_generic.sld) in gs-importer to org.geoserver.catalog.StyleGenerator in gs-main.

Add the public String getTemplate(StyleType type) method to the abstract class StyleHandler in gs-main. StyleGenerator will call this method to obtain the template for a given StyleHandler.

public abstract class StyleHandler {
    /**
     * Generated template using provided substitutionMap from StyleGenerator.
     * <ul>
     * <li>color: java.aw.Color to use during substitution</li>
     * <li>colorName: Human readable color name, for use generating comments</li>
     * <li>layerName: Layer name, for use generating comments</li>
     * </ul>
     */
    String getTemplate(StyleType type, Map<String,Object> substitutionMap);
}

Where has been made public:

public enum StyleType {
   POINT,
   LINE,
   POLYGON,
   RASTER,
   GENERIC
}

Add a new Generate from template style section to the New/Edit Style page, with a drop-down menu to select a template and a link to generate the style.

Implementation

StyleGenerator.createStyle() will be modified to accept a StyleHandler, used to retrieve the style templates an other information specific to the style format. The importer extension will be modified to use the updated StyleGenerator. CSS template styles will be created, to be returned by CSSHandler.getTemplate().

Feedback

Backwards Compatibility

Since this is solely an addition to the core geoserver API, there should be no conflicts. When a StyleHandler does not implement getTemplate(), and UnsupportedOperationException will be thrown. In this case, the StyleGenerator try to convert an SLD template to the requisite format. This provides some measure of support for third-party formats.

Voting

  • Alessio Fabiani
  • Andrea Aime
  • Ben Caradoc-Davies
  • Christian Mueller
  • Gabriel Roldán
  • Jody Garnett
  • Jukka Rahkonen
  • Justin Deoliveira
  • Phil Scadden
  • Simone Giannecchini

Links

Email Discussion

Clone this wiki locally