Instalação diretamente no Linux (não recomendado)
Instalação Manual Ubuntu Ubuntu 18.04 e 20.04
Softwares Requeridos
Atualize os repositórios de referência de sua máquina:
ubuntu@server$ sudo apt-get update -yubuntu@server$ sudo apt-get upgrade -yInstale as dependências diversas:
ubuntu@server$ sudo apt-get install git curl npm ruby ruby-dev -yAtualizar referências para a versão de ruby:
ubuntu@server$ sudo update-alternatives --install /usr/bin/ruby ruby /usr/bin/ruby2.x 10ubuntu@server$ sudo update-alternatives --install /usr/bin/gem gem /usr/bin/gem2.x 10Nota: O comando update-alternatives --install precisa das informações
Instale a versão stable mais nova do nodejs:
ubuntu@server$ sudo curl -sL https://deb.nodesource.com/setup_12.x -o nodesource_setup.shubuntu@server$ sudo bash nodesource_setup.shubuntu@server$ sudo apt install nodejs -yVerificando se foi instalada a versão mais recente do NodeJS e do NPM:
Ubuntu18.04
ubuntu@server$ nodejs -v 
~ v12.18.3ubuntu@server$ npm -v
~ 6.14.6Ubuntu20.04
ubuntu@server$ node -v 
~ v12.18.3ubuntu@server$ npm -v
~ 6.14.6Instale o postgresql e postgis:
Ubuntu18.04
ubuntu@server$ sudo apt-get install postgresql-10 postgresql-contrib postgis postgresql-10-postgis-2.4 postgresql-10-postgis-2.4-scripts -yUbuntu20.04
ubuntu@server$ sudo apt-get install postgresql-12 postgresql-contrib postgis postgresql-12-postgis-3 postgresql-12-postgis-3-scripts -yInstale o php7.2, php7.2-fpm e extensões do php utilizadas no sistema
Ubuntu20.04
ubuntu@server$ sudo add-apt-repository ppa:ondrej/php
ubuntu@server$ sudo apt-get updateUbuntu20.04 e Ubuntu18.04
ubuntu@server$ sudo apt-get install php7.2 php7.2-mbstring php7.2-xml php7.2-gd php7.2-cli php7.2-json php7.2-curl php7.2-pgsql php-apcu php7.2-fpm imagemagick libmagickcore-dev libmagickwand-dev php7.2-imagick -yInstale o nginx
ubuntu@server$ sudo apt-get install nginxInstale o gerenciador de dependências do PHP Composer
ubuntu@server$ curl -sS https://getcomposer.org/installer | phpubuntu@server$ sudo mv composer.phar /usr/local/bin/composer.pharTambém é importante ter o pacote zip instalado no seu servidor. Ele é usado para gerar o pacote com os anexos enviados nas inscrições. Caso ainda não tenha:
ubuntu@server$ sudo apt-get install zip unzip -yNo Ubuntu o executável do NodeJS se chama nodejs, porém para o correto funcionamento das bibliotecas utilizadas, o executável deve se chamar node. Para isto criamos um link simbólico com o comando abaixo:
Ubuntu18.04
ubuntu@server$ sudo update-alternatives --install /usr/bin/node node /usr/bin/nodejs 10Ubuntu20.04 e Ubuntu18.04
Instalando os minificadores de código Javascript e CSS: uglify-js, uglifycss e autoprefixer:
ubuntu@server$ sudo npm install -g terser uglifycss autoprefixerInstalando o SASS, utilizado para compilar os arquivos CSS:
ubuntu@server$ sudo gem install sass -v 3.4.22Clonando o Repositório
Primeiro vamos criar o usuário que rodará a aplicação e que será proprietário do banco de dados, definindo sua home para /srv e colocando-o no grupo www-data:
ubuntu@server$ sudo useradd -G www-data -d /srv/mapas -m mapasVamos clonar o repositório usando o usuário criando, então precisamos primeiro "logar" com este usuário:
ubuntu@server$ sudo su - mapas
mapas@server$ git clone https://github.com/hacklabr/mapasculturais.gitAgora vamos colocar o repositório na branch master. Caso queira você poderá ver todas as versões dosponíveis aqui
mapas@server$ cd mapasculturais
mapas@server$ git checkout master
mapas@server$ git pull origin masterAgora vamos instalar as dependências de PHP utilizando o Composer.
mapas@server$ cd ~/mapasculturais/src/protected/
mapas@server$ composer.phar installBanco de Dados
Vamos voltar ao usuário root para criar o banco de dados.
mapas@server$ exit
ubntu@server$Primeiro vamos criar o usuário no banco de dados com o mesmo nome do usuário do sistema
ubuntu@server$ sudo -u postgres psql -c "CREATE USER mapas"Agora vamos criar a base de dados para a aplicação com o mesmo nome do usuário
ubuntu@server$ sudo -u postgres createdb --owner mapas mapasCriar as extensões necessárias no banco
ubuntu@server$ sudo -u postgres psql -d mapas -c "CREATE EXTENSION postgis;"
ubuntu@server$ sudo -u postgres psql -d mapas -c "CREATE EXTENSION unaccent;"Volte a "logar" com o usuário criado e importar o esquema da base de dados
ubuntu@server$ sudo su - mapas
mapas@server$ psql -f mapasculturais/db/schema.sqlConfigurações de instalação
Primeiro crie um arquivo de configuração copiando o arquivo de template de configuração. Este arquivo está preparado para funcionar com este guia, utilizando o método de autenticação Fake.
mapas@server$ cp mapasculturais/src/protected/application/conf/config.template.php mapasculturais/src/protected/application/conf/config.phpCriando diretórios de log, files e estilo
$ exit
ubuntu@server$ sudo mkdir /var/log/mapasculturais
ubuntu@server$ sudo chown mapas:www-data /var/log/mapasculturaisCom o usuário criado, crie a pasta para os assets, para os uploads e para os uploads privados (arquivos protegidos, como anexos de inscrições em oportunidades):
ubuntu@server$ sudo su - mapas
mapas@server$ mkdir mapasculturais/src/assets
mapas@server$ mkdir mapasculturais/src/files
mapas@server$ mkdir mapasculturais/private-filesConfiguração do nginx
Precisamos criar o virtual host do nginx para a aplicação. Para isto crie, como root, o arquivo /etc/nginx/sites-available/mapas.conf
mapas@server$ exit
ubuntu@server$ sudo vi /etc/nginx/sites-available/mapas.confEu costumo utilizar o vi, mas você pode usar o vim, nano e afins para fazer a edição deste arquivo
Coloque o conteúdo abaixo dentro do arquivo /etc/nginx/sites-available/mapas.conf criado anteriormente: Muita atenção aqui, pois você precisará subistituir todos os "meu.dominio.gov.br" pelo seu domínio ou IP fixo dependendo de qual for o seu caso.
server {
  set $site_name meu.dominio.gov.br;
  listen *:80;
  server_name meu.dominio.gov.br;
  access_log   /var/log/mapasculturais/nginx.access.log;
  error_log    /var/log/mapasculturais/nginx.error.log;
  index index.php;
  root  /srv/mapas/mapasculturais/src/;
  location / {
    try_files $uri $uri/ /index.php?$args;
  }
  
  location ~ /files/.*\.php$ {
    return 80;
  }
  
  location ~* \.(js|css|png|jpg|jpeg|gif|ico|woff)$ {
          expires 1w;
          log_not_found off;
  }
  location ~ \.php$ {
    try_files $uri =404;
    include fastcgi_params;
    fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
    fastcgi_pass unix:/var/run/php/php7.2-fpm-$site_name.sock;
    client_max_body_size 0;
  }
  charset utf-8;
}
server {
  listen *:80;
  server_name www.meu.dominio.gov.br;
  return 301 $scheme://meu.dominio.gov.br$request_uri;
}Feita a alteração no arquivo, salve!
Crie o link para habilitar o virtual host
ubuntu@server$ sudo ln -s /etc/nginx/sites-available/mapas.conf /etc/nginx/sites-enabled/mapas.confRemover o arquivo default da pasta /etc/nginx/sites-available/ e /etc/nginx/sites-enabled/
ubuntu@server$ sudo rm /etc/nginx/sites-available/default
ubuntu@server$ sudo rm /etc/nginx/sites-enabled/defaultConfigurações pool do php7.2-fpm: Crie o arquivo /etc/php/7.2/fpm/pool.d/mapas.conf. Muita atenção na alteração da linha listen = /var/run/php/php7.2-fpm-meu.dominio.gov.br.sock pois o nome do arquivo .sock precisará ser extamente como foi configurado do arquivo /etc/nginx/sites-available/mapas.conf. O diretório /var/run/php/ podrá mudar dependendo da versão que estiver trabalhando.
ubuntu@server$ sudo vi /etc/php/7.2/fpm/pool.d/mapas.confEu costumo utilizar o vi, mas você pode usar o vim, nano e afins para fazer a edição deste arquivo
[mapas]
listen = /var/run/php/php7.2-fpm-meu.dominio.gov.br.sock
listen.owner = mapas
listen.group = www-data 
user = mapas
group = www-data
catch_workers_output = yes
pm = dynamic
pm.max_children = 10
pm.start_servers = 1
pm.min_spare_servers = 1
pm.max_spare_servers = 3
pm.max_requests = 500
chdir = /srv/mapas
; php_admin_value[open_basedir] = /srv/mapas:/tmp
php_admin_value[session.save_path] = /tmp/
; php_admin_value[error_log] = /var/log/mapasculturais/php.error.log
; php_admin_flag[log_errors] = on
php_admin_value[display_errors] = 'stderr'Concluindo
Para finalizar, precisamos popular o banco de dados com os dados iniciais e executar um script que entre outras coisas compila e minifica os assets, otimiza o autoload de classes do composer e roda atualizações do banco.
ubuntu@server$ sudo su - mapas
mapas@server$ psql -f mapasculturais/db/initial-data.sql
mapas@server$ ./mapasculturais/scripts/deploy.sh
mapas@server$ exitReinicie os serviços do nginx e php7.2-fpm
ubuntu@server$ sudo service nginx restart
ubuntu@server$ sudo service php7.2-fpm restartA partir deste momento sua aplicação estará disponível para acesso utilizando a Autenticação Fake
Instalação do certificado SSL com LetsEncrypt
Ubuntu18.04
Passo 1 — Instalando o Certbot
Primeiro, adicione o repositório:
ubuntu@server$ sudo add-apt-repository ppa:certbot/certbotVocê vai precisar pressionar ENTER para aceitar. Depois, atualize a lista de pacotes para pegar as novas informações de pacotes do repositório:
ubuntu@server$ sudo apt-get updateE, finalmente, instale o pacote Nginx do Certbot com o apt-get:
ubuntu18.04
ubuntu@server$ sudo apt-get install python-certbot-nginxUbuntu20.04
ubuntu@server$ sudo apt install certbot python3-certbot-nginx -yPasso 2 — Confirmando a Configuração do Nginx
Para verificar, abra o arquivo de bloco do servidor para o seu domínio usando o vi ou o seu editor de textos favorito:
ubuntu@server$ sudo vi /etc/nginx/sites-available/mapas.confVerifique se todas as informações abaixo foram configuradas corretamente, já fizemos nas etapas anteriores, iremos apenas conferir.
set $site_name meu.dominio.gov.br;
server_name  meu.dominio.gov.br;
server_name meu.dominio.gov.br;
return 301 $scheme://mapas.siapp.one$request_uri;Depois de conferir o arquivo, saia do seu editor, e verifique a sintaxe da edição da sua configuração:
ubuntu@server$ sudo nginx -tSe você receber um erro, reabra o arquivo de bloco do servidor e verifique se há erros de digitação ou caracteres ausentes. Quando a sintaxe do seu arquivo de configuração estiver correta, recarregue o Nginx para carregar a nova configuração:
ubuntu@server$ sudo systemctl reload nginxPasso 3 — Permitindo HTTPS Através do Firewall
Cada servidor possuí sua particularidade, garanta que as portas 443(https) e 80(http) estejam liberadas no Firewall Permitindo HTTPS Através do Firewall vá até o tópico Passo 3 — Permitindo HTTPS Através do Firewall caso esteja utilizando um servidor padrão, no meu caso estou utilizando AWS e por isso o procedimento é um pouco diferente
Passo 4 — Obtendo um Certificado SSL
Obtendo o certificado
ubuntu@server$ sudo certbot --nginx -d meu.dominio.gov.brSe isso for bem sucedido, o certbot perguntará como você gostaria de definir suas configurações de HTTPS.
Please choose whether or not to redirect HTTP traffic to HTTPS, removing HTTP access.
-------------------------------------------------------------------------------
1: No redirect - Make no further changes to the webserver configuration.
2: Redirect - Make all requests redirect to secure HTTPS access. Choose this for
(...)Escolha 1 para redirecionar não redirecionar o tráfego forçado para HTTPS e 2 para fazer com que todaas as requisições sejam forçadas para HTTPS
Se isso for bem sucedido, o certibot irá exibir uma mensagem de sucesso:
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
Congratulations! You have successfully enabled https://mapas.siapp.one
You should test your configuration at:
(...)Passo 5 — Verificando a Auto-Renovação do Certbot
ubuntu@server$ sudo certbot renew --dry-runEm uma das máquinas que fiz a instalação precisei reiniciar o serivdor inteiro para que o NGINX funcione corretamente. A configuração do SSL foi feita com base no seguinte artigo.
Autenticação - MultipleLocalAuth
Após a instalção do Mapa Cultural teremos várias possibilidades para autenticação, mas iremos abordar aqui apenas a autenticação utilizando MultipleLocalAuth que dará ao usuário a possibilidade de fazer a autenticação utilizando contas Locais, Gooogle, Facebook e afins. Após os procedimentos descritos abaixo iremos sair do modo de 'Autenticação Fake'. Para isso iremos utilizar as informações já disponibilidas no repositório MultipleLocalAuth e adicionar alguns detalhes com o objetivo de facilitar a implementação
Clonando o repositório, iremos acessar a pasta plugins do nosso projeto utilizando o usuário mapas
ubuntu@server$ sudo su - mapas
mapas@server$ cd mapasculturais/src/protected/application/plugins
mapas@server$ pwd
  output: /srv/mapas/mapasculturais/src/protected/application/pluginsApós nos certificarmos de que estamos no diretório correto iremos clonar o repositório MultipleLocalAuth
