> For clean Markdown of any page, append .md to the page URL.
> For a complete documentation index, see https://docs.ovac.councilbox.com/llms.txt.
> For full documentation content, see https://docs.ovac.councilbox.com/llms-full.txt.
> For AI client integration (Claude Code, Cursor, etc.), connect to the MCP server at https://docs.ovac.councilbox.com/_mcp/server.

# Upload council Act

POST https://api.ovac.pre.councilbox.com/council/:councilId/act
Content-Type: application/json

# Upload Appointment Act (`POST` - REST)

A diferencia del resto de la API, este método no utiliza la arquitectura GraphQL. Se trata de un **endpoint REST nativo** diseñado específicamente para la transferencia de archivos binarios, permitiendo la carga del acta o informe final de la cita provisto de su respectivo Código de Verificación Electrónica (CVE/CEA) o correspondiente.

### Detalles de la Solicitud

- **Método HTTP:** `POST`
    
- **URL:** `https://api.ovac.pre.councilbox.com/council/:councilId/act`
    
- **Content-Type:** `multipart/form-data`
    

### Cabeceras (Headers)

| **Key** | **Value** | **Requerido** | **Descripción** |
| --- | --- | --- | --- |
| **x-jwt-token** | {{token}} | SI | Token JWT de autenticación obtenido previamente en el método de login. |

## Referencia de la API

### Parámetros de Ruta (Path Parameters)

| Parámetro | Descripción | Requerido | Tipo |
| --- | --- | --- | --- |
| councilId | Identificador único de la cita a la que se desea permitir el acceso. | SI | Integer |

### Cuerpo de la Petición (Body Parameters - `form-data`)

| Parámetro | Descripción | Requerido | Tipo |
| --- | --- | --- | --- |
| file | Archivo físico del informe o acta (normalmente PDF) que contiene el CEA para almacenar en OVAC. | SI | File (Binary) |
| notify | Control de notificaciones automáticas:  <br>`true` -> Envía siempre una notificación al ciudadano informándole de la disponibilidad del documento (Valor por defecto si se omite).  <br>Cualquier otro valor -> El sistema procesará el archivo sin enviar notificación al ciudadano. | NO | Boolean |

> ⚙️ **Prerrequisitos de negocio:**  
Para que el backend acepte la carga del archivo, la cita debe encontrarse estrictamente en estado **`45`** (Procesando informe). Adicionalmente, este flujo requiere que la opción _"Mostrar footer en informe de cita"_ esté deshabilitada. 
  

## Ejemplos de Código y Peticiones

### 1\. Ejemplo de comando cURL

Al tratarse de una petición de tipo formulario multimedia (`multipart/form-data`), la estructura define los campos del cuerpo de forma independiente al archivo binario:

``` bash
curl --location "https://api.ovac.pre.councilbox.com/council/64879/act" \
--header "x-jwt-token: eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJqdGkiOiIzZTVhZTA1NC1jZGUyLTQ0MWEtYTY3Zi1kMGExNzYwYzUxNzYiLCJ1c2VyX2lkIjozNDc2LCJ0b2tlbl90eXBlIjoidXNlciIsImlhdCI6MTc3OTE3NjE2M30.0cWaj4uUaArUQR3C-RwqlpLafkX5Rih4LZs9ZPNpEFY" \
--form "file=@\"/Ruta/Documentos/Informes/64879.pdf\"" \
--form "notify=\"true\""

 ```

## Resultados Esperados (Respuestas HTTP)

### Caso A: Éxito (200 OK)

Si la cita se encuentra en el estado correcto (`45`) y el archivo se procesa sin anomalías.

``` json
{
    "success": true
}

 ```

### Caso B: Error de Validación (400 / 403 Bad Request)

Si la cita ya ha sido cerrada, no está en estado `45`, o la configuración de la organización deniega la inserción manual del documento externo.

``` json
{
    "message": "This council is not expecting this action"
}

 ```

> 💡 **Tip para la integración en Postman:** > Al dar de alta esta petición en tu colección, ve a la pestaña **Body**, marca la opción **form-data** y, al escribir la clave `file`, pasa el ratón sobre el extremo derecho de la casilla de texto para cambiar el desplegable de **Text** a **File**. Esto habilitará el botón nativo para seleccionar y adjuntar tu PDF de prueba.

Reference: https://docs.ovac.councilbox.com/metodos-api/ovac/upload-council-act

## OpenAPI Specification

