# Añadir atribución personalizada

> Añade datos de atribución de marketing personalizada a un perfil.

## OpenAPI

```yaml
/api-specs/web-api.yaml post /api/v2/web-api/attribution/
openapi: 3.1.0
info:
  title: Adapty Web API
  version: 1.0.0
  description: |
    La Adapty Web API te permite integrar la plataforma de gestión de suscripciones de Adapty
    en tus aplicaciones web. Esta API proporciona endpoints para obtener paywalls,
    registrar visitas a paywalls y añadir datos de atribución.
servers:
  - url: https://api.adapty.io
    description: Servidor de producción
security:
  - apikeyAuth: []
paths:
  /api/v2/web-api/attribution/:
    post:
      summary: Añadir atribución personalizada
      description: Añade datos de atribución de marketing personalizada a un perfil.
      operationId: addAttribution
      security:
        - apikeyAuth: []
      requestBody:
        required: true
        content:
          application/json:
            schema:
              $ref: "#/components/schemas/AddAttributionRequest"
            examples:
              basic:
                summary: Datos básicos de atribución
                value:
                  status: organic
                  attribution_user_id: attribution_user_id_value
                  channel: marketing_channel_value
                  campaign: campaign_name_value
                  ad_group: ad_group_name_value
                  ad_set: ad_set_name_value
                  creative: creative_name_value
                  customer_user_id: user123
      responses:
        "201":
          description: La atribución se ha añadido correctamente al perfil. El cuerpo de la respuesta está vacío.
          content:
            application/json:
              schema:
                type: object
                description: Cuerpo de respuesta vacío
        "400":
          description: Solicitud incorrecta
          content:
            application/json:
              schema:
                $ref: "#/components/schemas/InvalidEnumerationMemberError"
        "401":
          description: No autorizado
          content:
            application/json:
              schema:
                $ref: "#/components/schemas/UnauthorizedError"
        "404":
          description: No encontrado
          content:
            application/json:
              schema:
                $ref: "#/components/schemas/ProfileNotFoundError"
components:
  schemas:
    AddAttributionRequest:
      type: object
      required:
        - status
      properties:
        status:
          type: string
          enum:
            - organic
            - non_organic
            - unknown
          description: Indica si la atribución es orgánica o no orgánica.
          example: organic
        attribution_user_id:
          type: string
          description: ID asignado al usuario por la fuente de atribución.
          example: attribution_user_id_value
        channel:
          type: string
          description: Nombre del canal de marketing.
          example: marketing_channel_value
        campaign:
          type: string
          description: Nombre de la campaña de marketing.
          example: campaign_name_value
        ad_group:
          type: string
          description: Grupo de anuncios de atribución.
          example: ad_group_name_value
        ad_set:
          type: string
          description: Conjunto de anuncios de atribución.
          example: ad_set_name_value
        creative:
          type: string
          description: Palabra clave del creativo de atribución.
          example: creative_name_value
        customer_user_id:
          type: string
          description: ID de usuario que utilizas en tu aplicación para identificar al usuario. Por ejemplo, puede ser tu UUID de usuario, correo electrónico o cualquier otro ID. Nulo si no lo configuraste. Se requiere `customer_user_id` o `profile_id`.
          example: user123
        profile_id:
          type: string
          description: Identificador de un usuario en Adapty. Puedes encontrarlo en el campo **Adapty ID** del perfil en el Adapty Dashboard. Se requiere `customer_user_id` o `profile_id`.
          example: 3286abd3-48b0-4e9c-a5f6-ac0a006804a6
    InvalidEnumerationMemberError:
      type: object
      properties:
        errors:
          type: array
          items:
            type: object
            properties:
              source:
                type: string
              errors:
                type: array
                items:
                  type: string
        error_code:
          type: string
        status_code:
          type: integer
    UnauthorizedError:
      type: object
      properties:
        errors:
          type: array
          items:
            type: object
            properties:
              source:
                type: string
              errors:
                type: array
                items:
                  type: string
        error_code:
          type: string
        status_code:
          type: integer
    ProfileNotFoundError:
      type: object
      properties:
        errors:
          type: array
          items:
            type: object
            properties:
              source:
                type: string
              errors:
                type: array
                items:
                  type: string
        error_code:
          type: string
        status_code:
          type: integer
  securitySchemes:
    apikeyAuth:
      type: apiKey
      in: header
      name: Authorization
      description: |
        Las solicitudes a la API deben autenticarse con tu clave API pública en la cabecera **Authorization**
        con el valor `Api-Key {tu_clave_api_publica}`, por ejemplo,
        `Api-Key public_live_...`. Encuentra esta clave en el Adapty Dashboard ->
        **App Settings** -> pestaña **General** -> sección **API keys**.
```
