Ir para o conteúdo principal

[Gov.Doc] Manual Documental da API do Gov.Doc

Objetivo

O objetivo deste estudo é documentar as rotas da API do Sistema Gov.Doc. 

Introdução

O Gov.Doc é o sistema processador de texto do Governo do Estado de Rondônia e a sua API permite que outros sistemas (SOLAR, RegularizaJá, SID, etc) sejam capazes de criar, editar, arquivar documentos de maneira padronizada. Dessa forma, viu-se a necessidade de documentar as rotas para garantir e facilitar o acesso aos dados da API.

Bloco de Assinatura

O bloco de assinatura tem como sua principal funcionalidade permitir que o documento possa ser assinado por um ou mais usuários, assim como permite que o usuário assine documentos simultaneamente, além de outras funcionalidades.

       • Rotas do Bloco de Assinatura
Rota GET • /BlocoDeAssinatura/{idDoBloco}
Descrição Rota que busca o bloco de assinatura pelo ID.
Parâmetros idDoBloco : Guid → id do bloco
Request Body -
Response
{
  "id": "8db0864d-4472-4ac1-a82e-a71643bc412a",
  "titulo": "Bloco de assinatura",
  "documentos": [],
  "dataDeCriacao": "2021-09-08T11:01:31.7264862",
  "criador": null,
  "sistemaCriadorId": "ac4bec90-cbe0-4460-8c40-860e6ba5e60b",
  "cpfDoAssinante": "00000000000",
  "justificativaDeRecusa": null,
  "dataDeRecusa": "0001-01-01T00:00:00",
  "status": 2
}
Rota POST • /BlocoDeAssinatura/Criar
Descrição Rota para criar bloco de assinatura pelo CPF do usuário.
Parâmetros -
Request Body

• titulo : string → título do bloco de assinatura;

• documentosIds : List<Guid>→ lista com os Guids dos documentos inseridos no bloco;

• cpfDoCriadorDoBloco : string→ cpf do criador do bloco.

Response
{
  "id": "a84ed15c-d197-4042-9171-599f56b43e00",
  "titulo": "string",
  "documentos": [
    {
      "id": "e82014a4-958a-4a0f-8da7-b8742e609ec7",
      "titulo": "teste",
      "sequencial": 102,
      "modeloId": 1,
      "numeracao": "001.000102/2022-20",
      "cpfDoCriador": "00000000000",
      "dataDeCriacao": "2022-08-24T09:39:18.2583907",
      "tipoDeDocumento": "Parecer",
      "unidadeOrcamentariaId": 20,
      "departamento": "string",
      "historicoDeEdicoes": [],
      "compartilhamentos": [],
      "assinaturas": [],
      "historicos": [],
      "emMinuta": true,
      "blocoDeAssinaturaId": "a84ed15c-d197-4042-9171-599f56b43e00",
      "imagens": [],
      "excluido": false,
      "restrito": false,
      "sistemaOrigemId": "ac4bec90-cbe0-4460-8c40-860e6ba5e60b",
      "arquivado": false,
      "codigoCrc": null,
      "somenteLeitura": false
    }
  ],
  "dataDeCriacao": "2022-08-24T09:41:55.8515836-04:00",
  "criador": "01154865266",
  "sistemaCriadorId": "00000000-0000-0000-0000-000000000000",
  "cpfDoAssinante": null,
  "justificativaDeRecusa": null,
  "dataDeRecusa": "0001-01-01T00:00:00",
  "status": 1
}
Rota POST • /BlocoDeAssinatura/CriarPorSistema
Descrição Rota para criar bloco de assinatura pelo SISTEMA de origem.
Parâmetros -
Request Body

• titulo : string → título do bloco de assinatura;

• documentosIds : List<Guid>→ lista com os Guids dos documentos inseridos no bloco;

• sistemaDeOrigemId : Guid→ Guid do sistema que criará o bloco de assinaturas.

