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

# Create a redirect

export const ScopesList = ({scopes = [], description = "Esta API requiere uno de los siguientes ámbitos:"}) => {
  if (!scopes || scopes.length === 0) {
    return null;
  }
  const sortedScopes = scopes.sort((a, b) => a.localeCompare(b));
  return <div>
      <div className="text-sm mb-2">{description}</div>
      <div>
        {sortedScopes.map((scope, index) => <div key={index}>
            <code>
              <span className="text-xs">{scope}</span>
            </code>
          </div>)}
      </div>
    </div>;
};

export const SupportedProducts = ({marketing, sales, service, cms, marketingLevel, salesLevel, serviceLevel, cmsLevel}) => {
  const translations = {
    header: "Productos compatibles",
    description: "Se requiere uno de los siguientes productos o productos de ediciones superiores.",
    productNames: {
      marketing: "Marketing Hub",
      sales: "Sales Hub",
      service: "Service Hub",
      cms: "Content Hub"
    },
    tiers: {
      free: "Gratuito",
      starter: "Starter",
      professional: "Pro",
      enterprise: "Enterprise"
    }
  };
  const translateTier = tier => {
    if (!tier) return '';
    const lowerTier = tier.toLowerCase();
    return translations.tiers[lowerTier] || tier;
  };
  const products = [{
    name: marketing ? translations.productNames.marketing : '',
    level: translateTier(marketingLevel),
    icon: "https://mintlify-assets.b-cdn.net/Icons/marketing-bolt.svg",
    alt: "Marketing Hub"
  }, {
    name: sales ? translations.productNames.sales : '',
    level: translateTier(salesLevel),
    icon: "https://mintlify-assets.b-cdn.net/Icons/sales-star.svg",
    alt: "Sales Hub"
  }, {
    name: service ? translations.productNames.service : '',
    level: translateTier(serviceLevel),
    icon: "https://mintlify-assets.b-cdn.net/Icons/service-heart.svg",
    alt: "Service Hub"
  }, {
    name: cms ? translations.productNames.cms : '',
    level: translateTier(cmsLevel),
    icon: "https://mintlify-assets.b-cdn.net/Icons/content-play.svg",
    alt: "Content Hub"
  }].filter(product => product.name && product.level);
  if (products.length === 0) return null;
  return <div>
      <div className="text-sm mb-2">{translations.description}</div>
      <div className={`grid ${products.length === 1 ? 'grid-cols-1' : 'grid-cols-2'} gap-1.5`}>
        {products.map((product, index) => <div key={index} style={{
    display: 'flex',
    alignItems: 'center'
  }}>
            <img src={product.icon} alt={product.alt} className="w-3.5 h-3.5 mr-1.5 mt-2.5 mb-2.5 flex-shrink-0 align-middle" />
            <span className="font-medium mr-1 text-sm">{product.name} -</span>
            <span className="text-sm">{product.level}</span>
          </div>)}
      </div>
    </div>;
};

<AccordionGroup>
  <Accordion title="Supported products" defaultOpen="true" icon="cubes">
    <SupportedProducts marketing={true} sales={true} service={true} cms={true} marketingLevel="PROFESSIONAL" salesLevel="FREE" serviceLevel="FREE" cmsLevel="STARTER" />
  </Accordion>

  <Accordion title="Required Scopes" icon="key">
    <ScopesList
      scopes={[
  'content'
]}
    />
  </Accordion>
</AccordionGroup>


## OpenAPI

````yaml specs/2026-03/cms-url-redirects-v2026-03.json POST /cms/url-redirects/2026-03
openapi: 3.0.1
info:
  title: Redireccionamientos de URL
  description: Basepom for all HubSpot Projects
  version: 2026-03
  x-hubspot-product-tier-requirements:
    marketing: PROFESSIONAL
    sales: FREE
    service: FREE
    cms: STARTER
    commerce: FREE
    crmHub: FREE
    dataHub: FREE
  x-hubspot-api-use-case: >-
    Redirecciona una página hacia otra o redirecciona un blog entero con una URL
    utilizando variables de patrón flexible.
  x-hubspot-introduction: >-
    Usa la API de redireccionamiento de URL para redireccionar tráfico desde una
    página o publicación de blog alojada en HubSpot hacia cualquier URL.
    Redirecciona páginas a URL específicas o usa redireccionamientos flexibles
    hacia varias páginas usando variables. Más información sobre la gestión de
    redireccionamientos en HubSpot.
