ver. 1958 (4e4db56)
services/apiref
services/apisrv
services/attrs
services/caches
services/caches/formatters
services/caches/map
services/caches/search
services/caches/shortcuts
services/logs
services/logs/images
services/oauth
services/replicate
services/users

Retrieve information on a single geocache
:: services/caches/geocache method

Minimum Authentication: Level 1 (see Authentication Levels)
https://opencache.uk/okapi/services/caches/geocache

Retrieve information on a single geocache.

cache_code required Unique code of the geocache
langpref optional

Default value: en

Pipe-separated list of ISO 639-1 language codes. This indicates the order of preference in which language will be chosen for fields like name and description.

Please note, that you may also access caches' descriptions in all available languages. If you want to do this, you should use fields names, descriptions (etc.) instead of name and description (etc.).

fields optional

Default value: code|name|location|type|status

Pipe-separated list of field names which you are interested with. Selected fields will be included in the response. See below for the list of available fields.

attribution_append optional

Default value: full

By default, OKAPI appends the value of attribution_note field to all the cache descriptions. If you would like to display the attribution note separately, you may use this parameter. Use one of the following values:

  • full - OKAPI will append the attribution note to the descriptions of the geocache. The language of the note will match the language of the description (i.e. each value in descriptions may contain attribution notes in a different language).

  • none - OKAPI will not append the attribution note to geocache descriptions. You will need to use the attribution_note instead (which also depends on the langpref parameter).

    Important note: You are still required to display the attribution_note field in some other way.

  • static - OKAPI will append a "static" attribution note to the descriptions of the geocache. This might equal the "full" attribution note, but not necessarilly, since the "full" note may contain a current date (why?), and the "static" note will not. This is implemented primarily for internal use (i.e. the replicate module). Usually you should not use it, because on some installations the static note will not be sufficient to meet the data license requirements.

oc_team_annotation optional

Default value: description

Opencaching team members may directly annotate geocache listings. This parameter controls how to retrieve those annotations:

  • description - inserts the OC team annotations into the description texts,
  • separate (recommended) - includes the oc_team_annotation field instead. You are REQUIRED to display its contents alongside with the owner's cache listing.

OC team annotations are not to be confused with "OC Team comment" log entries, which have a similar purpose, but need not to be visible with the cache description. OC team annotations will be deleted when obsolete, while the log entries usually will stay.

Note that some OC installations do not implement team annotations. They will ignore this parameter.

owner_fields optional

Default value: uuid|username|profile_url

Pipe-separated list of user fields to include in the owner field. For valid field names, see services/users/user method.
lpc optional

Default value: 10

Log-entries per cache - the number of logs returned in the latest_logs field. This should be an integer or a special "all" value. Please note, that you must include the latest_logs field in fields in order to see the log entries.
log_fields optional

Default value: uuid|date|user|type|comment

Pipe-separated list of log fields to include in the latest_logs field. For valid field names, see the logs/entry method.
log_user_fields optional

Default value: uuid|username|profile_url

Pipe-separated list of user fields to include in the user subfield of the latest_logs field. For valid field names, see the services/users/user method.
user_logs_only optional

Default value: false

Boolean. If true with Level 3 Authentication, only logs of your user will be included in the latest_logs field. If true with Level 1 or 2 Authentication, then the parameter user_uuid must be supplied, and only logs of that user will be included in the latest_logs field. You must include the latest_logs field in fields in order to see the log entries.

my_location optional

