Class GBIFTaxonomyReader
java.lang.Object
org.episteme.core.io.AbstractResourceReader<String>
org.episteme.natural.biology.loaders.GBIFTaxonomyReader
- All Implemented Interfaces:
ResourceIO<String>, ResourceReader<String>
Connector to the Global Biodiversity Information Facility (GBIF) API.
What it does: Provides access to the GBIF taxonomy backbone, allowing search and retrieval of biological species data without storing the massive dataset locally.
Data Source: GBIF (https://www.gbif.org/developer/species)
License: Data is free (CC0 or CC-BY), API is open.
- Since:
- 1.0
- Author:
- Silvere Martin-Michiellot, Gemini AI (Google DeepMind)
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionReturns the category for grouping.Returns a short description of this resource handler.Returns a long description of this resource handler.getName()Returns the display name of this resource handler.Returns the base path where this resource is located.Returns the type of resource.static StringgetSpeciesJSON(int usageKey) Fetches species details by GBIF usage key.String[]Returns the supported versions of the format this reader/writer handles.protected StringloadFromSource(String resourceId) static <T> TPlaceholder for future mapping to Biology domain objects.static StringSearches for species matching the query.Methods inherited from class AbstractResourceReader
clearCache, getMiniCatalog, getSampleDataPath, isUsingFallback, load, loadAll, loadAllFromSource, loadFromFallback, loadFromInputStream, setCacheEnabledMethods inherited from class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface ResourceIO
getExpectedResourceFiles, getSupportedExtensions, isFileBased, isOutputMethods inherited from interface ResourceReader
isInput
-
Constructor Details
-
GBIFTaxonomyReader
public GBIFTaxonomyReader()
-
-
Method Details
-
loadFromSource
- Specified by:
loadFromSourcein classAbstractResourceReader<String>- Throws:
Exception
-
getResourcePath
Description copied from interface:ResourceIOReturns the base path where this resource is located. -
getResourceType
Description copied from interface:ResourceIOReturns the type of resource. -
getSupportedVersions
Description copied from interface:ResourceIOReturns the supported versions of the format this reader/writer handles.Each implementation MUST override this method to declare which versions of the underlying format are supported. The returned array should contain version strings in the format's standard notation (e.g., "3.0", "2.1", "Level 3 Version 2").
Examples:
- MathML: {"3.0", "2.0"}
- SBML: {"Level 3 Version 2", "Level 3 Version 1", "Level 2 Version 5"}
- PhyloXML: {"1.10", "1.00"}
- Returns:
- array of supported version strings, never null (empty array if version-agnostic)
-
search
Searches for species matching the query.- Parameters:
query- scientific or common name- Returns:
- raw JSON response string
- Throws:
RuntimeException- if connection fails
-
map
-
getSpeciesJSON
Fetches species details by GBIF usage key.- Parameters:
usageKey- the unique GBIF identifier- Returns:
- raw JSON response string
-
getCategory
Description copied from interface:ResourceIOReturns the category for grouping. MUST be implemented with I18N support.- Returns:
- the category name
-
getName
Description copied from interface:ResourceIOReturns the display name of this resource handler. MUST be implemented with I18N support.- Returns:
- the display name
-
getDescription
Description copied from interface:ResourceIOReturns a short description of this resource handler. MUST be implemented with I18N support.- Returns:
- the description
-
getLongDescription
Description copied from interface:ResourceIOReturns a long description of this resource handler. MUST be implemented with I18N support.- Returns:
- the long description
-