-
Notifications
You must be signed in to change notification settings - Fork 13
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Coverage and Features from the same /collections/{collectionid|coverageid}? #65
Comments
I see no problem with a collection providing both vector features and a coverage. The vector features would be accessed via /collections/{collectionId}/items and the coverage would be accessed via /collections/{collectionId}/coverage. The question still stands as to what "itemType" the collection should declare itself as. Perhaps "itemType" should be allowed to be an array, e.g., [ "featureSet", "coverage" ]. CubeWerx is finding the need to allow collections that provide neither vector features nor coverages, but merely provides maps and tiles via /collections/{collectionId}/map, etc. Such can be the case when it's cascading map-only services such as WMS, or when the user doesn't have authorization to access the source data. Should an "itemType" enumeration value for this type of collection be defined too? Perhaps "map" could be an "itemType", so a collection that provides both coverages and maps could declare its "itemType" to be [ "coverage", "map" ], while a map-only collection could declare its "itemType" as simply "map". I don't like the idea of having separate /collections and /coverages endpoints. That splits the endpoint hierarchy up way too early. E.g., where would map-only collections go? And where would catalogues (and other future collection types) go? |
I see one hiccup in my suggestion already. I assume "itemType" is meant to indicate the type of items to expect from the /collections/{collectionId}/items endpoint. That's problematic right there, because not all collections will have a working /items endpoint (coverages and map-only collections being prime examples). I don't want to rock the boat to much, but perhaps this field should be called "collectionType" instead, and be an array. So a "collectionType" value of [ "featureSet", "coverage", "map" ] would clearly indicate the collection can provide vector features, a coverage, and a map. The "OGC API - Features" specification would specify that vector features of "featureSet" collections can be accessed at /collections/{collectionId}/items, the "OGC API - Coverages" specification would specify that the coverage of "coverage" collections can be accessed at /collections/{collectionId}/coverage, and the "OGC API - Maps" specification would specify that map layers of "map" collections can be accessed at /collections/{collectionId}/map. |
In addition, all three of these endpoints (.../items, .../coverage and .../map) would be listed in the "links" section of the /collections/{collectionId} endpoint resource, with the appropriate "rel" types. |
I just want to make the point that re-using @pomakis said:
At
Since catalog items are functionally features, they work with By saying "map-only collections" and "and other future collection types" you are presuming re-use of collections as a flexibly typed container for geospatial resources. Do you see how this is circular reasoning? Is there a reason to not split the endpoint hierarchy earlier that doesn't presume the definition of To try and focus here, let me reiterate my questions and see if we can start to progress this.
I think the answer here is no, so an action should be taken to change that wording if this collections debate ends up with us using
It seems this hasn't been fully thought through. Is it an array? Do we need a
I don't think this has been answered.
I don't think this has been answered. |
I think part of the confusion here is what the "itemType" property means. It certainly needs some clarification. I think the intent of it is to declare the type of items served by the /collections/{collectionId}/items endpoint. For vector-feature collections the itemType is "feature" and for catalogue collections the item type is "record". For other types of collections (such as coverages and map-only collections) there is no /collections/{collectionId}/items endpoint, so perhaps it stands to reason that such collections shouldn't declare an item type. I think it can be argued that a collection can be both a coverage and a feature collection if it has both /collections/{collectionId}/coverage and /collections/{collectionId}/items endpoints. In this case it would declare an "itemType" of "feature", because that's what the /collections/{collectionId}/items endpoint would serve. However, I'm not even sure if it makes conceptual sense for a spatial data resource to be both a coverage and a feature collection. |
Yes, I am. I thought that was one of the main points of the OGC API. Let's explore what things would look like if we have separate /collections, /coverages and /maps endpoints. If a collection is mappable, would the map be accessed with /collections/{collectionId}/map or with /maps/{mapId}?
I honestly think part of the problem here is the term "collection". It (in my opinion) unnecessarily begs the question of "collection of what?". It understandably makes the "OGC API - Coverages" and "OGC API - Maps" people uneasy, because what is a coverage a collection of? And what is a map a collection of? One could say that a coverage is a collection of samples and a map is a collection of pixels, but these aren't typically the units of interaction with these types of resources. So coverages and maps fit a bit uneasily under the /collections endpoint. But I don't think the solution is to therefore split things up into different endpoints. I think we need to provide a clearer definition of the term "collection" that doesn't beg the question of "collection of what?", or else replace it with a different term. "Spatial data resource" is unfortunately a bit too verbose to use as a path element in a URL. |
Thanks for the thoughtful responses. And apologies for being a bit blunt earlier. I was totally conflating "itemType" and (the missing) "collectionType". Realizing now that a collection with no items would not have an "itemType" at all actually makes this issue even stranger. Does anyone see a need to declare a "collectionType" so a client can tell that a given collection is either a feature collection or something else? Would we expect Features to add a "collectionType" of "featureCollection"? I suppose my first question stands though -- if a collection is to be accessed as either features or a coverage, how do we reconcile the statement that the collection is a coverage? And yes, there is such a thing as a feature-coverage that's actually very common. This all comes back to as you say:
A lot of people have been going on that assumption, IMHO, without really having thought it through. API-Features restricts an API to distribution of one dataset. This means that each collection is some grouping of the features in the dataset. Using this logic, an OGC API is actually just a web API that gives access to a dataset (or some functionality). Re:
I don't think putting the dataset access down under collections helps with that. There will always be the case that the service-in-question doesn't contain the data that needs to be included or things need to be handled by reference for whatever reason. Whether the information is off the root of the API or under a collections path is kind of irrelevant. Finally -- you are right re the collections term. Jamming all this stuff that is kinda sorta not really a collection under that end point name is problematic. IMHO, the solution is to use end points off the root that are better suited -- As an initial core accross OGC-API, again IMHO, we should restrict these APIs to distribute one and only one dataset. As a near-term additional specification, we should build standard methods to integrate multiple OGC-API dataset distributions under some kind of hierarchical structure as has been discussed over in opengeospatial/ogcapi-common#11. There are a ton of ways that this could be done -- none of which have been adequately explored. |
I was one of the original supporters of the idea of having /collections/{CollectionId}/coverage After seeing the endless discussions about I deeply, deeply regret to have been one of the first supporting the idea. It was a dream to see all services in one comprehensive API but it has become a nightmare. I believe we need a way out. And one way out is the one proposed by @dblodgett-usgs:
I support this idea and we should start exploring the options. Back to coverages, I'm supporting the idea of going back to /coverages and allowing the coverage group to have full flexibility in what they need to have a powerful OGC API coverages. I'm supporting to have a OWS Common that allows a single dataset to be served as collections (only for features) or coverages (only for... can you guess?) Possible hierarchical structure; Who has specified "datasets"? nobody yet. I do not care: it is just links; HTTP allows that. In the future we could define "datasets" or "stac" or "records"... who knows. I insist: we need a way out. I'm sorry. I was wrong. |
Cc: @jerstlouis @Schpidi |
@joanma747 I back the dream, I am not giving up on it, I am sad to see you regret it and to say you were wrong :) But I understand feeling this way after some of the pushback it has triggered lately, and I agree we need to find a way to settle these discussions. However in this consortium of 520+ member organizations, pushback from a few does not necessarily mean the idea is fundamentally wrong, and if we can better understand and address the concerns of those raising issues, perhaps even they might come to find it adequate. At our Coverage meeting this last Wednesday both @Schpidi and @tomkralidis were very supportive of the current approach, where coverages re-use and extend this common approach to geospatial data for Coverages. @tomkralidis in particular agreed how convenient this is from a GIS client to access data sources the same way regardless of their types. If both Features and Coverages are already agreeing about a shared manner to distribute data, why is there so much controversy? Keep in mind that a single dataset may contain both feature collections and coverages. |
No, as you could have both /coverage and /items for the two ways to access it.
itemType was introduced specifically for Features and Records, and as such would be part of the "extended" base geospatial resource description, not the Common part. It does add to the confusion, unfortunately.
A collectionType would not help, as a single geospatial resource might have multiple ways to access it. Currently, the "type" property of links is the only way to determine. I believe we need something more, e.g. an array of supported access mode, "accessAPIs" : [ "Features", "Coverage" ], and/or additional links target attributes.
It depends whether one wants to link to the spatial resource while being agnostic of access API, or link specifically to a Features or Coverage access API. |
@joanma747 I don't think you were wrong; actually quite the opposite! In my simple-minded view of coverages, I see them as a collection of measurements (samples) taken with reference to some subdivision/tessellation of some object space that is somehow geo-located. You also need to know what measurements are being taken in each subdivision/tesselation of the object space. I believe that in the WCS specification these are called the rangeset, the domain set and the range type. To me, the domain set feels more like metadata/description about the coverage since it is basically telling you how the object space/world was cut up. I believe the object space/world can be cut up in many different ways -- it can be a regular grid, or some other type of tessellation (e.g. hexagons) or even something irregular like county boundaries (?); not sure about that last one but seem to make sense to me. For lack of a better term, I am going to refer to these little sub-spaces of the object space/world as "cells". Similarly, the range type also feels like metadata/description about what measurements are being made in each cell of the domain set. Finally, the range set feels like the "data" of a coverage since those are the actual measurements or observations that are taken inside each "cell" of the domain set. So, if I am understanding everything correctly, a coverage is a collection of measurements each made inside of some defined subdivision (i.e. "cell") of an object space. Associated with each coverage is some description about the "cells" and some description about what measurements/observations were taken in each cell. Assuming this is correct then I don't see why the /collection/{collectionId} path does not work! I see at least several endpoints that emerge...
Now, back to /collection/{collectionId}/items. Someone earlier mentioned that it is possible that a coverage can be accessed as a feature. I am not sure what exactly that means. Does it mean that the cells (and the measurements therein) of a coverage are retrieved as individual features or does it mean that there is some other set of features associated with the coverage that can be retrieved. Dunno but in either case if these feature thingies are retrieved as discreet items, then the /collections/{collectionId}/items endpoint seems the natural access path. This approach is completely analogous to the map subtree that is being defined off of /collections/{collectionId} path for getting maps and ties into what both @pomakis and @jerstlouis seem to be saying. So,@joanma747 I don't think you made a mistake at all ... with my limited understanding of coverages is all seems to hang together. It is not perfect but it does seem to resolve an awful lot of problems we had with the old Web APIs that seemed to be silos unto themselves! |
Hi all: simplistic thoughts out loud:
Suggestions:
|
@tomkralidis The problem with "collectionType" enum, is that a collection could be available as both a coverage and a feature collection, or as a coverage and 3D Tiles. This is why I was suggesting earlier an array of such an enum instead, like "accessAPIs" or "availableTypes" or even "collectionTypes". |
Recommendation:
Dafinitions:
|
@cmheazel Agreeing with everyting except 5, and the Collection definition which goes against the one agreed in Part 2: Geospatial data. As previously discussed in common, itemType is singular. |
I believe this issue can be closed as Overcome By Events, and also a possible duplicate of #25 As mentioned there and in my comment just above:
|
Coverages SWG call: Agreed to close. |
In 7.4.1 Collections there are a few things that could use some clarification. These questions are intentionally leading some discussion regarding #8 and opengeospatial/ogcapi-common#140.
First, there is the following text:
Is this precluding a spatial data resource that is both a coverage AND a feature-collection?
Second, in 7.4.2.2 response there is:
What is the expected itemType for a coverage that can be accessed as both a coverage or features?
Spatial data servers typically list datasets available from the server in some kind of catalog. This catalog would typically lists "access types" for each dataset. In the case of a dataset with both features and coverages access, what would the server link to in both cases?
In the case of a feature collection, it's clear. it would link to the collection.
e.g. https://info.geoconnex.us/collections/hu02
But what if that collection is both accessible as a feature collection and a coverage? Would the server link to the same collection resource? Would it link to
/collections/{coverageid}/coverage/
?The last question is what are we gaining by trying to overload
/collections
and have one link relationdata
? As the questions above illustrate, the basic details of cataloging collections of just two types -- especially if both types are desired at the same time -- are not well established. What would be lost if we used/coverages
and a link relation specific to coverage access instead of/collections
at the root of the coverages API?The text was updated successfully, but these errors were encountered: