InvAPI Control Panel API Documentation¶
This documentation describes the overall design and principles of the API, along with specific endpoints and usage examples.
Overview
The invapi.hostkey.com control panel is built on top of this API.
Making API Requests¶
All API requests must be made over HTTPS to ensure encryption of data in transit.
Use the POST method for all requests unless otherwise specified.
API Example Format¶
Examples in this documentation use curl, a command-line HTTP client. curl is pre-installed on most Linux and macOS systems and is available for download on all major platforms, including Windows.
Each example is split across multiple lines using the \ line continuation character, which is compatible with bash. A typical request looks like this:
Example POST Request:
The -X flag specifies the HTTP method. For consistency, the method is included in all examples, even when not explicitly required for GET requests.
Examples that require a JSON payload in the request body pass the data via the --data parameter.
All API responses are returned in JSON format and formatted in this documentation for readability.
Tip: Environment Variables
To avoid repeating your API token in every example, you can export it once as an environment variable in your terminal. On Linux or macOS:
The token will then be automatically substituted in your requests.
Disclaimer
All values shown in this documentation are for illustrative purposes only. Do not rely on operating system IDs, plan identifiers, or other example values. Always use your actual server, network, or domain identifiers when querying or creating resources. In some cases, only the account API key will work, not the specific server key (and vice versa), so if you encounter method authorization errors, try switching the API key type.
api_keys.php¶
API key management module: creation, editing, deletion, viewing history, and retrieving lists of keys for customers and servers.
| Method | Description |
|---|---|
add | Creates a new API key for a customer or a specific server. The customer must have active servers. |
delete | Deletes the specified API key from the system. |
edit | Modifies parameters of an existing API key (name, IP, status, expiration). |
history | Returns the history of actions performed on API keys (creation, modification, deletion). |
list | Returns a list of all API keys for the current customer. |
list_for_server | Returns a list of API keys bound to a specific server. |
view | Returns detailed information about a single API key. |
auth.php¶
Authentication and authorization module: session management, login via WHMCS, LDAP, API keys, and SSO (Google, GitHub, VK), 2FA verification, SMS and email, as well as customer tag management.
| Method | Description |
|---|---|
2fa_check | Verifies the correctness of the two-factor authentication code for the current user session. |
2fa_resend | Requests a resend of the two-factor authentication code for the user. If the user is in debug mode, the code is returned in the response. |
billing_list | Returns a list of available payment systems (billings) available to the current user or administrator. |
email_check | Verifies email validity, sends a verification code, or checks an existing code/token to confirm the address. |
flip_tag | Creates or removes the specified tag for the user. If the tag already exists, it will be removed; if it does not exist, it will be created. |
get_log | Returns an authorization event log for a specified period or by token. |
get_log_details | Returns detailed information about authentication events for the current user (via user_token). |
github_init | Returns the data required to initialize authorization via GitHub (client_id and redirect_uri). |
github_signin | Exchanges the authorization code for a GitHub access token and links the account to the user (SSO). If the token is already linked, it redirects to an 'already used' page; otherwise, it performs the linking. |
google_signin | Logs in using a Google ID Token. If the token is already linked to the user, the method links the current session with this account. |
info | Returns detailed information about the current user session, including role, permissions, customer data, and a list of active servers. |
login | Authorization via client API key. Returns an access token, user role, and a list of available servers. |
logout | Clears the current access token. |
session_reset | Terminates all active user sessions corresponding to the provided reset token and clears associated tags. |
set_tag | Creates or removes a tag for the customer. Allows setting values for specific parameters (e.g., auto_credit) or simply toggling the presence of a tag. |
tg_verify | Links the user's Telegram username to their account and returns a link to the bot for notifications. |
vk_init | Initiates the authorization process via VK by generating temporary parameters (code_challenge, state) and saving them for subsequent verification during login. |
vk_signin | Performs user authorization via the VK OAuth2 protocol. Exchanges the code for a token and links the account to the user. |
whmcslogin | Logs in using WHMCS credentials (email/password) or SSO (Google). Returns a session token, customer information, permissions, and 2FA status. |
eq.php¶
Equipment Management Module (eq.php): API for server deployment, power management, IPMI, backups, searching, and retrieving detailed hardware configuration information.
| Method | Description |
|---|---|
abort_reinstall | Terminates the server reinstallation process, removes associated tags (reinstall_start, autodeploy_start, autodeploy_timeout), and restores VLAN settings. |
add_ipmi_admin | Creates a user with administrator privileges for management via IPMI. If the user already exists, returns their data. |
add_ipmi_user | Creates a new IPMI user for the server. If the user is an administrator, the provided credentials are used. |
announceip | Performs announcement of the specified subnet or server to manage traffic routing. |
backup_get_schedule | Returns the current backup schedule for the specified server. |
backup_list | Returns a list of available backups for the specified server. |
backup_save_schedule | Saves the configured backup schedule for the specified server. |
boot_dev | Requests a server reboot to boot from the specified media (PXE or disk) depending on the boot mode. |
check_backup_lock | Checks if the backup process is locked for the specified server. |
check_pin | Checks the PIN code for operations. |
clear_pxe | Clears the current PXE configuration for the specified host. |
console | Requests the launch of the server management console via IPMI/NoVNC. |
create_backup | Initiates the backup creation process for the specified server. The operation is performed asynchronously. |
create_pxe | Requests the creation of a PXE configuration for subsequent OS reinstallation on the server. Supports configuring hostname, SSH keys, and post-install scripts. |
delete_backup | Deletes the specified server backup by its name. |
deploy | Starts the deployment process of selected equipment or a preset based on provided configuration parameters. |
get_ipmi | Returns the IP address and IPMI interface model for the specified server. May contain multiple interfaces. |
get_traffic | Returns IPv4 traffic usage data for the specified server. |
get_upgrade_key | Returns a key to perform an upgrade operation, linked to a specific invoice (invoice_id). If no tags with the key are found, an empty string is returned. |
getserversforannounce | Returns a list of active user servers that have passed subnet mask (mask_23/mask_24) restriction checks and are available for IP announcement. |
groups | Returns the list of groups for a specific server. |
hard_off | Sends a command for forced (hard) power off of the equipment via IPMI/BMC. |
history | Returns the server event history. |
list | Returns a list of available or rented equipment with filtering by various parameters (location, status, type, etc.). |
off | Powers off the server. |
on | Powers on the server. |
order_instance | Starts the deployment process of a new server from a preset or reinstallation of an existing server with OS and additional software selection. |
ovirt_novnc | Requests NoVNC console access for the server via oVirt. Requires authorization and appropriate permissions. |
reboot | Sends a request to reboot the specified equipment via IPMI or system tools. |
reinstall | Creates a key to start the server reinstallation stage and queues the task (stage: create_pxe). |
remove_ipmi_user | Removes additional IPMI user accounts for the specified server. |
request_backup_link | Requests the generation of a temporary link to download a server backup. |
restore_backup | Starts the process of restoring the server from an existing backup by filename. |
search | Returns a list of available servers using various filters (group, location, status, type, etc.). |
sensors | Returns sensor status data for the specified server via IPMI. |
set_pin | Sets the PIN code for operations. |
show | Returns detailed information about the server, including hardware (hwconfig), current status, IP addresses, interfaces, and IPMI. |
status | Returns the current server status and its state data. |
status_check | Performs a check of the current equipment state (statuses) through internal system mechanisms. |
suspend | Requests suspension (suspend) or unsuspension (unsuspend) of a VPS/server. If the action is suspend, the server will be locked. |
traffic_add | Creates an invoice for additional outbound traffic for the server. After payment, the limit will be increased. |
unified_server_search | Unified search for servers by query. |
unit_reset | Requests an IPMI settings reset for the specified server. If the operation requires confirmation, a callback is returned. |
unsuspend | Unlocks (unsuspends) the server if it was temporarily suspended. |
update_servers | Updates the list of active and pending payment servers for the user, including WHMCS status checks and prebill order processing. |
eq_callback.php¶
Module for processing asynchronous responses from workers for equipment (EQ) and virtual machine management. Handles task statuses (deploy, reinstall, backup, network), updates billing, and sends noti
| Method | Description |
|---|---|
check | Checks the current status of a task by key and returns the execution context if the task is completed or at an intermediate stage. |
reinstall | Callback handler from the worker after the reinstallation operation is completed. Updates the server status, clears temporary tags, sends an email to the client with access credentials, and updates billing. |
ip.php¶
Module for managing IP addresses and network infrastructure: retrieving IP information, managing PTR records, monitoring traffic, and working with subnets and VLANs.
| Method | Description |
|---|---|
get_client_ip | Returns the IP address of the current client making the request. |
get_ip | Returns full information about a specific IP address, including network data, mask, and ownership. |
get_ptr | Returns the PTR record (reverse DNS name) for the specified IP address bound to a server. |
get_traffic | Returns incoming and outgoing traffic statistics for the specified IP address over a given period. Supports summary mode or detailed breakdown by timestamps. |
list_free_ip | Returns a list of unused IP addresses for the specified location or subnet. For clients, the subnet ID is used; for administrators, the location code is used. |
set_main | Sets the specified IP address as the primary IP for the server interface. Updates billing data in WHMCS if applicable. |
update_ptr | Sets the reverse DNS record (PTR) for the specified IP address bound to a server. |
iso.php¶
ISO Image Management Module: uploading, deleting, mounting, and unmounting images on servers, as well as retrieving lists of available and uploaded images.
| Method | Description |
|---|---|
add | Adds a new ISO image or updates an existing one by name. |
delete | Deletes an ISO image by ID. |
list_iso | Returns a list of available ISO images. |
mount_iso | Mounts an ISO image on the specified server. |
unmount_iso | Unmounts an ISO image from the specified server. |
upload | Uploads an ISO image via URL. |
uploaded | Returns a list of uploaded ISO images for a client or staff member. |
jenkins.php¶
Jenkins integration module for task management: retrieving the list of available tasks and executing them for servers.
| Method | Description |
|---|---|
get_tasks | Returns the list of available Jenkins tasks accessible to the current user or client. |
jira.php¶
Jira integration module for creating support tickets related to server management (power, reboot, KVM) and sales assistance requests.
| Method | Description |
|---|---|
request_PXEboot | Creates a Jira ticket for manual server PXE boot if remote management is unavailable. |
request_assistance | Creates a Jira ticket for the sales department with details regarding service cancellation or modification. |
request_check | Creates a Jira ticket to check and boot the server into the OS if remote management is unavailable. |
request_kvm | Creates a Jira ticket to connect an IP KVM to the server. |
request_poff | Creates a Jira ticket for manual server power off. |
request_pon | Creates a Jira ticket for manual server power on. |
request_reboot | Creates a Jira ticket for manual server reboot. |
nat.php¶
Module for managing static NAT: adding and removing IP address forwarding rules via MikroTik.
| Method | Description |
|---|---|
add_static_nat | Adds a static NAT passthrough for the specified server. Accepts the server ID and ACL for IPMI. |
remove_static_nat | Removes the static NAT passthrough for the specified server or white IP. |
net.php¶
Network infrastructure management module: adding and removing IP addresses, blocking traffic, managing network port status, retrieving statistics, and displaying Cacti graphs.
| Method | Description |
|---|---|
add_ipv4 | Adds the specified number of IPv4 addresses to a server or assigns specific IP addresses. Supports automatic search for free IPs in a VLAN or manual specification of a list. |
block_ip | Blocks the specified IP address on the server via BIRD or blackhole. Requires authentication. |
get_status | Returns the current status and configuration of the server's network port. Requires authentication. |
port_off | Disables the specified server network port and adds a block tag with the specified reason. |
port_on | Enables the specified server network port, removing the block (tag 'block') if it was not set by an administrator. |
remove_ipv4 | Removes the specified IPv4 address from the server. If the remove_all flag is passed, all addresses are removed. |
show_cacti | Returns traffic monitoring graph data for the specified server and port from the Cacti system. |
show_ipv4_free | Returns a list of available IPv4 addresses for the specified server and interface in a given VLAN. Requires authentication. |
unblock_ip | Removes the block from the specified IP address on the server. Requires access rights verification. |
os.php¶
Operating system management module: provides methods for adding, removing, updating, and retrieving a list of OS with filtering by hardware compatibility and licenses.
| Method | Description |
|---|---|
list | Returns a list of operating systems. If id or instance_id is specified, filters OS by compatibility with hardware or preset. Also returns a list of excluded OS. |
pdns.php¶
DNS record and zone management module: adding, deleting, and viewing domains, subdomains, and zones, as well as retrieving callback-URL information.
| Method | Description |
|---|---|
add_dns | Adds a new DNS record to the specified zone. |
add_domain | Adds a new domain to the DNS system for the specified client. |
delete_dns | Deletes the specified DNS record. |
delete_domain | Deletes the domain and all associated records. |
get_cb_url | Returns the URL for callback notifications. |
list_domains | Returns the list of client domains. |
list_zones | Returns the list of DNS zones. |
view_zone | Returns details of the specified DNS zone. |
presets.php¶
Server preset management module: retrieving lists, grouping, searching for suitable servers, and detailing configurations with prices in different currencies.
| Method | Description |
|---|---|
groups | Returns a list of available preset groups |
info | Returns a list of available presets considering the selected currencies (default EUR, RUB) |
list | Returns a list of available server presets with filtering by location and access rights |
search | Returns a list of servers matching the parameters of the specified preset. If the user is not authorized, the search is limited to free offers only. |
show | Returns information about a preset by ID or name. Supports filtering and limits. |
rhr.php¶
Remote Hands Requests Management Module: creation, filtering, status updates, and communication regarding requests.
| Method | Description |
|---|---|
add | Creates a new Remote Hands Request (RHR) specifying the type and equipment. |
chat | Adds a client-visible message to the request history. |
discard | Recursively changes the request status to canceled or closed. |
list | Returns a list of available RHR tasks with filtering by location, status, and date. |
s3.php¶
S3 storage management module: creating and deleting accounts, managing buckets and files, obtaining usage statistics, managing pricing plans and billing.
| Method | Description |
|---|---|
cancel_payment_account_deletion | Cancels the service cancellation process for an S3 account, restoring its status. |
create_account | Creates a new S3 account (bucket) for the client, links it to a pricing plan, and creates an order in the billing system. |
create_bucket | Creates a new S3 bucket for the user. Verifies that s3uid belongs to the current client and creates the bucket via the provider API. |
create_order | Creates a new S3 account, a bucket, and links it to a pricing plan with automatic payment through billing. |
delete_account | Deletes the user's S3 account, performing action auditing and logging into history. |
delete_bucket | Deletes the specified bucket from S3 storage if it belongs to the user. |
delete_file | Deletes the specified file from the user's S3 bucket |
delete_payment_account | Requests S3 service cancellation and subsequent deletion of the payment account. Returns information about the cancellation date. |
get_buckets | Returns a list of the user's S3 buckets, including bandwidth usage and snapshots information |
get_buckets_rmq | Returns a list of the user's buckets, their usage information, billing data, metrics, and S3 access credentials. |
get_files | Returns a list of files and folders in the specified bucket with support for pagination and search. |
get_users | Returns a list of S3 users with details on traffic, storage, and service data (billing/status) |
history | Returns event history related to a specific S3 account or user |
list_plans | Returns a list of available S3 plans considering user permissions and location. For administrators, it returns the full list; for clients, only active plans with prices in their currency. |
show_key | Returns the decrypted secret key or access key for the specified S3 account |
software.php¶
Software Management Module: provides methods for retrieving a list of available software with filtering by server characteristics or presets, as well as selecting compatible presets and operating syst
| Method | Description |
|---|---|
list | Returns a list of software suitable for a specific server (id) or preset (instance_id), taking into account licenses, hardware specifications, and promotional offers. |
stocks.php¶
Server inventory management module: provides lists of available servers with filtering by locations and groups, as well as detailed information about a specific server.
| Method | Description |
|---|---|
list | Returns a list of available servers in inventory with the ability to filter by location and group. |
show | Returns detailed information about a specific server by its identifier. |
tags.php¶
Tag management module for infrastructure components: adding, removing, clearing, searching, and displaying tag lists for servers and variables.
| Method | Description |
|---|---|
add | Adds a custom tag to a server or component. Supports bulk addition via an ID list. |
clear | Clears all or non-essential tags from a component. For clients, only public tags are available. |
get | Retrieves tags for a component. (Implementation is empty in code, method is in whitelist) |
list | Returns a list of tags for a specific server or component. For clients, there is a restriction by component type (eq, vars). |
remove | Removes a tag by its name for a specific component or removes all specified tags from an ID list. If id_list is passed, the operation is performed in bulk. |
search | Searches for components matching a specific tag and value. |
search_user | Searches for user equipment by tag value. Used in global search form. |
show | Shows possible tags for a component. (Implementation is empty in code, method is in whitelist) |
traffic_plans.php¶
Traffic tariff plan management module: creation, deletion, updating, and retrieval of available plans with filtering by server or location and price conversion.
| Method | Description |
|---|---|
list | Returns a list of suitable traffic tariff plans for the specified server (id) or location. Supports filtering by hardware type and price conversion to EUR/USD. |
vm.php¶
Virtual Machine (VM) management module providing an API for creating, retrieving, deleting, and restoring snapshots, as well as loading statistics.
| Method | Description |
|---|---|
create_snapshot | Initiates the creation of a snapshot for the specified virtual machine. Returns a task key for status tracking. |
get_snapshot | Returns a list of snapshots and settings for the specified virtual machine. |
load_stats | Initiates the loading of resource usage statistics for the virtual machine. |
remove_snapshot | Initiates the deletion of a snapshot with the specified name. |
restore_snapshot | Initiates the restoration of the virtual machine state from a snapshot. |
update_restore_settings | Updates automatic restore and snapshot rotation settings for the specified virtual machine. |
whmcs.php¶
WHMCS integration module for managing customers, invoices, credit, order cancellations, and server billing data.
| Method | Description |
|---|---|
add_contact | Adds an additional contact user for an existing customer in WHMCS. If the type is not specified, a random contact is created. |
apply_credit | Applies a credit amount (balance) to pay a specific invoice in WHMCS. If the invoice status changes to 'Paid', traffic overage tags are automatically cleared. |
create_addfunds | Creates an invoice in WHMCS to top up the customer's balance by the specified amount. If the subscribe option is enabled, automatic renewal is activated. |
delete_cancellation_request | Deletes a cancellation request for a specific server, restoring the invoice status or allowing a new one to be created. |
delete_contact | Deletes an additional contact associated with a customer in WHMCS. |
download_invoice | Returns a PDF file of the invoice in base64 format for downloading or viewing. |
generate_due_invoice | Generates the next invoice for a server in WHMCS, considering the current billing cycle and active add-ons. It is blocked if the customer has unpaid invoices or if the next payment date has not yet arrived. |
get_billing_data | Returns detailed information about the billing data of a specific server (synchronized data from WHMCS). |
get_cancellation_requests | Returns a list of active cancellation requests for a specific server or user, with filtering by date, type, and payment status. |
get_client | Returns detailed information about the authenticated client, including data from WHMCS and internal system data (tags, verification). Supports extended data retrieval via the full parameter. |
get_clientgroups | Returns a list of available customer groups from WHMCS for the specified location. |
get_contacts | Returns a list of additional contacts associated with a customer in WHMCS. If an email is specified, only contacts with corresponding access rights are returned. |
get_invoice | Returns detailed information about an invoice from WHMCS, including customer data and payment status. |
get_invoices | Returns a list of all invoices associated with the customer in the selected WHMCS location. |
get_related_invoices | Returns a list of all invoices associated with a specific server (via account_id). |
getcredits | Returns information about available credits on the user's account in WHMCS. |
getpaymentgw | Returns a list of available payment methods (gateways) for a specific invoice with processed payment links. |
mass_pay | Allows bulk payment of several customer invoices in a single transaction. A minimum of 2 invoices is required. |
request_cancellation | Initiates the order or subscription cancellation process. It checks for active licenses, invoice payment status, and calculates the refund amount considering actual time used and traffic limits. |
request_subscription_cancellation | Initiates the bank subscription cancellation process for a server. Creates a JIRA ticket and attaches a request tag to the server. |
reset_password | Allows resetting a user's password. If reset_token is not provided, a link is sent via email. If the token is known, 2FA verification and password change are performed. |
transactions | Returns a list of user transactions for a specific invoice or transaction ID. |
update_client | Updates the customer profile in WHMCS, including personal data (name, email), contact information, 2FA settings, and custom fields. Supports updating legal data for companies. |
update_contact | Updates additional contact information (first name, last name, email, phone) for a customer in WHMCS. Supports email uniqueness check and phone number verification. |