timegroup
parameter aggregates records over a specified number of minutes. For example, setting timegroup=1
returns one position per minute.
GET https://api.myshiptracking.com/api/v2/vessel/track
Parameter | Required | Type | Default | Description |
---|---|---|---|---|
apikey (header) | yes | text |
Your API key. Pass it via the HTTP header
Authorization: Bearer YOUR_API_KEY or x-api-key .
|
|
timegroup | no | integer | 1 |
Time grouping in minutes for aggregating track positions. Allowed values: 1–60.
For example, if a vessel reports positions every second, setting timegroup=1 will return one record per minute.
|
mmsi | yes (one required) | integer | 9-digit Maritime Mobile Service Identity. (Do not include if using imo.) | |
imo | integer | 7-digit International Maritime Organization number. (Do not include if using mmsi.) | ||
fromdate | yes (if not using days ) |
ISO 8601 datetime |
Start date/time in ISO 8601 UTC format (e.g. 2025-04-03T12:12:00Z ).
|
|
todate | yes (if not using days ) |
ISO 8601 datetime |
End date/time in ISO 8601 UTC format (e.g. 2025-04-03T13:10:00Z ).
|
|
days | yes (if not using fromdate and todate ) |
integer |
Number of days to look back. Provide either fromdate and todate or days , but not both.
|
Field | Type | Description |
---|---|---|
lat | real | Latitude in decimal degrees. (Trial users may receive a masked value.) |
lng | real | Longitude in decimal degrees. (Trial users may receive a masked value.) |
course | real | Vessel course in degrees. |
speed | real | Speed in knots. |
time | datetime | Timestamp (UTC) when the position was recorded. |
All API responses follow a standardized envelope format for consistency and ease of integration.
On success (HTTP status code 200
), the envelope includes:
status
: "success"duration
: Time taken to process the request (in seconds).timestamp
: Server timestamp when the response was generated (ISO 8601 format).data
: The requested resource data. For XML responses, the data is formatted according to the requested XML structure.On error, the envelope includes:
status
: "error"duration
: Time taken to process the request.timestamp
: Server timestamp when the error was generated.code
: Specific error code used for troubleshooting.message
: Detailed error message.The response format (JSON or XML) is determined by the Accept
header.
Note: When credits are charged for a request, the response includes a custom HTTP header
X-Credit-Charged
indicating the number of credits deducted.
<?xml version="1.0"?>
<RESPONSE status="success" duration="0.009773170" timestamp="2025-04-03T13:28:50.430Z">
<POSITIONS>
<POS lat="37.938033" lng="23.621187" course="74" speed="10.5" time="2025-04-03T13:06:28Z"/>
<POS lat="37.8726" lng="23.645068" course="335.3" speed="22.3" time="2025-04-03T12:53:20Z"/>
<POS lat="37.740217" lng="23.722643" course="332.2" speed="22.1" time="2025-04-03T12:29:44Z"/>
<!-- Additional track positions... -->
</POSITIONS>
</RESPONSE>
{
"status": "success",
"duration": "0.008774525",
"timestamp": "2025-04-03T13:30:22.785Z",
"data": [
{
"lat": 37.938033,
"lng": 23.621187,
"course": 74,
"speed": 10.5,
"time": "2025-04-03T13:06:28Z"
},
{
"lat": 37.8726,
"lng": 23.645068,
"course": 335.3,
"speed": 22.3,
"time": "2025-04-03T12:53:20Z"
},
{
"lat": 37.740217,
"lng": 23.722643,
"course": 332.2,
"speed": 22.1,
"time": "2025-04-03T12:29:44Z"
}
]
}
{
"status": "error",
"duration": "0.001234567",
"timestamp": "2025-04-03T13:30:00.000Z",
"code": "MST_ERR_VALIDATOR",
"message": "fromdate and todate must be provided together."
}
The following error responses can be returned. Each error follows the standardized response envelope.
Error Code | HTTP Status | Description |
---|---|---|
MST_ERR_VALIDATOR | 400 | Parameter validation failed (e.g. incorrect format or missing required time range parameters). |
ERR_INVALID_IDENTIFIER | 400 | Either both or neither of MMSI and IMO were provided; exactly one identifier is required. |
ERR_INVALID_DATE | 400 | Invalid date format for fromdate or todate. |
ERR_DATE_RANGE | 400 | The range between fromdate and todate must be 90 days max and up to 2 years back |
ERR_NO_KEY | 401 | No API key was provided in the request headers. |
ERR_INVALID_KEY | 401 | The provided API key is invalid or unrecognized. |
ERR_NOACCESS | 403 | The API key does not have permission to access this endpoint. |
ERR_NO_CREDITS | 402 | Insufficient credit balance for the requested operation. |
ERR_VESSEL_NOT_FOUND | 404 | No vessel was found matching the provided identifier. |
ERR_RATE_LIMIT | 429 | The request rate limit has been exceeded. |
ERR_INTERNAL | 500 | An internal server error occurred. |
<?php
$apiKey = "YOUR_API_KEY";
$mmsi = "239923000"; // Or use IMO by setting $imo instead
$fromdate = "2025-04-03T12:12:00Z";
$todate = "2025-04-03T13:10:00Z";
$url = "https://api.myshiptracking.com/api/v2/vessel/track?mmsi={$mmsi}&fromdate={$fromdate}&todate={$todate}";
// Optional: Append &timegroup=30 for grouping, or use &days=NUMBER_OF_DAYS
$headers = [
"Authorization: Bearer $apiKey"
// Alternatively: "x-api-key: $apiKey"
];
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);
$response = curl_exec($ch);
if(curl_errno($ch)) {
echo 'Request Error: ' . curl_error($ch);
} else {
echo $response;
}
curl_close($ch);
?>
curl --location 'https://api.myshiptracking.com/api/v2/vessel/track?mmsi=239923000&fromdate=2025-04-03T12%3A12%3A00Z&todate=2025-04-03T13%3A10%3A00Z' \
--header 'authorization: Bearer YOUR_API_KEY'
# Optional: Append &timegroup=30 or &days=NUMBER_OF_DAYS
import requests
api_key = "YOUR_API_KEY"
mmsi = "239923000" # Or use IMO by modifying the URL
fromdate = "2025-04-03T12:12:00Z"
todate = "2025-04-03T13:10:00Z"
url = f"https://api.myshiptracking.com/api/v2/vessel/track?mmsi={mmsi}&fromdate={fromdate}&todate={todate}"
# Optional: Append &timegroup=30 or &days=NUMBER_OF_DAYS
headers = {
"Authorization": f"Bearer {api_key}"
# Alternatively: "x-api-key": api_key
}
response = requests.get(url, headers=headers)
if response.ok:
print(response.json())
else:
print("Error:", response.status_code, response.text)
const apiKey = "YOUR_API_KEY";
const mmsi = "239923000"; // Or use IMO by adjusting the URL
const fromdate = "2025-04-03T12:12:00Z";
const todate = "2025-04-03T13:10:00Z";
let url = `https://api.myshiptracking.com/api/v2/vessel/track?mmsi=${mmsi}&fromdate=${fromdate}&todate=${todate}`;
// Optional: Append &timegroup=30 or &days=NUMBER_OF_DAYS
fetch(url, {
method: "GET",
headers: {
"Authorization": `Bearer ${apiKey}`
// Alternatively: "x-api-key": apiKey
}
})
.then(response => response.headers.get("Content-Type").includes("application/xml") ? response.text() : response.json())
.then(data => console.log(data))
.catch(error => console.error("Error:", error));
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.URL;
public class VesselTrackExample {
public static void main(String[] args) {
try {
String apiKey = "YOUR_API_KEY";
String mmsi = "239923000"; // Or set IMO here
String fromdate = "2025-04-03T12:12:00Z";
String todate = "2025-04-03T13:10:00Z";
String urlString = "https://api.myshiptracking.com/api/v2/vessel/track?mmsi=" + mmsi + "&fromdate=" + fromdate + "&todate=" + todate;
// Optional: Append &timegroup=30 or &days=NUMBER_OF_DAYS as needed
URL url = new URL(urlString);
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setRequestMethod("GET");
conn.setRequestProperty("Authorization", "Bearer " + apiKey);
int responseCode = conn.getResponseCode();
BufferedReader in = new BufferedReader(new InputStreamReader(
(responseCode == HttpURLConnection.HTTP_OK) ? conn.getInputStream() : conn.getErrorStream()));
String inputLine;
StringBuilder response = new StringBuilder();
while ((inputLine = in.readLine()) != null) {
response.append(inputLine);
}
in.close();
System.out.println(response.toString());
} catch (Exception e) {
e.printStackTrace();
}
}
}
using System;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Threading.Tasks;
class VesselTrackExample {
static async Task Main() {
string apiKey = "YOUR_API_KEY";
string mmsi = "239923000"; // Or use IMO instead
string fromdate = "2025-04-03T12:12:00Z";
string todate = "2025-04-03T13:10:00Z";
string url = $"https://api.myshiptracking.com/api/v2/vessel/track?mmsi={mmsi}&fromdate={fromdate}&todate={todate}";
// Optional: Append &timegroup=30 or &days=NUMBER_OF_DAYS if needed
using (HttpClient client = new HttpClient()) {
client.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Bearer", apiKey);
HttpResponseMessage response = await client.GetAsync(url);
if (response.IsSuccessStatusCode) {
string content = await response.Content.ReadAsStringAsync();
Console.WriteLine(content);
} else {
Console.WriteLine("Error: " + response.StatusCode);
}
}
}
}
require 'net/http'
require 'uri'
require 'json'
api_key = "YOUR_API_KEY"
mmsi = "239923000" # Or use IMO instead
fromdate = "2025-04-03T12:12:00Z"
todate = "2025-04-03T13:10:00Z"
uri = URI("https://api.myshiptracking.com/api/v2/vessel/track?mmsi=#{mmsi}&fromdate=#{fromdate}&todate=#{todate}")
# Optional: Append &timegroup=30 or &days=NUMBER_OF_DAYS
request = Net::HTTP::Get.new(uri)
request["Authorization"] = "Bearer #{api_key}"
response = Net::HTTP.start(uri.hostname, uri.port, use_ssl: true) do |http|
http.request(request)
end
if response.is_a?(Net::HTTPSuccess)
data = JSON.parse(response.body)
puts data
else
puts "Error: #{response.code} #{response.message}"
end
Your request preview will appear here...
Your response will appear here...