Vessels In Port

Vessels In Port Endpoint

Description

Return a list of vessels that are either currently in the port or whose last known position was in the port

The default response format is JSON. To receive XML, set the Accept header to application/xml.

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

HTTP Request

GET https://api.myshiptracking.com/api/v2/port/inport

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
port_id yes (one required) integer Port identifier. Do not include if using unloco
unloco text Port UN/LOCODE. Do not include if using port_id

Billing & Credits Details

Credit Charge Details

This request returns a list of vessels in port and costs 10 credits per request.
If the request returns no results, no charge is made.

Response Fields

10 credits
Field Type Description
mmsi int Maritime Mobile Service Identity of the vessel.
imo int International Maritime Organization number (if available). If zero, returns an empty string.
name text Name of the vessel.
arrived datetime Arrival time at the current port (UTC).
vtype int Vessel type code.
vessel_type text Readable description of the vessel type.
flag text Country flag code of the vessel.
gt int Gross Tonnage of the vessel.
dwt int Deadweight (if available).
built int Year the vessel was built (if available).
length int Length of the vessel in meters.
width int Width of the vessel in meters.

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 (JSON)

{
    "status": "success",
    "duration": "0.006779555",
    "timestamp": "2025-04-03T18:04:50.149Z",
    "data": [
        {
            "mmsi": 239430000,
            "imo": 9121077,
            "name": "SUPERJET",
            "arrived": "2025-04-03T15:24:41Z",
            "vtype": 4,
            "vessel_type": "High speed craft",
            "flag": "GR",
            "gt": 493,
            "dwt": 50,
            "built": 1995,
            "length": 42,
            "width": 10
        }
    ]
}

Sample Error Response (JSON)

{
    "status": "error",
    "duration": "0.001600648",
    "timestamp": "2025-04-03T18:05:31.240Z",
    "code": "ERR_NOT_FOUND",
    "message": "No vessels found in port."
}

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 out-of-range values).
ERR_INVALID_IDENTIFIER 400 Both or neither of port_id and unloco were provided; exactly one identifier is required.
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_NOT_FOUND 404 Port not found or no vessels currently in port.
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";
$portId = 21; // Alternatively, use $unloco instead
$url    = "https://api.myshiptracking.com/api/v2/port/inport?port_id={$portId}";
// For using unloco, comment out the above line and use:
// $url = "https://api.myshiptracking.com/api/v2/port/inport?unloco=UNLOCO_CODE";

$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/port/inport?port_id=21" \
  -H "Authorization: Bearer YOUR_API_KEY"
# For using unloco, replace ?port_id=21 with ?unloco=UNLOCO_CODE
import requests

api_key = "YOUR_API_KEY"
port_id = 21  # Alternatively, set unloco instead
url     = f"https://api.myshiptracking.com/api/v2/port/inport?port_id={port_id}"
# For using unloco, append: ?unloco=UNLOCO_CODE

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 portId = 21; // Alternatively, use unloco instead
let url    = `https://api.myshiptracking.com/api/v2/port/inport?port_id=${portId}`;
// For using unloco, adjust the URL accordingly.

fetch(url, {
  method: "GET",
  headers: {
    "Authorization": `Bearer ${apiKey}`
    // Alternatively: "x-api-key": apiKey
  }
})
.then(response => {
  if (!response.ok) {
    throw new Error("Network response was not ok");
  }
  return 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 PortInportAPIExample {
    public static void main(String[] args) {
        try {
            String apiKey = "YOUR_API_KEY";
            int portId    = 21; // Alternatively, set unloco instead
            String urlString = "https://api.myshiptracking.com/api/v2/port/inport?port_id=" + portId;
            // For using unloco, adjust the URL accordingly
            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 PortInportAPIExample {
    static async Task Main() {
        string apiKey = "YOUR_API_KEY";
        int portId    = 21; // Alternatively, use unloco instead
        string url    = $"https://api.myshiptracking.com/api/v2/port/inport?port_id={portId}";
        // For using unloco, adjust the URL accordingly

        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"
port_id = 21  # Alternatively, set unloco instead
uri = URI("https://api.myshiptracking.com/api/v2/port/inport?port_id=#{port_id}")
# For using unloco, adjust the URL accordingly

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