Response
{
  "id": "15dfaf88-850d-4672-bed8-994221c710bb",
  "titulo": "tsesset",
  "documentos": [
    {
      "id": "e82014a4-958a-4a0f-8da7-b8742e609ec7",
      "titulo": "teste",
      "sequencial": 102,
      "modeloId": 1,
      "numeracao": "001.000102/2022-20",
      "cpfDoCriador": "00000000000",
      "dataDeCriacao": "2022-08-24T09:39:18.2583907",
      "tipoDeDocumento": "Parecer",
      "unidadeOrcamentariaId": 20,
      "departamento": "string",
      "historicoDeEdicoes": [],
      "compartilhamentos": [],
      "assinaturas": [],
      "historicos": [],
      "emMinuta": true,
      "blocoDeAssinaturaId": "15dfaf88-850d-4672-bed8-994221c710bb",
      "imagens": [],
      "excluido": false,
      "restrito": false,
      "sistemaOrigemId": "ac4bec90-cbe0-4460-8c40-860e6ba5e60b",
      "arquivado": false,
      "codigoCrc": null,
      "somenteLeitura": false
    }
  ],
  "dataDeCriacao": "2022-08-24T10:38:00.6220451-04:00",
  "criador": null,
  "sistemaCriadorId": "ac4bec90-cbe0-4460-8c40-860e6ba5e60b",
  "cpfDoAssinante": null,
  "justificativaDeRecusa": null,
  "dataDeRecusa": "0001-01-01T00:00:00",
  "status": 1
}


Rota PUT • /BlocoDeAssinatura
Descrição Rota para editar o bloco de assinatura.
Parâmetros -
Request Body

• documentosIds : List<Guid>→ lista com os Guids dos documentos inseridos no bloco;

• cpfDoCriadorDoBloco : string→ CPF do criador do bloco de assinatura (somente o criador do bloco pode editar);

dataDeCriacao : dateTime → data de criação do bloco de assinaturas;

blocoId : Guid → Guid do bloco de assinaturas.

Response
{
  "id": "a84ed15c-d197-4042-9171-599f56b43e00",
  "titulo": "string",
  "documentos": [
    {
      "id": "e82014a4-958a-4a0f-8da7-b8742e609ec7",
      "titulo": "teste",
      "sequencial": 102,
      "modeloId": 1,
      "numeracao": "001.000102/2022-20",
      "cpfDoCriador": "00000000000",
      "dataDeCriacao": "2022-08-24T09:39:18.2583907",
      "tipoDeDocumento": "Parecer",
      "unidadeOrcamentariaId": 20,
      "departamento": "string",
      "historicoDeEdicoes": [],
      "compartilhamentos": [],
      "assinaturas": [],
      "historicos": [],
      "emMinuta": true,
      "blocoDeAssinaturaId": "a84ed15c-d197-4042-9171-599f56b43e00",
      "imagens": [],
      "excluido": false,
      "restrito": false,
      "sistemaOrigemId": "ac4bec90-cbe0-4460-8c40-860e6ba5e60b",
      "arquivado": false,
      "codigoCrc": null,
      "somenteLeitura": false
    }
  ],
  "dataDeCriacao": "2022-08-24T09:41:55.8515836",
  "criador": "00000000000",
  "sistemaCriadorId": "00000000-0000-0000-0000-000000000000",
  "cpfDoAssinante": null,
  "justificativaDeRecusa": null,
  "dataDeRecusa": "0001-01-01T00:00:00",
  "status": 1
}
Rota PUT • /BlocoDeAssinatura/AdicionarDocumento
Descrição Rota para adicionar documentos ao bloco de assinatura pelo CPF do usuário. 
Parâmetros -
Request Body

• documentosIds : List<Guid>→ lista com os Guids dos documentos que serão adicionados no bloco;

• cpf : string→ CPF do usuário que irá adicionar o documento (apenas o criador do bloco pode adicionar documento);

blocoId : Guid → Guid do bloco de assinaturas.

Response
{
  "status": "Ok",
  "message": "Documento adicionado ao Bloco com sucesso! "
}
Rota PUT • /BlocoDeAssinatura/AdicionarDocumentoPorSistema
Descrição Rota para adicionar documentos ao bloco de assinatura pelo SISTEMA de origem.
Parâmetros -
Request Body

• documentosIds : List<Guid>→ lista com os Guids dos documentos que serão adicionados no bloco;

• sistemaDeOrigemId : Guid Guid do sistema que irá adicionar o documento no bloco de assinaturas (somente o sistema de origem criador do bloco pode adicionar documento).

• blocoId : Guid → Guid do bloco de assinaturas.

