~~ODT~~
Meus Memorandos
Este caso de uso possibilita o acompanhamento dos Memorandos Eletrônicos enviados ou autenticados pelo usuário. Os chefes, vice-chefes, gerentes e secretários também poderão visualizar os memorandos originários da sua unidade.
Todos os servidores ativos da instituição que possuem acesso ao módulo de protocolo podem acessar esta funcionalidade.
Descrição do Caso de Uso
Este caso de uso inicia quando o usuário acessa a opção: SIPAC → Protocolo → Consultas/Relatórios → Memorandos → Meus Memorandos.
O caso de uso inicia exibindo uma série de opções para filtrar as buscas pelos processos enviados.
Os seguintes filtros podem ser utilizados:
- Número/Ano: Tipo NUMÉRICO, formato: …9/AAAA.
- Ano: Tipo NUMÉRICO, formato: AAAA.
- Identificador: Tipo NUMÉRICO.
- Assunto (Título): Tipo TEXTO.
- Unidade de Origem: Tipo AUTOCOMPLETE, formato: DENOMINAÇÃO UNIDADE (CÓDIGO UNIDADE), entrada de dados: DENOMINAÇÃO ou CÓDIGO.
- Cadastrado por: Tipo AUTOCOMPLETE, formato: NOME USUÁRIO (LOGIN), entrada de dados: NOME ou LOGIN.
- Servidor de Assinatura: Tipo AUTOCOMPLETE, formato: NOME USUÁRIO (LOGIN), entrada de dados: NOME ou LOGIN.
- Unidade de Destino:Tipo AUTOCOMPLETE, formato: DENOMINAÇÃO UNIDADE (CÓDIGO UNIDADE), entrada de dados: DENOMINAÇÃO ou CÓDIGO.
- Tipo: Tipo TEXTO. São exibidas as opções de: Todos, Memorando Eletrônico ou Memorando Circular.
- Data de Cadastro: Formato - DD/MM/AAAA a DD/MM/AAAA. Tipo - DATA.
- Situação: Tipo - TEXTO. São exibidas as opções:
- EM EDIÇÃO;
- AGUARD. AUTEN;
- AUTENTICADO;
- ENVIADO;
- CANCELADO.
- Todos os Memorandos: Tipo LÓGICO.
São exibidas as seguintes informações sobre os memorandos consutlados:
- Documento: Tipo TEXTO, formato: …9/AAAA - SIGLA UNIDADE.
- Identificador: Tipo NUMÉRICO.
- Enviado Em: Tipo DATA.
- Assunto: Tipo TEXTO.
- Situação: Tipo - TEXT.
- Leituras: Tipo - NUMÉRICO.
- Destino: Tipo TEXTO, formato: UNIDADE (CÓDIGO DA UNIDADE) ou SERVIDOR (MATRÍCULA DO SERVIDOR).
E para cada memorando as seguintes opções:
-
- Ao ser selecionada, essa opção permite a leitura do memorando pelo usuário.
-
- Ao ser selecionada, são disponibilizadas informações detalhadas acerca desse documento.
-
- Ao ser selecionada, é exibida uma lista com todos os usuários que leram o memorando em questão.
- Exportar Memorando para .doc:
- Exporta o memorando para um arquivo .doc.
Principais Regras de Negócio
- RN01 - Serão exibidos apenas o memorandos:
- Cadastrados pelo usuário
- Assinados pelo usuário, ou seja, autenticados por eles.
- Encaminhados pelo usuário
- Originários da unidade de responsabilidade do usuário, ou seja, caso o usuário seja chefe, vice-chefe, gerente ou secretário da unidade de origem do memorando.
Resoluções/Legislações Associadas
Não se Aplica.
Classes Persistentes e Tabelas Envolvidas
Classe | Tabela |
---|---|
br.ufrn.sipac.protocolo.dominio.Documento | administrativo.protocolo.documento |
br.ufrn.sipac.protocolo.dominio.TipoDocumentoProtocolo | administrativo.protocolo.tipoDocumento |
br.ufrn.sipac.protocolo.dominio.LeituraDocumento | administrativo.protocolo.leitura_documento |
br.ufrn.sipac.protocolo.dominio.AutenticadorDocumento | administrativo.protocolo.autenticador_documento |
Plano de Teste
Sistema: SIPAC
Módulo: Protocolo
Link(s): Protocolo → Consultas/Relatórios → Memorandos → Meus Memorandos
Usuário: marcilia, jbb, paulinho.
Papel que usuário deve ter: Sem checagem de papéis.
Cenários de Teste
- Verificar se os memorandos nas quatro situações abaixo, seguindo as regras de negócio, estão sendo mostrados nesse caso de uso:
- EM EDIÇÃO
- AGUAR. AUTEN.
- AUTENTICADO
- ENVIADO
Dados para o Teste
- Para obter o identificador de uma unidade podemos usar a seguinte consulta:
SELECT u.id_unidade, u.sigla, u.codigo_unidade, u.nome FROM comum.unidade u WHERE 1 = 1 AND u.id_unidade = -- (Opcional) AND u.sigla = '' -- (Opcional) AND u.codigo_unidade = -- (Opcional) AND u.nome LIKE '' -- (Opcional)
- A partir do identificador da unidade podemos adquirir os dados do servidor, usuário e pessoa, responsáveis da unidade, com a seguinte consulta:
SELECT r.id_servidor, us.id_usuario, us.login, p.id_pessoa, p.nome, r.id_unidade, u.nome FROM comum.responsavel_unidade r INNER JOIN rh.servidor s ON s.id_servidor = r.id_servidor INNER JOIN comum.pessoa p ON p.id_pessoa = s.id_pessoa INNER JOIN comum.unidade u ON u.id_unidade = r.id_unidade INNER JOIN comum.usuario us ON us.id_pessoa = p.id_pessoa WHERE r.id_unidade = <IDENTIFICADOR DA UNIDADE> AND (r.data_fim >= CURRENT_TIMESTAMP OR r.data_fim IS NULL) AND r.nivel_responsabilidade IN ( 'C','V','G','S' )
Com os dados dos identificadores do usuário e do servidor, podemos consultar os dados do memorando a partir do seguintes códigos:
- Usando como base a consulta:
SELECT DISTINCT doc.iddocumento, doc.identificacao, doc.ano, unidade.sigla FROM protocolo.documento doc INNER JOIN protocolo.autenticador_documento aut ON doc.iddocumento = aut.id_documento INNER JOIN comum.unidade unidade ON doc.idunidade = unidade.id_unidade LEFT JOIN (SELECT COUNT(*) > 0 AS encaminhado, iddocumento, idusuarioorigem FROM protocolo.movimento_documento m WHERE encaminhamento = TRUE AND idusuarioorigem = <IDENTIFICADOR DO USUÁRIO> GROUP BY iddocumento, idusuarioorigem) AS movimento ON (movimento.iddocumento = doc.iddocumento) LEFT JOIN (SELECT COUNT(r.id_unidade) > 0 AS responsavel, r.id_unidade FROM comum.responsavel_unidade r WHERE r.id_servidor = <IDENTIFICADOR DO SERVIDOR> AND (r.data_fim >= CURRENT_TIMESTAMP OR r.data_fim IS NULL) AND r.nivel_responsabilidade IN ( 'C','V','G','S' ) GROUP BY r.id_unidade) AS usuario_unidade ON (usuario_unidade.id_unidade = doc.idunidade) WHERE doc.idtipodocumento IN ( 976,980 ) AND doc.status IN ( 1,2,4,5,6,7,8,9 ) AND doc.iddocumento_principal IS NULL ORDER BY doc.iddocumento DESC
Usar:
- Para TODOS os memorandos que poderão ser vistos pelo usuário:
AND ( doc.id_usuario = <IDENTIFICADOR DO USUÁRIO> OR (aut.id_autenticador = <IDENTIFICADOR DO SERVIDOR> AND aut.id_registro_inativacao IS NULL) OR movimento.encaminhado = TRUE OR usuario_unidade.responsavel = TRUE)
- Apenas para os memorandos cadastrados pelo usuário:
AND doc.id_usuario = <IDENTIFICADOR DO USUÁRIO>
- Apenas para os memorandos autenticados pelo usuário:
AND aut.id_autenticador = <IDENTIFICADOR DO SERVIDOR> AND aut.id_registro_inativacao IS NULL
- Apenas para os memorandos encaminhados pelo usuário:
AND movimento.encaminhado = TRUE
- Para restringir apenas aos memorandos vistos pelos responsáveis, caso não seja quem cadastrou/autenticou/encaminhou, podemos usar a seguinte cláusula:
AND (doc.id_usuario != <IDENTIFICADOR DO USUÁRIO> --Não sendo o usuário que cadastrou AND (aut.id_autenticador != <IDENTIFICADOR DO SERVIDOR> OR aut.id_registro_inativacao IS NOT NULL) --Nem um dos autenticadores do memorando AND (movimento.encaminhado IS NULL OR movimento.encaminhado = FALSE) --Nem o usuário que o encaminhou AND (usuario_unidade.responsavel = TRUE) --E sendo responsável pela unidade ) IS TRUE -- (FALSE para obter apenas os cadastrados/autenticados/encaminhados)