servers:
  - url: https://api.hubapi.com
security: []
tags:
  - name: Basic
paths:
  /cms/url-redirects/2026-03:
    post:
      tags:
        - Basic
      operationId: post-/cms/url-redirects/2026-03_/cms/url-redirects/v3
      parameters: []
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/UrlMappingCreateRequestBody'
        required: true
      responses:
        '201':
          description: successful operation
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/UrlMapping'
        default:
          $ref: '#/components/responses/Error'
          description: ''
      security:
        - oauth2:
            - content
components:
  schemas:
    UrlMappingCreateRequestBody:
      required:
        - destination
        - redirectStyle
        - routePrefix
      type: object
      properties:
        destination:
          type: string
          description: >-
            La URL de destino, a la que debe redirigirse la URL objetivo si
            coincide con el `routePrefix`.
        isMatchFullUrl:
          type: boolean
          description: >-
            Si el `routePrefix` debe coincidir con la URL completa, incluido el
            dominio.
        isMatchQueryString:
          type: boolean
          description: >-
            Si el `routePrefix` debe coincidir con la ruta completa de la URL,
            incluida la cadena de consulta.
        isOnlyAfterNotFound:
          type: boolean
          description: >-
            Si el mapeo de redireccionamiento de URL debe aplicarse solo si no
            se encuentra una página activa en la URL. Si es False, el mapeo de
            redireccionamiento de URL tendrá prioridad sobre cualquier página
            existente.
        isPattern:
          type: boolean
          description: Si el `routePrefix` debe coincidir en función del patrón.
        isProtocolAgnostic:
          type: boolean
          description: >-
            Si el `routePrefix` debe coincidir con ambos protocolos HTTP y
            HTTPS.
        isTrailingSlashOptional:
          type: boolean
          description: Si se ignorará una barra diagonal final.
        precedence:
          type: integer
          description: >-
            Se utiliza para priorizar el redireccionamiento de URL. Si una URL
            dada coincide con más de un redireccionamiento, se utilizará el de
            **menor** precedencia.
          format: int32
        redirectStyle:
          type: integer
          description: >-
            El tipo de redireccionamiento que se creará. Las opciones incluyen:
            301 (permanente), 302 (temporal) o 305 (proxy). Encuentra más
            detalles
            [aquí](https://knowledge.hubspot.com/cos-general/how-to-redirect-a-hubspot-page).
          format: int32
        routePrefix:
          type: string
          description: >-
            La URL entrante de destino, la ruta o el patrón que debe coincidir
            para el redireccionamiento.
    UrlMapping:
      required:
        - created
        - destination
        - id
        - isMatchFullUrl
        - isMatchQueryString
        - isOnlyAfterNotFound
        - isPattern
        - isProtocolAgnostic
        - isTrailingSlashOptional
        - precedence
        - redirectStyle
        - routePrefix
        - updated
      type: object
      properties:
        created:
          type: string
          description: La fecha y hora en que se creó inicialmente la asignación de URL.
          format: date-time
        destination:
          type: string
          description: >-
            La URL de destino, a la que debe redirigirse la URL objetivo si
            coincide con el `routePrefix`.
        id:
          type: string
          description: El ID único de este redireccionamiento de URL.
        isMatchFullUrl:
          type: boolean
          description: >-
            Si el `routePrefix` debe coincidir con la URL completa, incluido el
            dominio.
        isMatchQueryString:
          type: boolean
          description: >-
            Si el `routePrefix` debe coincidir con la ruta completa de la URL,
            incluida la cadena de consulta.
        isOnlyAfterNotFound:
          type: boolean
          description: >-
            Si el mapeo de redireccionamiento de URL debe aplicarse solo si no
            se encuentra una página activa en la URL. Si es False, el mapeo de
            redireccionamiento de URL tendrá prioridad sobre cualquier página
            existente.
        isPattern:
          type: boolean
          description: Si el `routePrefix` debe coincidir en función del patrón.
        isProtocolAgnostic:
          type: boolean
          description: >-
            Si el `routePrefix` debe coincidir con ambos protocolos HTTP y
            HTTPS.
        isTrailingSlashOptional:
          type: boolean
          description: Si se ignorará una barra diagonal final.
        precedence:
          type: integer
          description: >-
            Se utiliza para priorizar el redireccionamiento de URL. Si una URL
            dada coincide con más de un redireccionamiento, se utilizará el de
            **menor** precedencia.
          format: int32
        redirectStyle:
          type: integer
          description: >-
            El tipo de redireccionamiento que se creará. Las opciones incluyen:
            301 (permanente), 302 (temporal) o 305 (proxy). Encuentra más
            detalles
            [aquí](https://knowledge.hubspot.com/cos-general/how-to-redirect-a-hubspot-page).
          format: int32
        routePrefix:
          type: string
          description: >-
            La URL entrante de destino, la ruta o el patrón que debe coincidir
            para el redireccionamiento.
        updated:
          type: string
          description: >-
            La fecha y hora en que se modificó por última vez la asignación de
            URL.
          format: date-time
    Error:
      required:
        - category
        - correlationId
        - message
      type: object
      properties:
        category:
          type: string
          description: La categoría del error
        context:
          type: object
          additionalProperties:
            type: array
            items:
              type: string
          description: Contexto de la condición de error
          example: >-
            {invalidPropertyName=[propertyValue], missingScopes=[scope1,
            scope2]}
        correlationId:
          type: string
          description: >-
            Un identificador único para la solicitud. Incluye este valor con
            cualquier informe de error o ticket de asistencia.
          format: uuid
          example: aeb5f871-7f07-4993-9211-075dc63e7cbf
        errors:
          type: array
          description: información adicional acerca del error
          items:
            $ref: '#/components/schemas/ErrorDetail'
        links:
          type: object
          additionalProperties:
            type: string
          description: >-
            Un mapa de nombres de enlaces a las URI asociadas que contienen
            documentación sobre el error o los pasos recomendados para
            solucionarlo
        message:
          type: string
          description: >-
            Un mensaje legible en el que se describa el error y los pasos para
            solucionarlo, si procede
          example: An error occurred
        subCategory:
          type: string
          description: >-
            Una categoría específica que contiene detalles más concretos acerca
            del error
      example:
        message: Invalid input (details will vary based on the error)
        correlationId: aeb5f871-7f07-4993-9211-075dc63e7cbf
        category: VALIDATION_ERROR
        links:
          knowledge-base: https://www.hubspot.com/products/service/knowledge-base
    ErrorDetail:
      required:
        - message
      type: object
      properties:
        code:
          type: string
          description: El código de estado asociado al detalle del error
        context:
          type: object
          additionalProperties:
            type: array
            items:
              type: string
          description: Contexto de la condición de error
          example: '{missingScopes=[scope1, scope2]}'
        in:
          type: string
          description: El nombre del campo o parámetro en el que se encontró el error.
        message:
          type: string
          description: >-
            Un mensaje legible en el que se describa el error y los pasos para
            solucionarlo, si procede
        subCategory:
          type: string
          description: >-
            Una categoría específica que contiene detalles más concretos acerca
            del error
  responses:
    Error:
      description: An error occurred.
      content:
        '*/*':
          schema:
            $ref: '#/components/schemas/Error'
  securitySchemes:
    oauth2:
      type: oauth2
      flows:
        authorizationCode:
          authorizationUrl: https://app.hubspot.com/oauth/authorize
          tokenUrl: https://api.hubapi.com/oauth/v1/token
          scopes:
            cms-url-redirects-delete: ''
            content: ''

````