Response
{
  "status": "Ok",
  "message": "Documento adicionado ao Bloco com sucesso! "
}
Rota PUT • /BlocoDeAssinatura/RemoverDocumento
Descrição Rota para remover documentos do bloco de assinatura pelo CPF do usuário.
Parâmetros -
Request Body

• documentosIds : List<Guid>→ lista com os Guids dos documentos que serão removidos do bloco;

• cpfDoUsuarioLogado : string→ CPF do usuário que irá remover o documento do bloco de assinaturas (apenas o criador do bloco pode excluir documento);

blocoId : Guid → Guid do bloco de assinaturas.

Response
{
  "status": "Ok",
  "message": "Documento removido ao Bloco com sucesso! "
}
Rota PUT • /BlocoDeAssinatura/RemoverDocumentoPorSistema
Descrição Rota para remover documentos do bloco de assinatura pelo SISTEMA de origem.
Parâmetros -
Request Body

• documentosIds : List<Guid>→ lista com os Guids dos documentos que serão removidos do bloco;

• sistemaDeOrigemId : Guid Guid do sistema que removerá o documento do bloco de assinaturas (somente o sistema de origem criador do bloco pode adicionar documento).

• blocoId : Guid → Guid do bloco de assinaturas. 

Response
{
  "status": "Ok",
  "message": "Documento removido ao Bloco com sucesso! "
}
Rota POST • /BlocoDeAssinatura/DisponibilizarParaAssinatura
Descrição Rota para disponibilizar os blocos para assinatura.
Parâmetros -
Request Body

• cpfDoCriadorDoBloco : string→ CPF do usuário que irá disponibilizar o bloco para assinatura;

• sistemaDeOrigemId : Guid Guid do sistema que irá disponibilizar o bloco para assinatura;

• idDoBloco : Guid → Guid do bloco de assinaturas;

• assinante : → nome e cpf do usuário que irá assinar; 

    • nome : string;

    • cpf : string.

OBS: deve ser informado ao menos o cpfDoCriadorDoBloco OU sistemaDeOrigemId que criou o bloco. 

Response
{
  "status": "Ok",
  "message": "Bloco de assinatura disponibilizado com sucesso! "
}
Rota POST • /BlocoDeAssinatura/AssinarBloco
Descrição Rota para assinar o bloco de assinaturas.
Parâmetros -
Request Body

• idDoBloco : Guid → Guid do bloco de assinaturas;

• cpf : string→ CPF do usuário que irá assinar o documento;

• senha : string → senha do usuário que irá assinar o documento;

• aceitouTermo : boolean → termo para assinar o documento.

Response
{
  "status": "Ok",
  "message": "Bloco de assinatura assinado com sucesso! "
}
Rota DELETE • /BlocoDeAssinatura/Excluir
Descrição Rota para excluir bloco de assinatura pelo CPF do usuário.
Parâmetros -
Request Body

• cpfDoCriadorDoBloco : string→ CPF do usuário que irá excluir o bloco de assinaturas (somente o criador do bloco pode excluir);

idDoBloco : Guid → Guid do bloco de assinaturas.

Response
{
  "status": "Ok",
  "message": "Bloco de assinatura excluido com sucesso! "
}
Rota DELETE • /BlocoDeAssinatura/ExcluirPorSistema
Descrição Rota para excluir bloco de assinatura pelo SISTEMA de origem.
Parâmetros -
Request Body

• sistemaDeOrigemId : Guid → Guid do sistema onde o bloco de assinatura será excluido (somente o sistema de origem criador do bloco pode excluir).

idDoBloco : Guid → Guid do bloco de assinaturas.

Response
{
  "status": "Ok",
  "message": "Bloco de assinatura excluido com sucesso! "
}
Rota POST • /BlocoDeAssinatura/Cancelar
Descrição Rota para cancelar bloco de assinatura pelo CPF do usuário.
Parâmetros -
Request Body

• cpf : string→ CPF do usuário que irá cancelar a disponibilização do bloco de assinaturas (somente o criador do bloco pode cancelar);

idDoBloco : Guid → Guid do bloco de assinaturas.

Response
{
  "status": "Ok",
  "message": "Bloco de assinatura cancelado com sucesso! "
}
Rota POST • /BlocoDeAssinatura/CancelarPorSistema
Descrição Rota para cancelar bloco de assinatura pelo CPF do usuário.
Parâmetros -
Request Body

