Vessel History Track

Vessel History Track Endpoint

Description

Retrieve historical track positions for a specific vessel. This endpoint returns an array of position records based on a specified time range.

The endpoint returns up to 3000 records and data is available for up to a maximum of 2 years back.

Note: Only terrestrial AIS data is supported. Coverage depends on our network—check MyShipTracking.com for live coverage.

Additional Note: Some vessels record positions every few seconds. To avoid returning an overwhelming amount of data, the timegroup parameter aggregates records over a specified number of minutes. For example, setting timegroup=1 returns one position per minute.

HTTP Request

GET https://api.myshiptracking.com/api/v2/vessel/track

Parameters

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.

Trial Users Limitations

Trial API keys are limited to a maximum of 100 records per request and data from the last 20 days.

Billing & Credits Details

Credit Charge Details

Each request is charged 5 credits per distinct date found in the returned records.
For example:
  • If your request returns records from only one date, you'll be charged 5 credits.
  • If your request returns records from two different dates (e.g., 1500 records from 2025-04-02 and 240 records from 2025-04-03), you'll be charged 10 credits.
  • If your request returns records from three distinct dates, you'll be charged 15 credits, and so on.
If the request returns no results, no credits are deducted.

Response Fields

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.

Response Structure

All API responses follow a standardized envelope format for consistency and ease of integration.

Success Response

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.

Error Response

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.

Sample Success Response (XML)

<?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>

Sample Success Response (JSON)

{
    "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"
        }
    ]
}

Sample Error Response (JSON)

{
    "status": "error",
    "duration": "0.001234567",
    "timestamp": "2025-04-03T13:30:00.000Z",
    "code": "MST_ERR_VALIDATOR",
    "message": "fromdate and todate must be provided together."
}

Possible Error Responses

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.

Usage Examples

<?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

Try It Out

Request Preview

Your request preview will appear here...
                

Response

Your response will appear here...