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

# Create a promocode

> Create a promocode. <h3>OAuth</h3>Required scopes: <code>invoices</code>



## OpenAPI

````yaml /assets/openapi.json post /discounts/promocodes/v1
openapi: 3.0.2
info:
  title: Spacebring
  version: 1.0.0
  termsOfService: https://www.spacebring.com/terms
servers:
  - url: https://api.spacebring.com
security: []
paths:
  /discounts/promocodes/v1:
    post:
      tags:
        - Discounts
      summary: Create a promocode
      description: 'Create a promocode. <h3>OAuth</h3>Required scopes: <code>invoices</code>'
      operationId: createPromocode
      parameters:
        - in: header
          name: spacebring-network-id
          schema:
            type: string
            format: uuid
          required: false
          description: >-
            The id of the network. Required when using bearer token
            authentication
      requestBody:
        $ref: '#/components/requestBodies/createPromocode'
      responses:
        '201':
          description: Created
          content:
            application/json:
              schema:
                type: object
                properties:
                  promocode:
                    $ref: '#/components/schemas/promocode'
        '400':
          description: Bad Request
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/responseError'
      security:
        - BasicAuth: []
        - OAuth2:
            - invoices
components:
  requestBodies:
    createPromocode:
      required: true
      content:
        application/json:
          schema:
            type: object
            properties:
              promocode:
                type: object
                properties:
                  code:
                    type: string
                    minLength: 1
                  couponRef:
                    type: string
                    format: uuid
                  expiration:
                    type: object
                    properties:
                      date:
                        type: string
                        format: date-time
                        description: Required when expiration is enabled
                      enabled:
                        type: boolean
                    required:
                      - enabled
                  limitByFirstPurchase:
                    type: boolean
                  limitedRedemption:
                    type: object
                    properties:
                      enabled:
                        type: boolean
                      value:
                        type: integer
                        description: >-
                          Must be positive when enabled is true. Must not exceed
                          the coupon's limited redemption value
                    required:
                      - enabled
                      - value
                required:
                  - code
                  - couponRef
                  - expiration
                  - limitByFirstPurchase
                  - limitedRedemption
            required:
              - promocode
  schemas:
    promocode:
      type: object
      properties:
        archiveDate:
          $ref: '#/components/schemas/dateSchema'
        code:
          type: string
        couponRef:
          type: string
          format: uuid
        createDate:
          $ref: '#/components/schemas/dateSchema'
        expiration:
          type: object
          properties:
            date:
              $ref: '#/components/schemas/dateSchema'
            enabled:
              type: boolean
        id:
          type: string
          format: uuid
        limitByFirstPurchase:
          type: boolean
        limitedRedemption:
          type: object
          properties:
            enabled:
              type: boolean
            usage:
              type: integer
            value:
              type: integer
        locationRef:
          type: string
          format: uuid
        networkRef:
          type: string
          format: uuid
    responseError:
      type: object
      properties:
        message:
          type: string
        type:
          type: string
    dateSchema:
      format: date-time
      type: string
      description: The date and time in ISO 8601 format, e.g. 2021-05-21T10:00:00Z
  securitySchemes:
    BasicAuth:
      type: http
      description: >-
        See our [authentication
        documentation](https://www.spacebring.com/docs/api-reference/authentication#basic-authentication)
        for how to authorize your requests
      scheme: basic
    OAuth2:
      type: oauth2
      description: >-
        See our [authentication
        documentation](https://www.spacebring.com/docs/api-reference/authentication#oauth2)
        for how to authorize your requests
      flows:
        authorizationCode:
          authorizationUrl: https://api.spacebring.com/oauth2/authorize
          tokenUrl: https://api.spacebring.com/oauth2/token
          refreshUrl: https://api.spacebring.com/oauth2/token
          scopes:
            benefits.readonly: Read benefits and applications
            benefits: Read and write benefits and applications
            community.readonly: Read community companies and memberships
            community: Read and write community companies and memberships
            events.readonly: Read events and tickets
            events: Read and write events and tickets
            feed.readonly: Read feed posts
            feed: Read and write feed posts
            invoices.readonly: Read invoices
            invoices: Read and write invoices
            locations.readonly: Read locations
            locations: Read and write locations
            plans.readonly: Read plans
            plans: Read and write plans
            resources.readonly: Read resources and bookings
            resources: Read and write resources and bookings
            subscriptions.readonly: Read subscriptions
            subscriptions: Read and write subscriptions
            shop.readonly: Read products and orders
            shop: Read and write products and orders
            support.readonly: Read support tickets
            support: Read and write support tickets
            transactions.readonly: Read transactions
            transactions: Read and write transactions
            visitors.readonly: Read visitors
            visitors: Read and write visitors

````