So this is what I get for missing the Ignite sessions at WhereCampDC*:
http://twitter.com/#!/spara/status/81369354746331136
*I got to dance with my daughter and help her chase fireflies so I win.
The worst-kept rumor/secret in recent memory is now “out there” so here are my thoughts:
- It makes perfect sense for OGC. They were caught completely flatfooted by REST and this provides an expedient (and already widely-deployed) way to catch up, if they adopt it. Esri’s API works pretty well and is certainly a nice starting point for a spec.
- It’s also a no-brainer for Esri. If adopted, they are automatically OGC-compliant and may even be able to call ArcGIS Server a reference implementation. There’s no way that doesn’t benefit them and they would probably be the biggest winner in this. What would be nice is if Esri followed this up with some demonstration of commitment to the community such as releasing one or more of their REST API clients as open-source.
- I assume this includes the Esri JSON syntax (my term), which is the underpinning of the GeoServices REST Specification. That leaves me wondering about GeoJSON. It’s a community specification that’s been widely adopted across the industry. It wouldn’t be very hard to augment the GeoServices spec with “f=geojson” on the calls that are appropriate but I can’t see OGC doing that for a spec they don’t own (although, by doing so, they would live into the “open” part of their name).
For what it’s worth, I like GeoJSON and find it tighter and more focused than the Esri syntax for what it does and I think it should be part of the discussion somehow. It’s not entirely a 1-to-1 match as GeoJSON is designed for transmitting geometries and features. The Esri JSON syntax is broader in scope, addressing not only geometries but also other functions such as listing available endpoints and fetching endpoint metadata and such. So GeoJSON, in its current form, would not address all of the needs of the GeoServices spec but would certainly be a viable option for functions such as returning the results of feature layer queries.
- It would be interesting to see whether the spec gets implemented across the community. It has been available for months but there hasn’t been a wide uptake. The only example I am aware of is Arc2Earth’s cloud work which implements it on top of their Google-AppEngine-based services. Maybe OGC adoption would provide the kind of “top cover” that will give developers peace-of-mind. (Note: My company is an Arc2Earth reseller.)
- If the GeoServices REST Specification (Beware, PDF) is adopted by OGC, it will continue a trend begun with the adoption of KML and GeoRSS in which they formally adopt community and de facto standards that have emerged and been proven in the industry. I think that’s a valid approach that can exist alongside their usual standards development process. This case is a little different than those in that it was developed by a single vendor (like KML) and has been released and documented (like KML) but hasn’t really been widely implemented outside its initial vendor base prior to consideration (unlike KML). That’s a subtle but important difference that bears watching.
Those were some of my initial thoughts upon hearing this. If it happens, it’s obviously of immediate benefit to both OGC and Esri. The lack of any viable presence by OGC in this area has left a void that has begun to be filled by other efforts, including Esri’s. It’ll be interesting to see the longer-term implications. I think James is correct that we can expect to see implementations on server platforms such as MapServer and GeoServer but I wonder how relevant it will be in the emerging environment surrounding big data and hosted (i.e. cloud) infrastructures. An end-to-end GIS interface may be less relevant than a more atomic approach that allows support for spatial types to be injected as needed into a larger framework (for example, supporting use of GeoJSON on specific calls the way Twitter does). There’s room for both approaches but distinct paths are beginning to emerge.
interestingly someone popped up on the GeoServer list offering to implement ESRI rest on top of GeoServer this week.
I’m not surprised. I don’t think it would be a difficult thing to do and would probably work well on top of GeoServer. At this point, it would probably just buy better interaction with Esri clients, but that can be accomplished with the current OGC interfaces. It’s all just interesting times right now.