The reference point for cache distance and bearing calculation (typically - the user's location), in the "lat|lon" format. This parameter is required when accessing distance and/or bearing fields.

Use positive numbers for latitudes in the northern hemisphere and longitudes in the eastern hemisphere (and negative for southern and western hemispheres accordingly). These are full degrees with a dot as a decimal point (ex. "54.3|22.3").

user_uuid optional

User'd ID. Required to access fields like is_found using Level 1 Authentication.

Please note that if you want to access private fields (like my_notes), then this parameter won't help you. You have to use Level 3 Authentication instead.

If you use Level 3 Authentication, you shouldn't use this parameter. Or, to be exact:

  • user_uuid will be extracted from the Access Token you use. You don't have to provide it.
  • If you provide user_uuid, then it HAS TO match your Access Token. If it doesn't, OKAPI will respond with HTTP 400 error.
format optional Standard common formatting argument.
callback optional Standard common formatting argument.
Plus required consumer_key argument, assigned for your application.

Returned value:

A dictionary of fields you have selected. Currently available fields:

  • code - unique Opencaching code of the geocache,
  • name - name of the geocache,
  • names - a dictionary (language code => plain-text string) of names of the geocache (at this time, there will be only one language, but this may change in future),
  • location - location of the cache in the "lat|lon" format (lat and lon are in full degrees with a dot as a decimal point),
  • type - cache type, one of the type codes that are included in the types field of services/caches/capabilities. Currently there are eight types which are in use at all OKAPI installations:

    • Traditional,
    • Multi,
    • Quiz, also known as "Mystery",
    • Moving, a geocache with changing coordinates,
    • Virtual,
    • Webcam,
    • Other, also dubbed "unknown type"; allows OC users to create special caches which don't fit into the scheme of well-known types,
    • Event, a peculiar type of geocache which is NOT a geocache at all, but it is stored as a geocache in OC database. Just keep in mind, that in case of Event Caches, some fields may have a little different meaning than you would tell by their name.
    • (Types may be added or removed. Your application MUST be prepared for any new types and may handle them as "Other".)

    More types are in use at some installations:

    • Own, a moving geocache which is carried by the owner,
    • Podcast, a geocache with attached MP3 file(s). The MP3 data is not accessible via OKAPI. This type is only in use at Opencaching.US.
    • (Types may be added or removed. Your application MUST be prepared for any new types and may handle them as "Other".)

    There are even more types, but OKAPI maps them to common types (and eventually some attributes), so you won't see them in OKAPI data.

  • status - cache status. Valid cache status codes currently include:

    • Available - Cache is available and ready for search,
    • Temporarily unavailable - Cache is unavailable (probably cannot be found) but may be restored,
    • Archived - Cache is permanently unavailable (moved to the archives).
  • OCDE needs_maintenance - boolean, true if the geocache is known to be in poor condition, e.g. damaged. Usually there will be further explanations in the log entries.

    Please note that some Opencaching installations don't provide this information; they will always return false.

  • url - URL of the cache's web page,
  • owner - dictionary of user fields that are selected by the owner_fields option.

  • gc_code - Geocaching.com code (GC code) of the geocache or null if the cache is not listed on GC or the GC code is unknown.

    Please note that this information is supplied by cache owners and it is often missing, obsolete or otherwise incorrect.

  • distance - float, the distance to a cache, in meters. This requires my_location parameter to be provided.

    Please note, that sometimes it is faster to compute this yourself, on client-side, instead of querying OKAPI.

  • bearing - float, the absolute bearing to the cache, measured in degrees from north, or null if it cannot be calculated (i.e. when you are exactly at the target's location). This requires my_location parameter to be provided.

    Please note, that sometimes it is faster to compute this yourself, on client-side, instead of querying OKAPI.

  • bearing2 - string, the absolute bearing to the cache, represented as a typical direction string of length of 1 or 2 characters (ex. "N", "NE", "E", "SE", etc.), or "n/a" if it cannot be calculated. This requires my_location parameter to be provided.

    Please note, that sometimes it is faster to compute this yourself, on client-side, instead of querying OKAPI.

  • bearing3 - string, the absolute bearing to the cache, represented as a typical direction string of length of 1 or 2 or 3 characters (ex. "N", "NNE", "NE", "ENE", etc.), or "n/a" if it cannot be calculated. This requires my_location parameter to be provided.

    Please note, that sometimes it is faster to compute this yourself, on client-side, instead of querying OKAPI.

  • is_found - boolean, true if the user already found this cache. See also found_status parameter of the services/caches/search/all method.

    This field requires you to use the user_uuid parameter (or Level 3 Authentication). Please note, that this will also return true for attended Event Caches.

  • is_not_found - boolean, true if the user has submitted "Didn't find it" log entry for this cache.

    This field requires you to use the user_uuid parameter (or Level 3 Authentication).

  • is_watched - boolean, true if the user is watching this cache. You may consider highlighting such geocaches in some fashion, as the users may use this functionality to temporarily mark geocaches of particular interest (i.e. geocaches they plan to find today).

    This is private data. You will need Level 3 Authentication to access this field.

  • is_ignored - boolean, true if the user is ignoring this cache. (See also exclude_ignored parameter of all search methods.)

    This is private data. You will need Level 3 Authentication to access this field.

  • founds - number of times the geocache was successfully found (or attended, in case of Event Caches),

  • notfounds - number of times the geocache was not found (in case of Event Caches this will always be zero),

  • willattends - in case of Event Caches, this is the number of "Will attend" log entries. In case of any other cache type, it will be zero (not null, for backward compatibility),

  • watchers - number of users who are watching this cache.

    Note that many watchers are inactive users, especially at the old sites Opencaching.DE and Opencaching.PL (founded 2005/2006). Some of them won't receive watch notifications at all because of obsolete email addresses. So the watchers' counts are somewhat overstated.

  • size - deprecated (why?), use size2 instead. Float (between 1 and 5), size rating of the container, or null if geocache does not have a container,
  • size2 - string indicating the size of the container, so called "size2 code". One of the following values: 'none', 'nano', 'micro', 'small', 'regular', 'large', 'xlarge', 'other'.

  • oxsize - float (between 1 and 5) or null, this is a size rating variant, compatible with the one used by (former) OpenCaching.com site (and many Garmin GPS devices).

    Note: The mapping is undocumented and may change without notice.

    Note: Some of OC's size values cannot be properly mapped to oxsize, i.e. the 'other' size.

  • difficulty - float (between 1 and 5), difficulty rating of the cache,
  • terrain - float (between 1 and 5), terrain rating of the cache,
  • trip_time - float, approximate total amount of time needed to find the cache, in hours; this will usually include the time to reach the cache location and go back (from/to a parking spot, etc.); null if unknown,

  • trip_distance - float, approximate total distance needed to find the cache, in kilometers; this will usually include the time to reach the cache location and go back (from/to a parking spot, etc.); null if unknown,

  • OCPL rating - float (between 1 and 5), an overall rating of the cache, or null when the geocache does not have a sufficient amount of votes to have a rating.

    Note: Some installations don't provide ratings for their geocaches; they will always return null for this field. The has_ratings field of services/caches/capabilities tells if ratings are available.

    Note: Currently OC sites expose cache ratings as integers only. OKAPI used floats here for forward-compatibility only. In other words, currently you can get 4.0 or 5.0 here, but not 4.5. This may change in the future though, without notice.

  • OCPL rating_votes - number of votes submitted for the rating of this cache.

    Note: Some installations don't provide ratings for their geocaches; they will always return 0 for this field. The has_ratings field of services/caches/capabilities tells if ratings are available.

  • OCPL my_rating - float (between 1 and 5), the rating the user gave for this cache; null if the user did not rate.

    This is private data. You will need Level 3 Authentication to access this field.

    See the notes on the rating field.

  • recommendations - number of recommendations for this cache,
  • is_recommended - boolean, true if the user recommended this cache.

    This field requires you to use the user_uuid parameter (or Level 3 Authentication).

  • req_passwd - boolean; states if this cache requires a password in order to submit a "Found it" log entry,
  • short_description - a plaintext string with a single line (very short) description of the cache (kind of a "tagline text"),
  • short_descriptions - a dictionary (language code => plaintext string) of short cache descriptions,
  • description - HTML string, description of the cache; may include additional notices that are prepended or appended to the text, some of them depending on the oc_team_annotation and attribution_append options,
  • descriptions - a dictionary (language code => HTML string) of cache descriptions,
  • hint - HTML-encoded string, cache hints/spoilers; deprecated (why?), use hint2 instead,
  • hints - a dictionary (language code => HTML-encoded string) of cache hints/spoilers; deprecated, use hints2 instead,
  • hint2 - plain-text string, cache hints/spoilers; in general, hints should not be displayed to the user unless user specifically asks for them,
  • hints2 - a dictionary (language code => plain-text string) of cache hints/spoilers,
  • images - list of dictionaries, each dictionary represents one image saved along the cache description; each dictionary has the following structure:

    • uuid - UUID of the image,
    • url - URL of the image,
    • thumb_url - URL of a small (thumb) version of the image,
    • caption - plain-text string, caption of the image,
    • unique_caption - plain-text string, to be used as a filename for Garmin's crappy images implementation (currently, they get image caption from the image's filename itself),
    • is_spoiler - boolean, if true then the image is a spoiler image and should not be displayed to the user unless the user explicitly asks for it,
  • OCDE preview_image - On some installations, owners may select one of the images (see above) as a preview image. You are encouraged to display it as a 'teaser' for this cache. On other installations this functionality is disabled and you will always get the null value here.

    The value of preview_image is either null or a dictionary describing an image. The structure of this dictionary is the same as of a single entry on the images list described above.

  • attr_acodes - unordered list of OKAPI geocache-attribute IDs (A-codes) with which the cache was tagged. Use the attrs module to retrieve information on these attributes.

  • attrnames - if you don't want to dig into attr_acodes just now, then you can use these as a simple alternative. attrnames is an unordered list of names of the attributes with which the cache was tagged; the language will be selected based on the langpref parameter.
  • OCPL oc_team_annotation - HTML text containing OC team annotations to the geocache listing. See the oc_team_annotation parameter for more information.

    Notices: The content of this field is not properly localized. It will only partially respond to the langpref parameter and may contain an arbitrary mixture of languages and differently localized data (why?). Some installations don't implement OC team annotations; they currently always return an empty string for this field.

  • attribution_note - the proper attribution note for the cache listing according to the local OC site's Data License. By default, this note is also appended to geocache descriptions (see the attribution_append parameter).

  • latest_logs - a couple of latest log entries in the cache. The format is the same as the one returned by the services/logs/logs method.

    Note: The number of logs returned can be set with the lpc option, and the fields to return can be selected by the log_fields option.

  • my_notes - user's notes on the cache, in plain-text, or null if user hadn't defined any notes.

    This field requires you to use the Level 3 Authentication.

  • trackables_count - a total number of trackables hidden within the cache.
  • trackables - list of dictionaries, each dictionary represents one trackable hidden within the cache container; each dictionary has the following structure:

    • code - code of the trackable,
    • name - plain text name of the trackable,
    • url - trackable's own webpage address or null, if OKAPI cannot automatically determine this address.
  • alt_wpts - list of alternate/additional waypoints associated with this geocache. Each item is a dictionary of the following structure:

    • name - plain-text, short, unique "codename" for the waypoint,
    • location - location of the waypoint in the "lat|lon" format (lat and lon are in full degrees with a dot as a decimal point).

      Note: For waypoints with nonpublic location, "0|0" is returned. It is recommended to hide those null coordinates or show a placeholder like "---". Public waypoints coordinates are never "0|0".

    • type - string, unique identifier for the type of waypoint; one of the following:

      • parking, trailhead, path, stage, physical-stage, virtual-stage, final, poi, other - used by OC itself, for detailed descriptions of these you'll have to refer to external Opencaching documenation,
      • user-coords - extra coordinates supplied by the user who had found the cache (NOT the owner of the cache), most probably pointing to the final location of the cache (e.g. a quiz cache); this type of waypoint is available only in some installations and only if you're using Level 3 Authentication,
      • more types may be added at any moment; unknown types should be treated as other.
    • type_name - string, the human-readable name of the waypoint type, e.g. "Parking area" or "Final location"; the language will be selected based on the langpref argument,
    • gc_type - string, identifier for the type of waypoint as used in Groundspeak applications. Different types may be mapped to the same gc_type, and mappings may change. Use type instead if you need a unique and forward compatible identifier.

    • sym - string, one of commonly recognized waypoint symbol names, originally introduced by Garmin in their devices and GPX files (e.g. "Flag, Green" or "Parking Area").

      These symbol codes are only suggestions. They are understood by Garmin-related software and devices. If you don't know how to display such symbols, you are welcome to use any symbol you'd like in your application.

    • description - plain-text longer description of the waypoint.
  • country - deprecated; same as country2, but on some installations the language of the returned country name is undefined (it will not respond to the langpref parameter). Also, null may be returned instead of an empty string if the country is unknown.

  • country2 - name of the country the cache is placed in; may be empty ("") if the country is unknown.

    Note: This data is user-supplied and is not validated in any way. Consider using external geocoding services instead.

  • state - deprecated; same as region, but null may be returned instead of an empty string if the region is unknown. For some caches, the returned region will not match the country where the cache is placed.

  • region - name of the major subnational entity the cache is placed in; may be empty ("") if the entity is unknown. This may be a (federal) state, a province, a region or whatever is the country's most relevant administrative entity below national level.

    Note: On some installations this data is user-supplied and is not validated in any way. Other installations calculate it from cache coordinates but may have problems in border regions. Different OC sites may return different regions for the same geocache. Consider using external geocoding services instead. Also, currently you have no way of knowing in which language it will appear in (but it *may* start to vary on the value of your langpref parameter in the future).

  • protection_areas - list of dictionaries, each representing a protection area in which the cache probably is located; each dictionary has the following structure:

    • type - the type of the protection area, e.g. "National Nature Reserve",
    • name - the name of the protection area, e.g. "East Dartmoor Woods and Heaths".

    The types and names currently are in a local language of the OC site but may be translated depending on the langpref parameter in the future.

    Note that this information is not authoritative. It may be outdated or incomplete, and it is completely missing on some OC installations.

  • last_found - date and time (ISO 8601) when the geocache was last found or null when it hasn't been yet found.

    Note, that some Opencaching servers don't store the exact times along with the log entries.

  • last_modified - date and time (ISO 8601) when the geocache was last modified (changed status, attributes, etc.),
  • date_created - date and time (ISO 8601) when the geocache was listed at the Opencaching site. For OCDE-based installations this is the date when it was published, while for OCPL installations it is the date when it was originally submitted. These dates differ if the geocache is prepared and then published later.
  • date_hidden - date and time (ISO 8601) when:

    • the geocache was first hidden (for physical caches), or
    • the geocache was first published (for virtual caches), or
    • the event takes place (for event caches),
  • internal_id - internal ID of the cache (do not use this, unless you know what you're doing; use the "code" as an identifier).

For example, for geocache?cache_code=OP3D96&fields=type query, the result might look something link this:

{"type": "Traditional"}

If given cache code does not exist, the method will respond with an HTTP 400 error.