# Actualizar paywall

> Actualiza el Remote Config de un paywall específico. Este endpoint te permite modificar los valores del Remote Config que ayudan a personalizar la apariencia y el comportamiento del paywall.
>
> **Importante:** Si actualizas un Remote Config, se sobrescribirán todos los Remote Configs existentes. Si necesitas conservar los Remote Configs actuales, primero obtén el paywall, copia los remote_configs y modifica únicamente los objetos necesarios en la solicitud de actualización.

## OpenAPI

```yaml
/api-specs/adapty-api.yaml put /api/v2/server-side-api/paywalls/{paywall_id}/
openapi: 3.1.0
info:
  title: API de servidor de Adapty
  version: 1.0.0
servers:
  - url: https://api.adapty.io
    description: Servidor de producción
paths:
  /api/v2/server-side-api/paywalls/{paywall_id}/:
    put:
      summary: Actualizar paywall
      description: |
        Actualiza el Remote Config de un paywall específico. Este endpoint te permite modificar los valores del Remote Config que ayudan a personalizar la apariencia y el comportamiento del paywall.

        **Importante:** Si actualizas un Remote Config, se sobrescribirán todos los Remote Configs existentes. Si necesitas conservar los Remote Configs actuales, primero obtén el paywall, copia los remote_configs y modifica únicamente los objetos necesarios en la solicitud de actualización.
      operationId: updatePaywall
      tags:
        - Paywalls
      security:
        - apikeyAuth: []
      parameters:
        - name: paywall_id
          in: path
          required: true
          schema:
            type: string
            format: uuid
          description: El identificador único del paywall a actualizar
      requestBody:
        required: true
        content:
          application/json:
            schema:
              $ref: "#/components/schemas/PaywallUpdateRequest"
            example:
              remote_configs:
                - locale: en
                  data: "{\"title\":\"Premium Features\",\"subtitle\":\"Unlock all premium content\"}"
      responses:
        "200":
          description: Paywall actualizado correctamente
          content:
            application/json:
              schema:
                $ref: "#/components/schemas/PaywallResponse"
              example:
                title: Premium Subscription
                paywall_id: fd891d4f-5906-45b9-97c1-13cc3dc665df
                use_paywall_builder: true
                use_paywall_builder_legacy: false
                updated_at: "2025-07-30T11:13:58.798Z"
                created_at: "2025-07-30T11:13:58.798Z"
                state: live
                is_deleted: false
                web_purchase_url: https://example.com/purchase
                products:
                  - product_id: b95e9e51-a056-4eb6-9cf7-b75d139e7c3c
                    title: Premium Monthly
                    product_set: uncategorised
                    offer:
                      product_offer_id: e31a4296-f250-4faf-ac80-3cc93c2da8f5
                      title: Free Trial
                remote_configs:
                  - locale: en
                    data: "{\"title\":\"Premium Features\",\"subtitle\":\"Unlock all premium content\"}"
                main_screenshot:
                  image_id: 123456
                  url: https://public-media.adapty.io/public/screenshot.jpg
        "400":
          description: Solicitud incorrecta
          content:
            application/json:
              schema:
                $ref: "#/components/schemas/ErrorResponse"
              example:
                errors:
                  - source: remote_configs
                    errors:
                      - At least one field must be provided
                error_code: validation_error
                status_code: 400
        "401":
          description: No autorizado
          content:
            application/json:
              schema:
                $ref: "#/components/schemas/ErrorResponse"
              example:
                errors:
                  - Invalid API key
                error_code: unauthorized
                status_code: 401
        "404":
          description: Paywall no encontrado
          content:
            application/json:
              schema:
                $ref: "#/components/schemas/ErrorResponse"
              example:
                errors:
                  - source: null
                    errors:
                      - Paywall not found
                error_code: paywall_does_not_exist
                status_code: 404
        "500":
          description: Error interno del servidor
          content:
            application/json:
              schema:
                $ref: "#/components/schemas/ErrorResponse"
components:
  schemas:
    PaywallUpdateRequest:
      type: object
      properties:
        remote_configs:
          type: array
          items:
            type: object
            properties:
              locale:
                type: string
                description: La configuración regional del Remote Config (p. ej., "en", "es", "fr")
              data:
                type: string
                description: Cadena JSON que contiene los datos del Remote Config
            required:
              - locale
              - data
          description: Array de objetos RemoteConfig a actualizar
      required:
        - remote_configs
      description: Se debe proporcionar al menos un campo
    PaywallResponse:
      type: object
      properties:
        title:
          type: string
          description: El nombre del paywall, tal como está definido en tu Adapty Dashboard
        paywall_id:
          type: string
          format: uuid
          description: El identificador único del paywall
        use_paywall_builder:
          type: boolean
          description: Si el paywall utiliza el Paywall Builder
        use_paywall_builder_legacy:
          type: boolean
          description: Si el paywall utiliza el Paywall Builder heredado
        updated_at:
          type: string
          format: date-time
          description: Marca de tiempo de la última actualización del paywall
        created_at:
          type: string
          format: date-time
          description: Marca de tiempo de la creación del paywall
        state:
          type: string
          enum:
            - draft
            - live
            - inactive
            - archived
          description: El estado actual del paywall
        is_deleted:
          type: boolean
          description: Si el paywall está marcado como eliminado
        web_purchase_url:
          type: string
          format: uri
          nullable: true
          description: URL para compras web, si corresponde
        products:
          type: array
          items:
            type: object
            properties:
              product_id:
                type: string
                format: uuid
                description: El identificador único del producto
              title:
                type: string
                description: El título del producto
              product_set:
                type: string
                enum:
                  - weekly
                  - monthly
                  - trimonthly
                  - semiannual
                  - annual
                  - lifetime
                  - uncategorised
                  - nonsubscriptions
                  - two_months
                  - consumable
                description: La categoría del conjunto de productos
              offer:
                type: object
                nullable: true
                properties:
                  product_offer_id:
                    type: string
                    format: uuid
                    description: El identificador único de la oferta de producto
                  title:
                    type: string
                    description: El título de la oferta
                required:
                  - product_offer_id
                  - title
            required:
              - product_id
              - title
              - product_set
              - offer
          description: Array de objetos de producto con información sobre los productos
        remote_configs:
          type: array
          items:
            type: object
            properties:
              locale:
                type: string
                description: La configuración regional del Remote Config
              data:
                type: string
                description: Cadena JSON que contiene los datos del Remote Config
            required:
              - locale
              - data
          description: Array de objetos RemoteConfig con la configuración regional y los datos
        main_screenshot:
          type: object
          nullable: true
          properties:
            image_id:
              type: integer
              description: El identificador único de la imagen
            url:
              type: string
              format: uri
              description: La URL de la imagen
          required:
            - image_id
            - url
          description: Objeto de captura de pantalla principal con image_id y url
      required:
        - title
        - paywall_id
        - use_paywall_builder
        - use_paywall_builder_legacy
        - updated_at
        - created_at
        - state
        - is_deleted
        - products
    ErrorResponse:
      type: object
      properties:
        errors:
          type: array
          items:
            type: object
            properties:
              source:
                type: string
                nullable: true
                description: Origen del error
              errors:
                type: array
                items:
                  type: string
                description: Array de mensajes de error
        error_code:
          type: string
          description: Nombre corto del error
        status_code:
          type: integer
          description: Código de estado HTTP
      required:
        - errors
        - error_code
        - status_code
  securitySchemes:
    apikeyAuth:
      type: apiKey
      name: Authorization
      in: header
      default: Api-Key {Your secret API key}
      description: |
        Las solicitudes a la API deben autenticarse con tu clave API secreta en la cabecera **Authorization**
        con el valor `Api-Key {your_secret_api_key}`, por ejemplo,
        `Api-Key secret_live_...`. Puedes encontrar esta clave en el Adapty Dashboard ->
        **App Settings** -> pestaña **General** -> sección **API keys**.
```