• sistemaDeOrigemId : Guid → Guid que irá cancelar a disponibilização do bloco de assinatura (somente o sistema de origem criador do bloco pode cancelar).

idDoBloco : Guid → Guid do bloco de assinaturas.

Response
{
  "status": "Ok",
  "message": "Bloco de assinatura cancelado com sucesso! "
}

Documentos

       • Rotas dos Documentos
Rota GET • /Documentos/{id}
Descrição Rota que busca o documento pelo Guid.
Parâmetros id : Guid → Guid do documento.
Request Body -
Response
{
  "id": "d6baad9e-01a1-46bc-8bee-d5260c87e763",
  "tipoDeDocumento": "Parecer",
  "corpo": "testando123\n",
  "cabecalho": "<style>\n:root {\n    --ck-sample-base-spacing: 2em;\n    --ck-sample-color-white: #fff;\n    --ck-sample-color-green: #279863;\n    --ck-sample-color-blue: #1a9aef;\n    --ck-sample-container-width: 1285px;\n    --ck-sample-sidebar-width: 350px;\n    --ck-sample-editor-min-height: 400px;\n}\n\n/* --------- EDITOR STYLES  ---------------------------------------------------------------------------------------- */\n\n.editor__editable,\n/* Classic build. */\nmain .ck-editor[role='application'] .ck.ck-content,\n/* Decoupled document build. */\n.ck.editor__editable[role='textbox'],\n.ck.ck-editor__editable[role='textbox'],\n/* Inline & Balloon build. */\n.ck.editor[role='textbox'] {\n    width: 100%;\n    background: #fff;\n    font-size: 1em;\n    line-height: 1.6em;\n    min-height: var(--ck-sample-editor-min-height);\n    padding: 1.5em 2em;\n}\n\n/* Because of sidebar `position: relative`, Edge is overriding the outline of a focused editor. */\n.ck.ck-editor__editable {\n    background: #fff;\n    border: 1px solid hsl(0, 0%, 70%);\n    width: 100%;\n    position: relative;\n    z-index: 10;\n}\n\n.ck.ck-editor {\n    /* To enable toolbar wrapping. */\n    width: 100%;\n    overflow-x: hidden;\n}\n\n/* --------- DECOUPLED (DOCUMENT) BUILD. -----------*/\nbody[data-editor='DecoupledDocumentEditor'] .document-editor__toolbar {\n    width: 100%;\n}\n\nbody[ data-editor='DecoupledDocumentEditor'] .collaboration-demo__editable,\nbody[ data-editor='DecoupledDocumentEditor'] .row-editor .editor {\n    width: 21cm;\n    height: 100%;\n    min-height: 22.7cm;\n    padding: 1.75cm 1.5cm;\n    margin: 2.5rem;\n    margin-top: 0;\n    border: 1px hsl( 0, 0%, 82.7% ) solid;\n    background-color: var(--ck-sample-color-white);\n    box-shadow: 0 0 5px hsla( 0, 0%, 0%, .1 );\n    background-image: url(/images/marcaDaguaMinuta.jpg);\n}\n\nbody[ data-editor='DecoupledDocumentEditor'] .collaboration-demo__editable,\nbody[ data-editor='DecoupledDocumentEditor'] .row-editor .editorSemMinuta {\n    width: 21cm;\n    height: 100%;\n    min-height: 22.7cm;\n    padding: 1.75cm 1.5cm;\n    margin: 2.5rem;\n    margin-top: 0;\n    border: 1px hsl( 0, 0%, 82.7% ) solid;\n    background-color: var(--ck-sample-color-white);\n    box-shadow: 0 0 5px hsla( 0, 0%, 0%, .1 );\n}\n\nbody[ data-editor='DecoupledDocumentEditor'] .row-editor {\n    max-height: 550px;\n    display: flex;\n    position: relative;\n    justify-content: center;\n    overflow-y: auto;\n    background-color: #f8f9fb;\n    border: 1px solid hsl(0, 0%, 77%);\n}\n\nbody[data-editor='DecoupledDocumentEditor'] .sidebar {\n    background: transparent;\n    border: 0;\n    box-shadow: none;\n}\n\n/* --------- COMMENTS & TRACK CHANGES FEATURE ---------------------------------------------------------------------- */\n.sidebar {\n    padding: 0 15px;\n    position: relative;\n    min-width: var(--ck-sample-sidebar-width);\n    max-width: var(--ck-sample-sidebar-width);\n    font-size: 20px;\n    border: 1px solid hsl(0, 0%, 77%);\n    background: hsl(0, 0%, 98%);\n    border-left: 0;\n    overflow: hidden;\n    min-height: 100%;\n    flex-grow: 1;\n}\n\n    /* Do not inherit styles related to the editable editor content. See line 25.*/\n    .sidebar .ck-content[role='textbox'],\n    .ck.ck-annotation-wrapper .ck-content[role='textbox'] {\n        min-height: unset;\n        width: unset;\n        padding: 0;\n        background: transparent;\n    }\n\n    .sidebar.narrow {\n        min-width: 60px;\n        flex-grow: 0;\n    }\n\n    .sidebar.hidden {\n        display: none !important;\n    }\n\n#sidebar-display-toggle {\n    position: absolute;\n    z-index: 1;\n    width: 30px;\n    height: 30px;\n    text-align: center;\n    left: 15px;\n    top: 30px;\n    border: 0;\n    padding: 0;\n    color: hsl( 0, 0%, 50% );\n    transition: 250ms ease color;\n    background-color: transparent;\n}\n\n    #sidebar-display-toggle:hover {\n        color: hsl( 0, 0%, 30% );\n        cursor: pointer;\n    }\n\n    #sidebar-display-toggle:focus,\n    #sidebar-display-toggle:active {\n        outline: none;\n        border: 1px solid #a9d29d;\n    }\n\n    #sidebar-display-toggle svg {\n        fill: currentColor;\n    }\n\n/* --------- COLLABORATION FEATURES (USERS) ------------------------------------------------------------------------ */\n.row-presence {\n    width: 100%;\n    border: 1px solid hsl(0, 0%, 77%);\n    border-bottom: 0;\n    background: hsl(0, 0%, 98%);\n    padding: var(--ck-spacing-small);\n    /* Make `border-bottom` as `box-shadow` to not overlap with the editor border. */\n    box-shadow: 0 1px 0 0 hsl(0, 0%, 77%);\n    /* Make `z-index` bigger than `.editor` to properly display tooltips. */\n    z-index: 20;\n}\n\n.ck.ck-presence-list {\n    flex: 1;\n    padding: 1.25rem .75rem;\n}\n\n.presence .ck.ck-presence-list__counter {\n    order: 2;\n    margin-left: var(--ck-spacing-large)\n}\n\n/* --------- REAL TIME COLLABORATION FEATURES (SHARE TOPBAR CONTAINER) --------------------------------------------- */\n.collaboration-demo__row {\n    display: flex;\n    position: relative;\n    justify-content: center;\n    overflow-y: auto;\n    background-color: #f2f2f2;\n    border: 1px solid hsl(0, 0%, 77%);\n}\n\nbody[ data-editor='InlineEditor'] .collaboration-demo__row {\n    border: 0;\n}\n\n.collaboration-demo__container {\n    max-width: var(--ck-sample-container-width);\n    margin: 0 auto;\n    padding: 1.25rem;\n}\n\n.presence, .collaboration-demo__row {\n    transition: .2s opacity;\n}\n\n.collaboration-demo__topbar {\n    background: #fff;\n    border: 1px solid var(--ck-color-toolbar-border);\n    display: flex;\n    justify-content: space-between;\n    align-items: center;\n    border-bottom: 0;\n    border-radius: 4px 4px 0 0;\n}\n\n    .collaboration-demo__topbar .btn {\n        margin-right: 1em;\n        outline-offset: 2px;\n        outline-width: 2px;\n        background-color: var( --ck-sample-color-blue );\n    }\n\n        .collaboration-demo__topbar .btn:focus,\n        .collaboration-demo__topbar .btn:hover {\n            border-color: var( --ck-sample-color-blue );\n        }\n\n.collaboration-demo__share {\n    display: flex;\n    align-items: center;\n    padding: 1.25rem .75rem\n}\n\n.collaboration-demo__share-description p {\n    margin: 0;\n    font-weight: bold;\n    font-size: 0.9em;\n}\n\n.collaboration-demo__share input {\n    height: auto;\n    font-size: 0.9em;\n    min-width: 220px;\n    margin: 0 10px;\n    border-radius: 4px;\n    border: 1px solid var(--ck-color-toolbar-border)\n}\n\n.collaboration-demo__share button,\n.collaboration-demo__share input {\n    height: 40px;\n    padding: 5px 10px;\n}\n\n.collaboration-demo__share button {\n    position: relative;\n}\n\n    .collaboration-demo__share button:focus {\n        outline: none;\n    }\n\n    .collaboration-demo__share button[data-tooltip]::before,\n    .collaboration-demo__share button[data-tooltip]::after {\n        position: absolute;\n        visibility: hidden;\n        opacity: 0;\n        pointer-events: none;\n        transition: all .15s cubic-bezier(.5,1,.25,1);\n        z-index: 1;\n    }\n\n    .collaboration-demo__share button[data-tooltip]::before {\n        content: attr(data-tooltip);\n        padding: 5px 15px;\n        border-radius: 3px;\n        background: #111;\n        color: #fff;\n        text-align: center;\n        font-size: 11px;\n        top: 100%;\n        left: 50%;\n        margin-top: 5px;\n        transform: translateX(-50%);\n    }\n\n    .collaboration-demo__share button[data-tooltip]::after {\n        content: '';\n        border: 5px solid transparent;\n        width: 0;\n        font-size: 0;\n        line-height: 0;\n        top: 100%;\n        left: 50%;\n        transform: translateX(-50%);\n        border-bottom: 5px solid #111;\n        border-top: none;\n    }\n\n    .collaboration-demo__share button[data-tooltip]:hover:before,\n    .collaboration-demo__share button[data-tooltip]:hover:after {\n        visibility: visible;\n        opacity: 1;\n    }\n\n.collaboration-demo--ready {\n    overflow: visible;\n    height: auto;\n}\n\n    .collaboration-demo--ready .presence,\n    .collaboration-demo--ready .collaboration-demo__row {\n        opacity: 1;\n    }\n\n\n/* --------- RWD --------------------------------------------------------------------------------------------------- */\n\n.cabecalho {\n    width: 21cm;\n    background-color: #fff;\n    height: 6cm;\n    padding: 1px;\n    border: 1px hsl( 0, 0%, 82.7% ) solid;\n    box-shadow: 0 0 5px hsla( 0, 0%, 0%, .1 );\n    border-bottom: none;\n}\n\n.caixa {\n    margin-top: 5px;\n    text-align: center;\n    word-wrap: normal;\n    display: block;\n}\n\n.brasao {\n    max-width: 150px !important;\n    margin: 0 auto;\n}\n\n.caixa > h6 {\n    margin-top: 1em;\n    font-size: 13pt;\n    font-family: 'Gill Sans', 'Gill Sans MT', Calibri, 'Trebuchet MS', sans-serif;\n    text-align: center;\n    text-transform: uppercase;\n    word-wrap: normal;\n    font-weight: bold;\n}\n\n.caixa > strong {\n    font-size: 11pt;\n    font-family: 'Gill Sans', 'Gill Sans MT', Calibri, 'Trebuchet MS', sans-serif;\n}\n\n.rodape {\n    width: 21cm;\n    background-color: #fff;\n/*    white-space: nowrap;*/\n    margin-top: -41px;\n    position: relative;\n    height: 2cm;\n    font-size: .8em;\n    text-align: center;\n    color: rgba(0,0,0,.4);\n    border:  1px hsl( 0, 0%, 82.7% ) solid;\n    box-shadow: 0 0 5px hsla( 0, 0%, 0%, .1 );\n}\n\n.rodape P {\n    font-family: 'Gill Sans', 'Gill Sans MT', Calibri, 'Trebuchet MS', sans-serif;\n    font-size: 18px;\n    color: black;\n    text-align: right;\n    padding: 0.5cm;\n }\n\n</style>\n<link rel=\"stylesheet\" href=\"https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.4.1/css/bootstrap.min.css\">\n\n<div class=\"col-12\">\n    <div align=\"center\">\n        <img src=\"\" alt=\"Brasao Governo\">\n        <br />\n    </div>\n    <br />\n    <div align=\"center\">\n        <strong>Companhia de Mineração de Rondônia</strong>\n        <h5>Parecer 001.000103/2022-20</h5>\n    </div>\n</div>\n\n<div class=\"editorSemMinuta\" style=\"margin-left: 3.5rem\">\n    ",
  "rodape": "</div><div class='col-12'><hr style='margin: 1rem; '/><div align='right' style=margin: 1rem;'> <p> Documento criado em 24/08/2022 12:09:22 </p></div></div>",
  "departamento": "string",
  "unidadeOrcamentariaId": 20,
  "numeracao": "001.000103/2022-20",
  "cpfDoCriador": "00000000000",
  "assinaturas": [],
  "codigoVerificador": "AD8A4A72",
  "qrCode": null,
  "urlDaAplicacao": null,
  "restrito": false,
  "arquivado": false
}
Rota GET • /Documentos/Historico/{id}
Descrição Rota que consulta o histórico pelo Guid do documento.
Parâmetros id : Guid → Guid do documento.
Request Body -
Response
[
  {
    "descricao": "Editado",
    "usuario": "00000000000",
    "dateTime": "2022-08-24T12:09:22.728058"
  },
  {
    "descricao": "Criado no sistema REGULARIZAJA",
    "usuario": "00000000000",
    "dateTime": "2022-08-24T12:09:22.7280561"
  }
]
Rota POST • /Documentos
Descrição Rota para criar documento.
Parâmetros -
Request Body

