> ## Documentation Index
> Fetch the complete documentation index at: https://developers.onidel.com/llms.txt
> Use this file to discover all available pages before exploring further.

# Create a new reserved IP

> Allocate a new reserved IP address in the specified location



## OpenAPI

````yaml /api-reference/openapi.yaml post /network/reserved_ips
openapi: 3.0.3
info:
  title: Onidel Cloud API - OpenAPI 3.0
  description: >-
    Welcome to the **Onidel Cloud API** documentation. This API allows
    developers to seamlessly integrate with the Onidel Cloud platform, enabling
    them to manage cloud resources efficiently and securely. With our API, you
    can automate processes, retrieve detailed account information, and manage
    virtual machines (VPS), networking, storage, and more.
  termsOfService: https://docs.onidel.com/policies/terms-of-service
  contact:
    email: support@onidel.com
  version: 1.2.0
servers:
  - url: https://api.cloud.onidel.com
security: []
tags:
  - name: SSH Key
    description: Manage SSH keys for secure server access.
  - name: VPC
    description: Manage Virtual Private Cloud (VPC) networks for isolated networking.
  - name: Firewall
    description: Manage firewall groups for VM security.
  - name: OS Template
    description: >-
      We have a wide range of operating systems available to deploy server
      instances.
  - name: Instance Type
    description: We provide different instance types for different workload.
  - name: Startup Script
    description: >-
      Manage startup scripts that run on first boot of a server instance.
      Maximum 10 scripts per team.
  - name: IP List
    description: >-
      Manage IP lists for use in firewall rules. IP lists group multiple IP
      addresses/CIDRs together.
  - name: Firewall Rule
    description: Manage firewall rules within a firewall group.
  - name: Object Storage
    description: Manage S3-compatible object storage services, buckets, and access keys.
  - name: Custom ISO
    description: Manage custom ISO images that can be used to boot server instances (BYOI).
  - name: Measured Boot Image
    description: >-
      Manage SEV-SNP measured direct boot images (UKIs) and attach/detach them
      to instances.
paths:
  /network/reserved_ips:
    post:
      tags:
        - Reserved IPs
      summary: Create a new reserved IP
      description: Allocate a new reserved IP address in the specified location
      requestBody:
        required: true
        content:
          application/json:
            schema:
              type: object
              properties:
                team_id:
                  type: string
                  description: >-
                    Team ID to create the reserved IP for. If not provided, uses
                    the user's primary team
                ip_type:
                  type: string
                  enum:
                    - ipv4
                    - ipv6
                  description: IPv4 (/32) or IPv6 (/64) address
                location:
                  type: string
                  description: Location name where the IP should be allocated
                name:
                  type: string
                  maxLength: 64
                  description: >-
                    Custom name for the reserved IP (defaults to IP address if
                    not provided)
              required:
                - location
      responses:
        '200':
          description: Reserved IP successfully created
          content:
            application/json:
              schema:
                type: object
                properties:
                  rip_id:
                    type: string
                    format: uuid
                    description: ID of the newly created reserved IP
                  ip_addr:
                    type: string
                    description: Newly created reserved IP address
                required:
                  - rip_id
        '400':
          description: Bad request
          content:
            application/json:
              schema:
                type: object
                properties:
                  err:
                    type: string
                    enum:
                      - UNSUPPORTED_LOCATION
                      - IP_NAME_TOO_LONG
                      - NOT_SUPPORTED
                    description: Error code indicating the specific validation failure
        '401':
          description: Unauthorized - user doesn't have write permission for the team
        '402':
          description: Payment required - insufficient balance
          content:
            application/json:
              schema:
                type: object
                properties:
                  err:
                    type: string
                    enum:
                      - INSUFFICIENT_BALANCE
        '403':
          description: Forbidden - quota exceeded
          content:
            application/json:
              schema:
                type: object
                properties:
                  err:
                    type: string
                    enum:
                      - RESERVED_IP_QUOTA_EXCEEDED
        '404':
          description: Resource not available
          content:
            application/json:
              schema:
                type: object
                properties:
                  err:
                    type: string
                    enum:
                      - RESOURCE_NOT_AVAILABLE
                    description: No available IP addresses in the specified location
      security:
        - api_key: []
components:
  securitySchemes:
    api_key:
      type: http
      scheme: bearer

````