```yaml
openapi: 3.1.0
info:
  title: ovac
  version: 1.0.0
paths:
  /council/:councilId/act:
    post:
      operationId: upload-council-act
      summary: Upload council Act
      description: >-
        # Upload Appointment Act (`POST` - REST)


        A diferencia del resto de la API, este método no utiliza la arquitectura
        GraphQL. Se trata de un **endpoint REST nativo** diseñado
        específicamente para la transferencia de archivos binarios, permitiendo
        la carga del acta o informe final de la cita provisto de su respectivo
        Código de Verificación Electrónica (CVE/CEA) o correspondiente.


        ### Detalles de la Solicitud


        - **Método HTTP:** `POST`
            
        - **URL:** `https://api.ovac.pre.councilbox.com/council/:councilId/act`
            
        - **Content-Type:** `multipart/form-data`
            

        ### Cabeceras (Headers)


        | **Key** | **Value** | **Requerido** | **Descripción** |

        | --- | --- | --- | --- |

        | **x-jwt-token** | {{token}} | SI | Token JWT de autenticación obtenido
        previamente en el método de login. |


        ## Referencia de la API


        ### Parámetros de Ruta (Path Parameters)


        | Parámetro | Descripción | Requerido | Tipo |

        | --- | --- | --- | --- |

        | councilId | Identificador único de la cita a la que se desea permitir
        el acceso. | SI | Integer |


        ### Cuerpo de la Petición (Body Parameters - `form-data`)


        | Parámetro | Descripción | Requerido | Tipo |

        | --- | --- | --- | --- |

        | file | Archivo físico del informe o acta (normalmente PDF) que
        contiene el CEA para almacenar en OVAC. | SI | File (Binary) |

        | notify | Control de notificaciones automáticas:  <br>`true` -> Envía
        siempre una notificación al ciudadano informándole de la disponibilidad
        del documento (Valor por defecto si se omite).  <br>Cualquier otro valor
        -> El sistema procesará el archivo sin enviar notificación al ciudadano.
        | NO | Boolean |


        > ⚙️ **Prerrequisitos de negocio:**  

        Para que el backend acepte la carga del archivo, la cita debe
        encontrarse estrictamente en estado **`45`** (Procesando informe).
        Adicionalmente, este flujo requiere que la opción _"Mostrar footer en
        informe de cita"_ esté deshabilitada. 
          

        ## Ejemplos de Código y Peticiones


        ### 1\. Ejemplo de comando cURL


        Al tratarse de una petición de tipo formulario multimedia
        (`multipart/form-data`), la estructura define los campos del cuerpo de
        forma independiente al archivo binario:


        ``` bash

        curl --location "https://api.ovac.pre.councilbox.com/council/64879/act"
        \

        --header "x-jwt-token:
        eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJqdGkiOiIzZTVhZTA1NC1jZGUyLTQ0MWEtYTY3Zi1kMGExNzYwYzUxNzYiLCJ1c2VyX2lkIjozNDc2LCJ0b2tlbl90eXBlIjoidXNlciIsImlhdCI6MTc3OTE3NjE2M30.0cWaj4uUaArUQR3C-RwqlpLafkX5Rih4LZs9ZPNpEFY"
        \

        --form "file=@\"/Ruta/Documentos/Informes/64879.pdf\"" \

        --form "notify=\"true\""

         ```

        ## Resultados Esperados (Respuestas HTTP)


        ### Caso A: Éxito (200 OK)


        Si la cita se encuentra en el estado correcto (`45`) y el archivo se
        procesa sin anomalías.


        ``` json

        {
            "success": true
        }

         ```

        ### Caso B: Error de Validación (400 / 403 Bad Request)


        Si la cita ya ha sido cerrada, no está en estado `45`, o la
        configuración de la organización deniega la inserción manual del
        documento externo.


        ``` json

        {
            "message": "This council is not expecting this action"
        }

         ```

        > 💡 **Tip para la integración en Postman:** > Al dar de alta esta
        petición en tu colección, ve a la pestaña **Body**, marca la opción
        **form-data** y, al escribir la clave `file`, pasa el ratón sobre el
        extremo derecho de la casilla de texto para cambiar el desplegable de
        **Text** a **File**. Esto habilitará el botón nativo para seleccionar y
        adjuntar tu PDF de prueba.
      tags:
        - subpackage_ovac
      parameters:
        - name: x-jwt-token
          in: header
          description: JWT token obtained from Login.
          required: true
          schema:
            type: string
      responses:
        '200':
          description: >-
            Successful response. GraphQL business errors may be returned inside
            the JSON `errors` field while transport status remains HTTP 200.
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/OVAC_upload_council_Act_Response_200'
      requestBody:
        content:
          application/json:
            schema:
              type: object
              properties: {}
