Skip to content
This repository has been archived by the owner on Mar 24, 2021. It is now read-only.

Latest commit

 

History

History
executable file
·
120 lines (94 loc) · 3.03 KB

README.md

File metadata and controls

executable file
·
120 lines (94 loc) · 3.03 KB

OurMeeting

O Projeto

O projeto foi criado a partir de um teste, que consistia em criar um sistema de agendamento de salas de reuniões, permitindo também o cadastro de usuários, setores e salas. O desenvolvimento deste projeto, desde planejamento e levantamento de requisitos, até os testes de docuemntação final, levou um pouco menos de 20h.

Como Instalar/Configurar

  1. Clone o respositório e acesse a pasta
git clone https://github.com/PauloAK/OurMeeting.git
  1. Instale as dependências do composer
composer install
  1. Instale as dependências do NPM
npm install
  1. Criar o arquivo de ambiente (.env)
cp .env.example .env
  1. Defina as permissões das pastas
sudo chown -R www-data .
sudo chmod -R ug+rwx storage bootstrap/cache
  1. Gerar a Chave de Criptografia
php artisan key:generate
  1. Crie um novo banco de dados MySQL/PostgreSQL para a aplicação.

  2. Edite o arquivo .env e defina os dados de acesso ao banco de dados que acabou de criar

DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_PORT=3306
DB_DATABASE=DB_NAME
DB_USERNAME=USERNAME
DB_PASSWORD=PASSWORD
  1. Crie a estrutura de tabelas e carga de dados inicial
php artisan migrate --seed
  1. Inicia o servidor integrado o Laravel
php artisan serve
  1. Acesse o endereço que é exibido em seu navegador, geralmente é: 127.0.0.1:8000

Especificações

  • Para agendar, deve estar autenticado no sistema
  • Um agendamento não pode ser superior a 1h;
  • O local pode haver mais de uma sala de reunião disponível;
  • O usuário, poderá reservar apenas 1 sala de reunião por dia;
  • O usuário poderá reservar apenas 1 horário por sala de reunião;
  • Deve ser possível cadastrar setores;
  • Deve ser possível cadastrar usuários;

Tecnologias

Front-End

Back-End

  • Laravel 5.8
  • PHP 7.2
  • MySQL

Recursos e Conceitos

  • [ADMIN] CRUD - Usuários
    • Somente ADMINs tem acesso à está área
    • Possibilidade de alteração de senha mediante validação.
  • [ADMIN] CRUD - Setores
    • Somente ADMINs tem acesso à está área
  • [ADMIN] CRUD - Salas
    • Somente ADMINs tem acesso à está área
  • Reuniões
    • Podem ter no máximo 60 minutos
    • Um usuário só pode marcar uma reunião por dia
    • Uma sala só pode ter uma reunião ao mesmo tempo
    • Usuário somente pode editar as suas reuniões, com exceção do ADMIN, que tem acesso à todas.

Diagrama Entidade Relacionamento

Requisitos

Funcionais

  • Manter Usuário.
  • Manter Setor.
  • Manter Reunião.

Não Funcionais

  • O sistema deverá utilizar banco de dados dados MySQL.
  • O sistema deverá ser responsivo para a utilização em mobile.
  • As senhas dos usuários devem ser armazenadas utilizando o hash bcrypt do Laravel