Time API
What is the Time API?
The Time API takes a given set of coordinates (latitude and longitude) and return the relevation timezone and current time information. With the GeoCat Time API, you can provide coordinates and get full timezone and current time details in return.
1) Accessing the API
For individual requests, we have a REST API endpoint. For bulk requests, you can upload a file in your Client Area account. This documentation is in reference to the HTTP REST API Endpoint. Please note: This API endpoint REQUIRES an API Key. You can find your API Key in the Client Area.
The API is available at the following endpoint: https://api.geocat.com/v3/time/
2) Request Parameters
The API only accepts 3 parameters in GET format:
- lat = the latitude of the requested location
- lon = the longitude of the requested location
- key = your API Keys from the Client Area
3) Return Format
The API returns data in a clean, "pretty print", jSON format. This format is both Human and Computer readable. You can for example test the API in a web browser and will be able to read the output without special software. You could also incorporate it into software using "jSON decoding" or equivalent in your programming language. We actually recommend testing your query in your browser first to ensure that you get the expected results before incorporating the results into your software or program to ensure you have the proper format and to see the expected output.
4) Example Return Data
An Example of the jSON return is as follows:
{
"copyright": {
"notice": "All data provided is property of GeoCat.com. Usage is subject to the Terms of Service and Privacy Policy.",
"terms_of_service": "https:\/\/www.geocat.com\/terms-of-service\/",
"privacy_policy": "https:\/\/www.geocat.com\/privacy-policy\/"
},
"status": {
"request": {
"key": "VALID",
"latitude": "VALID",
"longitude": "VALID"
},
"account": {
"userid": "248354",
"key": "0a1e1dd1-a920-11ef-9431-00163e25de56",
"status": "ACTIVE",
"plan": "UNLIMITED",
"free_used": 2500,
"free_left": 0,
"paid_used": 449,
"paid_left": 0,
"expires": "2025-12-22 22:20:54"
},
"query": {
"type": "PAID",
"allow": true,
"allow_reason": "UNLIMITED_ACCOUNT",
"method": "TIME",
"requested": "36.158158,-115.192865",
"found": true,
"time_taken": "50ms"
}
},
"result": {
"tzid": "America\/Los_Angeles",
"timestamp": {
"unix": "1736800133",
"datetime": "2025-01-13 12:28:53",
"iso8601": "2025-01-13T12:28:53-08:00",
"rfc5322": "Mon, 13 Jan 2025 12:28:53 -0800"
},
"time": {
"full": "12:28:53",
"hour_24": "12",
"hour_12": "12",
"minute": "28",
"second": "53",
"am_pm": "PM",
"swatch": "895"
},
"date": {
"full": "Monday, January 13th, 2025",
"weekday": "Monday",
"month": "January",
"day": "13",
"suffix": "th",
"year": "2025"
},
"details": {
"leap_year": "0",
"DST": "0",
"tz_short": "PST",
"tz_offset": "-28800"
}
}
}
5) The "status" section
Here is an example of the status section:
"status": {
"request": {
"key": "VALID",
"latitude": "VALID",
"longitude": "VALID"
},
"account": {
"userid": "248354",
"key": "0a1e1dd1-a920-11ef-9431-00163e25de56",
"status": "ACTIVE",
"plan": "UNLIMITED",
"free_used": 2500,
"free_left": 0,
"paid_used": 449,
"paid_left": 0,
"expires": "2025-12-22 22:20:54"
},
"query": {
"type": "PAID",
"allow": true,
"allow_reason": "UNLIMITED_ACCOUNT",
"method": "TIME",
"requested": "36.158158,-115.192865",
"found": true,
"time_taken": "50ms"
}
},
-
request = Contains info on the request validation This sub-section will ALWAYS be returned, regardless of given parameters. Contains the following fields:
key = Contains the validation status of the provided API key. May contains the following values:
- VALID = The API key was provided, it was validated, and exists in the system.
- INVALID = The API key was provided, but is not in a valid format or was not found in the system.
- MISSING = The API key was not provided. Check that the "key" parameter is provided to the API.
- VALID = The latitude was provided, it was validated, and is correct format.
- INVALID = The latitude was provided, but is not in a valid format.
- MISSING = The latitude was not provided. Check that the "lat" parameter is provided to the API.
- VALID = The longitude was provided, it was validated, and is correct format.
- INVALID = The longitude was provided, but is not in a valid format.
- MISSING = The longitude was not provided. Check that the "lon" parameter is provided to the API.
-
account = This sub-section is only returned if the request->key field is "VALID". Contains the following fields:
userid = Your user ID number in the system. Not really useful for users, but may be requested by support for troubleshooting.
key = Your API key. Should match the key provided in your request.
status = The status of your account at GeoCat. May contains the following values:- ACTIVE = Your account is fully activated and can be used to access the API.
- INACTIVE = Your account has not been activate. You need to verify your email address to activate your account.
- TERMINATED = Your account was closed or terminated. If you wish to reactivate your account, you'll need to contact support.
- FREE_TIER = You do not have an active paid plan. You are limited to 2500 queries daily any anything over this will use from your credit balance, should you have one.
- SMALL_TIER = You are on a SMALL plan. This plan includes 25,000 PAID queries daily above the 2500 free limit (27,500 queries total)
- MEDIUM_TIER = You are on a SMALL plan. This plan includes 50,000 PAID queries daily above the 2500 free limit (52,500 queries total)
- LARGE_TIER = You are on a SMALL plan. This plan includes 75,000 PAID queries daily above the 2500 free limit (77,500 queries total)
- UNLIMITED = You are on an Unlimited Plan. This plan is our largest tier possible and allows for limitless usage of the API while the package is active.
free_left = How much of your free limit is remaining for today. Max is 2500.
paid_used = How much of your paid credits have been used today over the 2500 free limit.
paid_left = How much of your paid credits is remaining: If on FREE_TIER, this will be the amount of paid credit you have left. If you are on a monthly plan, this will be the remaining limit for today. If you are on an UNLIMITED plan, this will show 0 but all queries will be allowed.
expires = The expiration date of your current plan. After this date, your account will be reverted to "FREE_TIER" unless you renew it. If on the FREE_TIER, this will return "NEVER", as Free Tier accounts do not have an expiration date. -
query = This sub-section is only returned if all fields in the request section are "VALID" and account status is "ACTIVE". Contains the following fields:
type = The query type. May contains the following values:
- FREE = Your account is below the free limit and this query is using from your free limit.
- PAID = You are over the free limit and this query is using credit or your plan.
- true = This query was allowed to proceed. Check "found" field to check if results were found.
- false = This query was not allowed to proceed. Please check "allow_reason" field.
- UNDER_FREE_LIMIT = Allowed because you are below the daily free limit.
- UNDER_PAID_LIMIT = Allowed because you had credit or an active paid plan.
- UNLIMITED_ACCOUNT = Allowed because you are on an Unlimited Plan.
- OVER_LIMIT = Was NOT allowed because you are over free limit, do not have an active plan, and have no credits.
requested = Validated requested lat+lon in format "lat,lon". May not match exactly your input if it required correction to be processed. For example, if you provided more than 6 digits after the decimal place, they will have been trunicated here. If you provided less than 6 digits after the decimal point, it will have been padded with trailing zeros here.
found = Whether or not a result was found for the given query. May contains the following values:- true = A result was found. There will be a result section returned.
- false = A result was not found. There will NOT be a result section returned.
6) The "result" section
Here is an example of the result section:
"result": {
"tzid": "America\/Los_Angeles",
"timestamp": {
"unix": "1736800133",
"datetime": "2025-01-13 12:28:53",
"iso8601": "2025-01-13T12:28:53-08:00",
"rfc5322": "Mon, 13 Jan 2025 12:28:53 -0800"
},
"time": {
"full": "12:28:53",
"hour_24": "12",
"hour_12": "12",
"minute": "28",
"second": "53",
"am_pm": "PM",
"swatch": "895"
},
"date": {
"full": "Monday, January 13th, 2025",
"weekday": "Monday",
"month": "January",
"day": "13",
"suffix": "th",
"year": "2025"
},
"details": {
"leap_year": "0",
"DST": "0",
"tz_short": "PST",
"tz_offset": "-28800"
}
}
- tzid = The IANA standard timezone identifier.
- timestamp = Current Timestamp. Will contain any of the following:
- unix = 64-bit UNIX Epoch Timestamp for current time and date.
- datetime = MySQL DATETIME formatted current time and date.
- iso8601 = Current date and time in ISO-8601 certified format.
- rfc5322 = Current date and time in RFC-5322 certified format.
- time = Current Time. Will contain the following:
- full = Full Current Clock - In 24 Hour Format. (hour:minutes:seconds)
- hour_24 = Current Hour in 24-hour format.
- hour_12 = Current Hour in 12-hour format. (am/pm)
- minute = Current Minute in 2-digit format.
- second = Current Seconds Past the Minute in 2-digit format.
- am_pm = If it's currently AM (morning) or PM (evening)
- swatch = Current Time In Swatch Format
- date = Current Date. Will contain the following:
- full = Full, Formatted Current Date
- weekday = Current Day of the Week
- month = Full Month Name
- day = Current Numeric Day of the Month in 2 digits
- suffix = Suffix for the Day of the Month.
- year = 4-digit Current Year.
- details = Additional Timezone Details. Will contain the following:
- leap_year = 0 if currently a leap-year, 1 if not a leap year
- DST = 1 if currently in Daylight Savings Time, 0 if not
- tz_short = Short Abbreviation of Timezone
- tz_offset = Offset in seconds from GMT / UTC.