-
Notifications
You must be signed in to change notification settings - Fork 27
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
Expand the Facets proposal with more details and new requirements #320
base: master
Are you sure you want to change the base?
Conversation
Quick reply before checking;
|
The second "drill-down" query mirrors the typical behavior of a user when using facets:
Alternatively a user could decide to zoom in on a histogram, which would also trigger the drill-down query. |
WRT the term "facets". I did a bit of research. First, this terms, after checking numerous OGC Standards, is not used. This is would be the first use in an OGC Standard. Therefore, a very clear definition of what is meant by ther term "facet" is required, Second, I also researched the use of the term on the broader Catalog context. While "facet search" is in Wikipedia (https://en.wikipedia.org/wiki/Faceted_search). If one digs more deeply, in Library Science, there are pre-facet and post-facet searches. In another context, facets are shown as panels of aggregated results on a web page (e.g. HCL Software). Finally, the use of the term facet in GIS goes back to 1965, although in a completely different context - a unit of storage As such, if the term facet/facets is to be used in the API - Records standard, then the term need to be very clearly defined and formally agreed to. Oh, and to just make life interesting: Forecasting a Continuum of Environmental Threats (FACETs) |
Thanks for the analysis @cnreediii. I feel like the term "aggregation" is closer to what is really happening, and would also better apply to the Features API (which is our intention eventually) where the concept of "faceted search" would sound even more unusual. |
Hi team, great work here, i'm wondering, why are we using a dictionary for the facets, with the facet property as key, wouldn't it be more logical to have an array of facets (similar to a array of features)? {"facets": [{
"id": "keywords",
"type": "",
"buckets":[]
}]} it could have been me suggesting this at one point, but now while implementing, i have my doubts |
No I think I came up with the dict structure and indeed it is useless if we end up repeating the id in the facet object; I also liked having an |
another thought here; which properties to add as facet should be a configuration, not something defined in the api schema, this allows for adjustments of the configured facets, without redefining the api definition alternatively it can be argued that by hardcoding the facets in the api schema, it will be clear by users beforehand which facets will be made available in the search result |
0e564c9
to
ddfa49a
Compare
proposals/facets/README.md
Outdated
|
||
#### Examples | ||
|
||
The facet `hasDownloads` will return the amount of records which have at least 1 distribution of a download type (CSV, Excel...): |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There is only one facet here "Available by"
- download service
- view service
* `hasMaps` : 11495 records | ||
The facet `is available by` will provide 2 sub-queries : | ||
- `Download service` returns the amount of records which have at least 1 distribution of a download type (CSV, Excel...): | ||
- `Visualization service` returns the amount of records which have at least 1 distribution of a type (WMS, WMTS...): |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
since we're in ogc-api realm, would be good to add ogc-api type of examples; eg OGCAPI:Maps, OGCAPI:tiles
Discussion/refresh during 2024 Joint OGC-ASF-OSGeo Code Sprint: Two Requirements Classes: Simple and Advanced Simple
Advanced
|
Discussion with @cportele:
Decision:
Next steps are to close this PR and start the extension draft. |
About the quaryable configuration; can it have 3 options:
facets parameter can then have 3 values:
I most appreciate the behavior of some facets being returned with every search result, without the need to configure a facets parameter |
want to refer to opengeospatial/ogcapi-features#681 facet functionality could offer the requested functionality |
Just to be sure I understand. Facets, also called smart filters, are a type of search filter that customers use to narrow down their search results quickly. Facets can be static (set up for every query) or dynamic (they can change depending on the context of the search query). Am I correct in my understanding? There is a fairly wide scope of definitions by different vendors. Thanks |
FYI as decided in #320 (comment), PR #372 adds OGC API - Records - Part 2: Facets. Once this PR is merged we can move the contents of this PR into the appropriate areas of the extension. |
This PR builds on top of the work by @pvgenuchten to offer a more detailed proposal, including two new endpoints which should let API consumers build a robust user experience.
The YAML schemas have not been updated yet, and there are several questions which still have to be answered:
/items
response? (instead of just letting them say yes/no)/aggregation/{aggregationId}
) which will carry over many of the query params used in/items
so as to end up matching the same records as a search on/items
would?Looking forward to discuss all these topics further before the end of the sprint! Please leave comments/suggestions as needed.