mapas@server$ git clone https://github.com/mapasculturais/plugin-MultipleLocalAuth.git MultipleLocalAuth
mapas@server$ exit
mapas@server$Agora, Faça a edição do arquivo de configuração do mapas (criado no passo 5) utilizando vi ou o editor de sua preferência.
ubuntu@server$ sudo vi /srv/mapas/mapasculturais/src/protected/application/conf/config.phpNeste momento teremos três etapas
Ativar o plugin
Configurar MultipleLocalAuth como seu Provider de autenticação
Configurar as chaves das redes sociais
1- Ativar o plugin
Ainda com o arquivo config.php aberto adicione a seguinte configuração:
'plugins' => [
    // ... outros plugins
    'MultipleLocalAuth' => [
        'namespace' => 'MultipleLocalAuth',
    ],
],Nota: A linha acima ficará dentro do array de configurações do arquivo config.php que estamos editando neste momento.
2- Configurar MultipleLocalAuth como seu Provider de autenticação
Procure a linha com o código
'auth.provider' => 'Fake',
comente e adicione uma nova ou altere para
'auth.provider' => '\MultipleLocalAuth\Provider'
3- Configurar as chaves das redes sociais
Adicione a configuração auth.config para definir as estratégias utilizadas e as chaves dos serviços:
'auth.config' => array(
  'salt' => 'LT_SECURITY_SALT_SECURITY_SALT_SECURITY_SALT_SECURITY_SALT_SECU',
   'timeout' => '24 hours',
    'strategies' => [
       'Facebook' => array(
         'app_id' => 'SUA_APP_ID',
         'app_secret' => 'SUA_APP_SECRET', 
         'scope' => 'email'
       ),
      'LinkedIn' => array(
        'api_key' => 'SUA_API_KEY',
        'secret_key' => 'SUA_SECRET_KEY',
        'redirect_uri' => URL_DO_SEU_SITE . '/autenticacao/linkedin/oauth2callback',
        'scope' => 'r_emailaddress'
      ),
      'Google' => array(
        'client_id' => 'SEU_CLIENT_ID',
        'client_secret' => 'SEU_CLIENT_SECRET',
        'redirect_uri' => URL_DO_SEU_SITE . '/autenticacao/google/oauth2callback',
        'scope' => 'email'
      ),
      'Twitter' => array(
          'app_id' => 'SUA_APP_ID', 
          'app_secret' => 'SUA_APP_SECRET', 
      ),
    ]
),Nota:
Em nosso projeto utilizamos apenas a autenticação Padrão e Google;
Para obter as chaves para a estratégia "Google", consulte Google Console Developers, após gerar as chaves basta adiciona-las na configurações citadas acima;
Para obter as chaves para a estratégia "Facebook", consulte aqui, após gerar as chaves basta adiciona-las na configurações citadas acima;
Para obter as chaves para a estratégia "LinkedIn", consulte aqui, após gerar as chaves basta adiciona-las na configurações citadas acima;
Para obter as chaves para a estratégia "Twitter", consulte aqui, após gerar as chaves basta adiciona-las na configurações citadas acima.
Prontinho!! Após o procedimento você deverá ser capaz de acessar a página de autenticação utilizando MultipleLocalAuth
Autor: Rafael Chaves & Wiusmarques Moreira & Edson Gellert Schubert
Last updated
Was this helpful?