UploadFile

O processo para envio de arquivos consiste em 3 passos:

1) uploadFile ou uploadFiles

Devemos usar a primitiva uploadFile para receber um link da AWS com o endereço de upload do arquivo ou a primitiva uploadfiles ser for mais que um arquivo.

Esta primitiva vai criar uma senha (areaSecret) para cada conjunto de domínio + serviço, uma espécie de estrutura de diretório único e protegido para o arquivo que será enviado. IMPORTANTE: Esta estrutura e a senha somente serão criados caso ainda não existam. Uma vez definido o areaSecret não poderá ser alterado.

Payload de entrada
    {
        //Uma string com o nome do domínio
        "domainName": "{string}",
      
        //Nome do serviço que esta enviando o arquivo
        "serviceName": "{string}",
      
        //Nome da pasta ou área de armazenamento
        "areaSecret": "{string}",
      
        //Identificador do arquivo no serviço onde é utilizado
        "targetObjectId": "{string}"
        
        //Nome do arquivo
        "fileName": "{string}"
    }
Request
curl --location --request POST "https://api.senior.com.br/platform/blob_service/uploadFile" --header "Content-Type: application/json" --header "client_id: {client_id}" --header "Accept: application/json" --header "Authorization: Bearer {token}" --data-raw "{ 'domainName': '{string}', 'serviceName': '{string}', 'areaSecret': '{string}', 'targetObjectId': '{string}', 'fileName': '{string}' }"
Response

200 Ok

    {
        "domainName": "{string}",
        "serviceName": "{string}",
        "targetObjectId": "{string}",
        "version": "{string}",
        "token": "{string}",
        "location": {
            "protocol": "S3",
            "uri": "{string}"
        },
        "fileName": "{string}"
    }    

403 Permissão negada

401 Unauthorized

    {
        "error_description": "The access token is invalid or has expired",
        "error": "invalid_token"
    }
2) Fazer efetivamente o upload dos dados

Para fazer o upload dos dados faça um put utilizando a uri fornecida pela resposta da primitiva uploadFile. Na resposta da primitiva uploadFile, temos informações que serão usadas no terceiro passo que é o commit. OBS: O Link devolvido na propriedade uri do primeiro passo tem um tempo de vida de 15 minutos. A partir deste tempo não será mais possível utilizar o link para fazer o envio. Será necessário repetir o primeiro passo, nestes casos.

Caso aconteça um erro semelhante:

<?xml version="1.0" encoding="UTF-8"?>
<Error><Code>AccessDenied</Code></Error>

Verifique se o "targetObjectId" está nulo ou vazio (""), conforme exemplo abaixo:

    {​​​​​​​​
        "domainName":"andre",
        "serviceName":"cliente",
        "areaSecret":"teste",
        "targetObjectId":"",
        "fileName":"andre",
        "version":"andre-teste",
        "token":"andre",
        "requirements":[
            "Open"
        ],
        "supportedProtocols":[
            "File"
        ],
        "style":" ",
        "ttl":1
    }​​​​​​​​

Altere o valor e realize os passos novamente, desde o POST, isso deverá corrigir o problema de AccessDenied.

3) Commit - commitFile

Todos os dados enviados estão em uma área temporária, é necessário fazer o commit para finalmente os dados serem movidos para uma área "permanente". Caso não seja feito o commit os dados serão apagados automaticamente. É neste passo que vamos receber a url para futuramente fazermos o download dos dados.

OBS: Todos os dados que serão utilizados no commit podem ser obtidos na resposta do primeiro passo, da primitiva uploadFiles.

Payload de entrada
    {
        //Uma string com o nome do domínio
        "domainName": "{string}",
      
        //Nome do serviço que esta enviando o arquivo
        "serviceName": "{string}",
      
        //Nome da pasta ou área de armazenamento
        "areaSecret": "{string}",
      
        //Identificador único do arquivo
        "targetObject": "{string}",
        
        //Nome do arquivo"
        "fileName": "{string}",
      
        //Esta propriedade foi devolvida na resposta da primitiva uploadFile
        "version": "{string}",
      
        //Se a cópia de trabalho deve ser liberada automaticamente após o commit.
        "release": boolean
      }
Request
curl --location --request POST "https://api.senior.com.br/platform/blob_service/commitFile" --header "Content-Type: application/json" --header "Accept: application/json" --header "Authorization: Bearer {token}" --data-raw "{ 'domainName': '{string}', 'serviceName': '{string}', 'areaSecret': '{string}', 'targetObjectId': '{string}', 'fileName': '{string}', 'version': '{string}', 'release': boolean }"