Skip to content

Open311 GeoReport v2 API - See the official documentation http://wiki.open311.org/GeoReport_v2/ for more information.

Notifications You must be signed in to change notification settings

mrich316/Open311.GeoReportApi

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

46 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Open311 GeoReport v2 API

See the official documentation for more information.

This project aims to create a ASP.NET Core framework to ease implementation of the GeoReport v2 api from Open311.

For early adopters only.

As of today, this project is an aspnet web api targeting netstandard2.0, making it available to all major platforms (windows, linux, macos). To use as-is, you can implement interfaces in the namespace Open311Open311.GeoReportApi.Services and replace the in-memory implementations in Startup.cs.

We know this is sub-optimal and we will try to create a reusable (and documented) owin middleware distributed by nuget.org. This should simplify distribution and adoption by the community.

Implementation Status

The GeoReport v2 specification defines 6 methods. We aim to implement all of them except for GET Service Request Id.

We currently support xml and json formats in utf-8. Please note the responses may not be fully compliants as of today, we are still in development.

API Method Implementation Status Compliance
Service Discovery planned
API Keys planned
GET Service List implemented xml/json
GET Service Definition implemented xml/json
POST Service Request implemented xml/json
GET Service Request Id not planned
GET Service Requests implemented xml/json
GET Service Request implemented xml/json

Since the storage of service requests is highly implementation specific, only interfaces are provided. The implementation is YOUR responsibility. It can really be any sources: web services, elastic storage, databases, erp, etc. To evaluate the framework, in-memory stores are provided, so you can test the solution without any development efforts.

Known Problems and Limitations

API Keys required to normally submit a new service request are not currently used. Also, we are missing a lot of unit tests in model logics and value providers. Work is being planned to address these issues.

The published signatures by our implementation are not validated for official compliance (yet). Once the code stabilize, we will make sure it is on par with the standard.

The jurisdiction is mandatory in our implementation, but it can be set to any default value (if not provided by the caller). You should be able to make it work in any scenarios.

The media_url property of a service request is implementation specific. We have not evaluated what the api should accept or not. From the official docs:

A convention for parsing media from this URL has yet to be established, so currently it will be done on a case by case basis much like Twitter.com does. For example, if a jurisdiction accepts photos submitted via Twitpic.com, then clients can parse the page at the Twitpic URL for the image given the conventions of Twitpic.com. This could also be a URL to a media RSS feed where the clients can parse for media in a more structured way.

About

Open311 GeoReport v2 API - See the official documentation http://wiki.open311.org/GeoReport_v2/ for more information.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published