servers:
  - url: https://api.ovac.pre.councilbox.com
  - url: https://api.ovac.councilbox.com
components:
  schemas:
    OVAC_upload_council_Act_Response_200:
      type: object
      properties: {}
      title: OVAC_upload_council_Act_Response_200
  securitySchemes:
    JwtToken:
      type: apiKey
      in: header
      name: x-jwt-token
      description: JWT token obtained from Login.

```

## SDK Code Examples

```python Upload council Act
import requests

url = "https://api.ovac.pre.councilbox.com/council/:councilId/act"

payload = {}
headers = {
    "x-jwt-token": "<apiKey>",
    "Content-Type": "application/json"
}

response = requests.post(url, json=payload, headers=headers)

print(response.json())
```

```javascript Upload council Act
const url = 'https://api.ovac.pre.councilbox.com/council/:councilId/act';
const options = {
  method: 'POST',
  headers: {'x-jwt-token': '<apiKey>', 'Content-Type': 'application/json'},
  body: '{}'
};

try {
  const response = await fetch(url, options);
  const data = await response.json();
  console.log(data);
} catch (error) {
  console.error(error);
}
```

```go Upload council Act
package main

import (
	"fmt"
	"strings"
	"net/http"
	"io"
)

func main() {

	url := "https://api.ovac.pre.councilbox.com/council/:councilId/act"

	payload := strings.NewReader("{}")

	req, _ := http.NewRequest("POST", url, payload)

	req.Header.Add("x-jwt-token", "<apiKey>")
	req.Header.Add("Content-Type", "application/json")

	res, _ := http.DefaultClient.Do(req)

	defer res.Body.Close()
	body, _ := io.ReadAll(res.Body)

	fmt.Println(res)
	fmt.Println(string(body))

}
```

```ruby Upload council Act
require 'uri'
require 'net/http'

url = URI("https://api.ovac.pre.councilbox.com/council/:councilId/act")

http = Net::HTTP.new(url.host, url.port)
http.use_ssl = true

request = Net::HTTP::Post.new(url)
request["x-jwt-token"] = '<apiKey>'
request["Content-Type"] = 'application/json'
request.body = "{}"

response = http.request(request)
puts response.read_body
```

```java Upload council Act
import com.mashape.unirest.http.HttpResponse;
import com.mashape.unirest.http.Unirest;

HttpResponse<String> response = Unirest.post("https://api.ovac.pre.councilbox.com/council/:councilId/act")
  .header("x-jwt-token", "<apiKey>")
  .header("Content-Type", "application/json")
  .body("{}")
  .asString();
```

```php Upload council Act
<?php
require_once('vendor/autoload.php');

$client = new \GuzzleHttp\Client();

$response = $client->request('POST', 'https://api.ovac.pre.councilbox.com/council/:councilId/act', [
  'body' => '{}',
  'headers' => [
    'Content-Type' => 'application/json',
    'x-jwt-token' => '<apiKey>',
  ],
]);

echo $response->getBody();
```

```csharp Upload council Act
using RestSharp;

var client = new RestClient("https://api.ovac.pre.councilbox.com/council/:councilId/act");
var request = new RestRequest(Method.POST);
request.AddHeader("x-jwt-token", "<apiKey>");
request.AddHeader("Content-Type", "application/json");
request.AddParameter("application/json", "{}", ParameterType.RequestBody);
IRestResponse response = client.Execute(request);
```

```swift Upload council Act
import Foundation

let headers = [
  "x-jwt-token": "<apiKey>",
  "Content-Type": "application/json"
]
let parameters = [] as [String : Any]

let postData = JSONSerialization.data(withJSONObject: parameters, options: [])

let request = NSMutableURLRequest(url: NSURL(string: "https://api.ovac.pre.councilbox.com/council/:councilId/act")! as URL,
                                        cachePolicy: .useProtocolCachePolicy,
                                    timeoutInterval: 10.0)
request.httpMethod = "POST"
request.allHTTPHeaderFields = headers
request.httpBody = postData as Data

let session = URLSession.shared
let dataTask = session.dataTask(with: request as URLRequest, completionHandler: { (data, response, error) -> Void in
  if (error != nil) {
    print(error as Any)
  } else {
    let httpResponse = response as? HTTPURLResponse
    print(httpResponse)
  }
})

dataTask.resume()
```