Ir para o conteúdo principal

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

Data de elaboração 23/08/22
Responsável pelo estudo

Gabriel Santi Binda

Raissa de Sousa Stolduski
Taillon Miguel Gonçalves

Vinicius da Rosa Pereira
Ádelle Camarão Monteiro

Equipe do estudo Tambakiss
Alvo Gov.Doc API
Origem Casos de novas implementações
Objetivo Documentar as rotas da API do Sistema Gov.Doc. 
Documentação correlata (opcional)

 

Observações

1. 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, assinar, arquivar documentos de maneira padronizada, entre outras funcionalidades. 

2.Desenvolvimento

2.1 Bloco de assinatura

Rota GET • /BlocoDeAssinatura/{idDoBloco}
Descrição Rota que busca os dados do bloco de assinatura pelo ID.
Parâmetros idDoBloco : Guid → id do bloco de assinatura.
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! "
}

2.2 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 compartilhar documento pelo CPF do usuário logado.
Parâmetros -
Request Body

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

• nome : string → nome do usuário que o documento será compartilhado;

• cpf : string → cpf do usuário que o documento será compartilhado;

• permissao : int → permissão do usuário que será compartilhado o documento (visualizar ou editar);

• filtro : string → filtro da view que filtra pelo nome ou cpf;

• secretariaId : int → secretaria do usuário que o documento será compartilhado no E-Estado;

• usuarioLogado → dados do usuário que irá compartilhar o documento

    • nome : string;

    • cpf : string;

• sistemaClientId : Guid → Guid do sistema de origem.

Response
{
  "status": "Ok",
  "message": "Documento compartilhado com sucesso! "
}
Rota POST • /Documentos/CompartilharPorSistema
Descrição Rota para compartilhar documento pelo SISTEMA de origem. 
Parâmetros -
Request Body

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

• sistemaClientId : Guid → Guid do sistema de origem;

• permissao : int → permissão do usuário que será compartilhado o documento (visualizar ou editar);

• cpfACompartiilhar : string → Cpf do usuário que o documento será compartilhado.

Response
{
  "status": "Ok",
  "message": "Documento compartilhado com sucesso! "
}
Rota POST • /Documentos/Arquivar
Descrição Rota para arquivar documento.
Parâmetros -
Request Body

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

• usuarioLogado → dados do usuário que irá arquivar o documento

    • nome : string;

    • cpf : string;

• sistemaClientId : Guid → Guid do sistema de origem.

Response
{
  "status": "Ok",
  "message": "Documento arquivado com sucesso! "
}
Rota POST • /Documentos/Assinar
Descrição Rota para assinar documento.
Parâmetros -
Request Body

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

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

• senha : string → senha do usuário cadastrada no Sauron;

• aceitouTermo : boolean → termo que o usuário deve aceitar.

Response
{
  "status": "Ok",
  "message": "Documento assinado com sucesso! "
}
Rota POST • /Documentos/Revogar
Descrição Rota para revogar documento.
Parâmetros -
Request Body

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

• cpf : string → Cpf do usuário que irá revogar o documento;

• senha : string → senha do usuário cadastrado no Sauron.

Response  
{
  "status": "Ok",
  "message": "Assinatura(s) do documento revogada(s) com sucesso! "
}
Rota POST • /Documentos/Autenticidade
Descrição Rota para verificar a autenticidade do documento.
Parâmetros -
Request Body

• numeracao : string → númeração do documento (gerado ao criar o documento);

• codigoVerificador : string → código que verifica a autenticidade do documento (gerado ao assinar o documento).

Response
{
  "valido": true,
  "mensagem": "Documento é Válido e Autêntico. Verificação feita dia 25 de agosto de 2022 às 09:03:12"
}
Rota GET • /Documentos/Pdf/{documentoId}
Descrição Rota para renderizar documento em PDF pelo id do documento.
Parâmetros documentoId : Guid →  Guid do documento que será renderizado; 
Request Body

-

Response Documento em pdf.
3. Conclusão

Concluímos que após analisar todas as funcionalidades do sistema Gov Doc Api o mesmo está apto para ser utilizado em todos por os sistemas do Governo de Rondônia.