• titulo : string → título do documento;

• conteudo : string → conteúdo do documento;

• unidadeOrcamentariaId : int → id da unidade orçamentária do usuário no E-Estado;

• departamento : string → departamento do usuário no E-estado;

• clientId : Guid → Guid do sistema de origem onde o documento será criado;

• tipoDeDocumento : string → tipo do documento (ata, parecer, memorando, etc)

• usuario → dados do usuário que irá criar o documento

    • nome : string;

    • cpf : string;

    • codigoDaUnidadeOrcamentaria : int;

    • email : string.

• restrito : boolean → definirá se o documento terá informações restritas ou não.

Response
{
  "id": "d6baad9e-01a1-46bc-8bee-d5260c87e763",
  "corpo": "testando123",
  "tipoDeDocumento": "Parecer",
  "departamento": "string",
  "unidadeOrcamentariaId": 20,
  "numeracao": "001.000103/2022-20",
  "cpfDoCriador": "00000000000"
}
Rota PUT • /Documentos
Descrição Rota para editar título e conteúdo do documento.
Parâmetros -
Request Body

• id : Guid → Guid do documento que será editado;

• titulo : string → título editado do documento;

• conteudo : string → conteúdo editado do documento;

• sistemaClientId : Guid → Guid do sistema de origem onde o documento será criado;

