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

# Enviar aplicação

> Enviar uma aplicação para a Square Cloud. Possui limite de taxa de 1 requisição a cada 3 segundos.

<ParamField header="Authorization" type="string" placeholder="Chave da API" required>
  A chave da API para sua conta. Você pode encontrá-la nas [configurações da conta](https://squarecloud.app/pt-br/account/security).
</ParamField>

### Parâmetros

<ParamField body="file" type="file" placeholder="application.zip" required>
  A aplicação a ser enviada deve estar compactada em um arquivo zip (.zip) e o Content Type deve ser multipart/form-data.
</ParamField>

### Resposta

<ResponseField name="status" type="string">
  Indica se a chamada foi bem-sucedida. `success` se bem-sucedida, `error` se não.
</ResponseField>

<ResponseField name="code" type="string">
  O código de status da resposta.
</ResponseField>

<ResponseField name="response" type="object">
  O conteúdo da resposta.

  <Expandable title="Alternar objeto">
    <ResponseField name="id" type="string">
      O ID da aplicação enviada.
    </ResponseField>

    <ResponseField name="name" type="string">
      O nome da aplicação enviada.
    </ResponseField>

    <ResponseField name="description" type="string">
      A descrição da aplicação enviada.
    </ResponseField>

    <ResponseField name="domain" type="string">
      O subdomínio da aplicação enviada (null se não aplicável).
    </ResponseField>

    <ResponseField name="ram" type="number">
      O uso de RAM da aplicação enviada em MB.
    </ResponseField>

    <ResponseField name="cpu" type="number">
      O uso de CPU da aplicação enviada.
    </ResponseField>

    <ResponseField name="language" type="object">
      <Expandable title="Alternar objeto">
        <ResponseField name="name" type="string">
          A linguagem de programação da aplicação enviada.
        </ResponseField>

        <ResponseField name="version" type="string">
          A versão recomendada da linguagem de programação.
        </ResponseField>
      </Expandable>
    </ResponseField>

    <ResponseField name="cluster" type="string">
      O cluster onde a aplicação está hospedada na nuvem.
    </ResponseField>
  </Expandable>
</ResponseField>

<RequestExample>
  ```bash cURL theme={null}
  curl --request POST \
    --url https://api.squarecloud.app/v2/apps \
    --header 'Authorization: SUA_API_KEY' \
    --form 'file=@./application.zip'
  ```

  ```javascript JavaScript theme={null}
  import fs from 'node:fs';

  const form = new FormData();
  form.append('file', new Blob([fs.readFileSync('./application.zip')]), 'application.zip');

  const response = await fetch('https://api.squarecloud.app/v2/apps', {
    method: 'POST',
    headers: { Authorization: 'SUA_API_KEY' },
    body: form,
  });
  ```

  ```python Python theme={null}
  import requests

  with open('application.zip', 'rb') as f:
      response = requests.post(
          'https://api.squarecloud.app/v2/apps',
          headers={'Authorization': 'SUA_API_KEY'},
          files={'file': ('application.zip', f, 'application/zip')},
      )
  ```
</RequestExample>

<ResponseExample>
  ```json theme={null}
  {
      "status": "success",
      "code": "SUCCESS",
      "response": {
          "id": "945f574e6cc14ea6818f91d7d56de101",
          "name": "Estrelinha Legal",
          "description": "Nossa, fui enviada na velocidade da luz! ✨",
          "domain": null,
          "ram": 1024,
          "cpu": 6,
          "language": {
              "name": "JavaScript",
              "version": "recommended"
          }
      }
  }
  ```
</ResponseExample>
