Skip to content

aodn/ogcapi-java

Repository files navigation

OGC API Java Implementation

This is a Java implementation of varies OGC api, you can find couples of APIs seperated into modules. Only the server module contains the real implementation, other modules are class generated from openapi files using swagger generator and do not expect any manual changes.

How code generated

WARNING: You may experience code generation problem when the code is running in Windows machine . Namely some enum will generated in two classes where one prefix with Api and the other emum contains empty skeleton.

All code generated using swagger generator with openapi file download online, these pages provide link to a website which store the openapi file.

The generator generates the interface and model only, the implementor need to implement those interface as needed.

Noted: There are typeMappings in api generator pom to force mapping to desire class instead of enum, this is because some of the definition in the openapi file is too restricted and not fit for purpose. The change will not break the api contract.

Another change will be on the file replacer, this is due to the following reasons:

  • javax package is removed in jdk17 and replaced by jakarta
  • unused extra import that cause compilation failure
  • return type ResponseEntity<String> is too restricted and need to be replaced by ResponseEntity<?>

Implementation

The server module contains the implementation of those interfaces, for details please read the README

Endpoints:

Description Endpoints Environment
Logfile /manage/logfile Edge
Beans info /manage/beans Edge
Env info /manage/env Edge
Info (Show version) /manage/info Edge
Health check /manage/health Edge

CQL

Field Desciption
score The min score value of the return record, the higher the value, the more relevance it will be. By default the score isn't set, it is Elastic Search field not STAC field

Sort

By default the sort is sortby=-score that is desc order of _score of elastic search. You can change it to sortby=-score,+title or parameter as long as that field support each, ref to CQLCollectionsField.class and check whether the sortField is null or not. The sort function require change in elastic schema so we do not support all of the fields. In fact some fields sort do not make sense.

Commit

We are using gitmoji(OPTIONAL) for consistent commit messages. Here are examples of the most used ones:

  • 🎨 - Improving structure/format of the code.
  • ⚡ - Improving performance.
  • 🔥 - Removing code or files.
  • 🐛 - Fixing a bug.
  • 🚑 - Critical hotfix.
  • ✨ - Introducing new features.
  • 📝 - Adding or updating documentation.
  • 🚀 - Deploying stuff.
  • 💄 - Updating the UI and style files.
  • 🎉 - Beginning a project.

Example of use: :sparkles: implement new OGC Features API endpoint

Branching name

  • hotfix/: for quickly fixing critical issues,
  • usually/: with a temporary solution
  • bugfix/: for fixing a bug
  • feature/: for adding, removing or modifying a feature
  • test/: for experimenting something which is not an issue
  • wip/: for a work in progress

And add the issue id after an / followed with an explanation of the task.

Example of use: feature/123-implement-ogc-processes-api

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 11

Languages