• usuario → dados do usuário que criará o documento

    • nome : string;

    • cpf : string;

    • codigoDaUnidadeOrcamentaria : int;

    • email : string.

Response
{
  "id": "d6baad9e-01a1-46bc-8bee-d5260c87e763",
  "conteudo": "lorem ipsum",
  "tipoDeDocumento": "Parecer",
  "departamento": "string",
  "unidadeOrcamentariaId": 20,
  "numeracao": "001.000103/2022-20",
  "cpfDoCriador": "00000000000",
  "assinaturas": []
}
Rota POST • /Documentos/PostDocumentoUsuarioExterno
Descrição Rota para criar documento com usuário externo.
Parâmetros -
Request Body

• titulo : string → título do documento;

• conteudo : string → conteúdo do documento;

• clientId : Guid → Guid do sistema de origem onde o documento será criado;

• tipoDeDocumento : string → tipo do documento (ata, parecer, memorando, etc)

• usuario → dados do usuário que irá criar o documento

    • nome : string;

    • cpf : string;

    • email : string.

• restrito : boolean → definirá se o documento terá informações restritas ou não.

Response
{
  "id": "47d5f0bd-f892-49e0-a64d-a0aa916366ec",
  "corpo": "<p>Este é um modelo de ata.</p>lorem ipsum",
  "tipoDeDocumento": "Ata",
  "departamento": null,
  "unidadeOrcamentariaId": null,
  "numeracao": "1019.000006/2022-",
  "cpfDoCriador": "00000000000"
}
Rota POST • /Documentos/Compartilhar
Descrição Rota para criar documento.
Parâmetros -
Request Body

• idDocumento : Guid → Guid do documento que será compartilhado;

• nome : string → nome do usuário ;

Response
Rota POST • /Documentos
Descrição Rota para criar documento.
Parâmetros -
Request Body
Response
Rota POST • /Documentos
Descrição Rota para criar documento.
Parâmetros -
Request Body
Response