-
-
Notifications
You must be signed in to change notification settings - Fork 490
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Upgrade guidance for geonetwork 3 users
Including mitigation guidance for removed serivces Signed-off-by: Jody Garnett <jody.garnett@gmail.com>
- Loading branch information
1 parent
65b9473
commit 3c15eed
Showing
23 changed files
with
421 additions
and
198 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file not shown.
Binary file not shown.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,44 +1,32 @@ | ||
# OpenSearch and INSPIRE ATOM {#opensearch-and-atom} | ||
# OpenSearch | ||
|
||
!!! warning | ||
|
||
Not yet available in version 4. | ||
Unavailable since version 4.0.0. | ||
|
||
There is no known sponsor or interested party for implementing OpenSearch. | ||
|
||
## OpenSearch | ||
The OpenSerach API provides a serivce description advertised in the HTML. | ||
|
||
The catalog provides an opensearch entry point at <http://localhost:8080/geonetwork/srv/eng/portal.opensearch>. This service is advertised in the HTML. | ||
Browsers detect the availability of opensearch by checking the index page at the root of the (sub)domain. Setup required defining a rewrite rule forwarding requests to the geonetwork application. | ||
|
||
![](img/opensearch.png) | ||
Reference: | ||
|
||
Browsers detect the availability of opensearch by checking the index page at the root of the (sub)domain. If you install geonetwork in a subfolder, consider to set up a rewrite rule forwarding the index request to the subfolder. | ||
* [OpenSearch](https://www.ogc.org/standard/opensearch/) (Open Geospatial Consortium) | ||
|
||
An example of such a rewrite rule in Apache: | ||
## Upgrading from GeoNetwork 3.0 Guidance | ||
|
||
``` text | ||
RewriteEngine on | ||
RewriteRule "^/$" "/geonetwork/" [R] | ||
``` | ||
OpenSearch API is no longer available. | ||
|
||
Verify in a browser if opensearch is detected by typing the url and then a space. The url bar should then give an indication that you're searching within the site. | ||
* Recommend migrating to [GeoNetwork OpenAPI](the-geonetwork-api) if html discoverability is of primary importance. | ||
|
||
![](img/opensearch-in-browser.png){width="300px"} | ||
This provides a self-describing service, and automation tools for developer access in different programming languages. | ||
However the result is specific to the GeoNetwork application, and not an industry standard for interoperability. | ||
|
||
## INSPIRE ATOM | ||
* Recommend migration to [OpenGIS Web Catalogue Serivce (CSW)](csw.md) if standards compliance is of primary importance. | ||
|
||
The INSPIRE technical guideline for download services facilitates an option to set up a download service based on OpenSearch and Atom. A separate OpenSearch endpoint is created for every Atom-based download service. | ||
|
||
!!! note | ||
|
||
Only records based on the ISO19139 standard can be used with Atom. ISO19115-3 records are not. | ||
|
||
|
||
A remote ATOM feed can be registered in a metadata record (see [Linking data using ATOM feeds](../user-guide/associating-resources/linking-online-resources.md#linking-data-using-atom-feed)), but the catalog can also create ATOM feeds from records describing datasets and services. | ||
|
||
For a service metadata record, the corresponding ATOM feed is accessed at: `http://localhost:8080/geonetwork/srv/atom/describe/service?uuid=8b719ebd-646e-4963-b9e0-16b3c2a6d94e`. If the service is attached to one or more datasets (see [Linking a dataset with a service](../user-guide/associating-resources/linking-dataset-or-service.md)), then the feed will also expose each dataset as an `entry` in the feed. Check that the service type is set to `download` (if not, the dataset feed will return an exception). | ||
|
||
The dataset feed is accessible at: `http://localhost:8080/geonetwork/srv/atom/describe/dataset?spatial_dataset_identifier_code=b795de68-726c-4bdf-a62a-a42686aa5b6f`. Links will be created for each online resource flagged with a `function` set to `download`. | ||
|
||
Examples: | ||
|
||
- <https://catalog.inspire.geoportail.lu/geonetwork> | ||
!!! note OGC API - Records | ||
|
||
The OGC API - Records stadard is not yet ready, but is expected to provide the best of both worlds: html discoverability, and standards compliance. | ||
|
||
Interested parties are encouraged to contribute towards this roadmap activity. |
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,100 @@ | ||
# Q Search {#q-search} | ||
|
||
!!! warning | ||
|
||
Unavailable since version 4.0.0. | ||
|
||
There is no known sponsor or interested party for implementing Q-Search | ||
Interested parties may contact the project team for guidance and to express their intent. | ||
|
||
The Q Search endpoint allows you to query the catalog programmatically. It is available in the local catalog at `http://localhost:8080/geonetwork/srv/eng/q` (otherwise substitute your catalog URL). | ||
|
||
## Upgrading from GeoNetwork 3.0 Guidance | ||
|
||
The Q Search endpoint is replaced by the Elasticsearch ``/srv/api/search/records/_search`` endpoint. | ||
|
||
## Query results parameters | ||
|
||
The following parameters can be appended to your request to format the results: | ||
|
||
- `_content_type=json`: returns results in json format. If this parameter is not provided, then the results are returned in xml format. | ||
- `sortBy`: sorts the results by different criteria (example: `sortBy=relevance`): | ||
- `relevance` (default sorting method if not provided) | ||
- `title` (metadata title) | ||
- `changeDate` (metadata datestamp) | ||
- `rating` | ||
- `popularity` | ||
- `denominatorDesc` | ||
- `denominatorAsc` | ||
- `sortOrder=reverse`: Used to sort alphabetically. Note this will sort in **ASCENDING** order (eg A - Z) | ||
- `from`, `to`: Used to return a subset of the results, usually for pagination (example: `from=1&to=20`) | ||
- `fast`: Used to indicate the information to return. Possible values: | ||
- `index`: returns the metadata information from the Lucene index (a subset of the information). In most cases this is the best option as the retrieval of information from the Lucene index is very fast. | ||
|
||
The fields returned are configured in the `dumpFields` section in <https://github.com/geonetwork/core-geonetwork/blob/master/web/src/main/webapp/WEB-INF/config-lucene.xml#L107> | ||
|
||
- `false`: returns the raw (full) metadata. This is slower as it will retrieve every metadata attribute from the database. If this parameter is not provided, it returns a minimal set of information for each record: uuid, internal id, metadata schema, create/change dates | ||
- `buildSummary`: Returns a summary element with search facets that can be used to filter the metadata, typically used to provide quick filters (facets) on the search results page. Values: | ||
- `true` (default, if the parameter is not provided). | ||
- `false`: does not return the summary. | ||
- `summaryOnly`: Returns the summary (depending on the value of the parameter `buildSummary`) and results. Values: | ||
- `0` (default, if the parameter is not provided). | ||
- Any other value returns the summary only. | ||
- `resultType`: type of summary to return. Summaries are configured in the `summaryTypes` section in <https://github.com/geonetwork/core-geonetwork/blob/master/web/src/main/webapp/WEB-INF/config-summary.xml#L132-L249> | ||
- `hits` (default value if not provided), returns the fields configured in the `hits` section in <https://github.com/geonetwork/core-geonetwork/blob/master/web/src/main/webapp/WEB-INF/config-summary.xml#L185> | ||
- `details` (recommended value to send), returns the fields configured in the `details` section in <https://github.com/geonetwork/core-geonetwork/blob/master/web/src/main/webapp/WEB-INF/config-summary.xml#L133> | ||
- `extraDumpFields`: a comma-separated list of additional fields that you wish to return alongside the fields returned according to the resultType you have chosen. The wildcard character `*` can be used to match multiple fields. For example `extraDumpFields=mycustomfield*` would match mycustomfield1 and mycustomfield2. | ||
- Other values in the summaries section are allowed | ||
|
||
## Query filter parameters | ||
|
||
You can search on any field(s) indexed in Lucene. For a complete reference see <https://github.com/geonetwork/core-geonetwork/blob/master/schemas/iso19139/src/main/plugin/iso19139/index-fields/default.xsl> | ||
|
||
Note you can query the Lucene index graphically,using a Java-based graphical tool such as [Luke](https://github.com/DmitryKey/luke). Version [4.10.4](https://github.com/DmitryKey/luke/releases/tag/luke-4.10.4.1/) is required to work with the version of Lucene bundled with GeoNetwork. Download the jar file where you can access the GeoNetwork index files, then execute with: | ||
|
||
`java -jar luke-with-deps.jar` | ||
|
||
Then follow the instructions in the tool. | ||
|
||
Most relevant fields: | ||
|
||
- `any`: A special Lucene field that indexes all the text content in the metadata. Example: <http://localhost:8080/geonetwork/srv/eng/q?any=water&from=1&to=20&resultType=details&fast=index&_content_type=json> | ||
|
||
There are some additional query fields, that use the content from the Lucene field `any`. | ||
|
||
- `or`: extract the tokens of the query parameter to return the results that contain at least 1 of the tokens | ||
- `without`: extract the tokens of the query parameter to return the results that don't contain any of the tokens. | ||
- `phrase`: return the results that contain the exact text as provided in the search query parameter. | ||
- `title`: metadata title. | ||
- `abstract`: metadata abstract. | ||
- `topicCat`: metadata topic categories. | ||
- `keyword`: metadata keywords. | ||
- `type`: hierarchyLevel (dataset, service, etc.) | ||
|
||
If several tokens are included in the query, an AND query with all the tokens is executed. For example, `title=roads&topicCat=biota`. This query will return the results that contain roads in the title AND have the topic category biota. | ||
|
||
An OR query of several fields can be executed using the format: `field1_OR_field2_OR_... =value`. For example, `title_OR_abstract=roads` returns the metadata that contain roads in the title OR the abstract. | ||
|
||
Additionally an OR query of several values for a single field can be executed, if the Lucene configuration for that field allows it, with the following format: `field=value1 or value2 or ...` For example `topicCat=biota or farming`, returns the metadata where the topic category is either biota OR farming. If the query was executed as `topicCat=biota&topicCat=farming` then only the metadata with BOTH topic categories would be returned. | ||
|
||
## Date Searches | ||
|
||
There are a number of ways that you can search by date. Date searches should be of the form YYYY-MM-DD | ||
|
||
- dateFrom/dateTo: uses the changeDate parameter in the index. | ||
- creationDateFrom/To: uses the creation date. | ||
- revisionDateFrom/To: uses the revision date. | ||
|
||
## Query examples | ||
|
||
Query with any field for metadata containing the string 'infrastructure', returning json, using the fast index to return results, and returning the fields configured in `config-summary.xml`: | ||
|
||
<http://localhost:8080/geonetwork/srv/eng/q?any=infrastructure&_content_type=json&fast=index&from=1&resultType=details&sortBy=relevance&to=20> | ||
|
||
Query datasets with title containing the string 'infrastructure', returning json, using the fast index to return results, returning the fields configured in `config-summary.xml` and returning only the first 20 results (ordered by relevance): | ||
|
||
<http://localhost:8080/geonetwork/srv/eng/q?title=infrastructure&type=dataset&_content_type=json&fast=index&from=1&resultType=details&sortBy=relevance&to=20> | ||
|
||
Query datasets with a revision date in June 2019 using the fast index to return results, returning the fields configured in `config-summary.xml` and returning only the first 20 results (ordered by relevance): | ||
|
||
<http://localhost:8080/geonetwork/srv/eng/q?_content_type=json&revisionDateFrom=2019-06-01&revisionDateTo=2019-06-30&fast=index&from=1&resultType=details&sortBy=relevance&to=20> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.