Bem vindo palestrante, esse repositório contém o tema base para os slides do Seminário Locaweb PHPSP.
Aqui você encontrará toda a estrutura necessária para desenvolver seus slides de forma simples e permitindo total interatividade aos participantes do evento.
Para instalar as dependências dos projeto execute na raiz do repositório clonado:
composer install
Você pode rodar a aplicação de 3 formas: 'AZK', 'Vagrant' ou 'Localmente'. Cada forma é explicada abaixo:
Instale o AZK (caso não tenha ainda instalado): http://docs.azk.io/en/installation/
Dica: Para MacOSX e Windows, você precisará do Virtualbox.
Vá até a pasta do projeto e rode:
azk start
A saída deve ser algo como:
azk: ↑ starting `websocket` system, 1 new instances...
azk: ✓ checking `library/php:fpm` image...
azk: ◴ waiting for `websocket` system to start, trying connection to port websocket/tcp...
azk: ↑ starting `php` system, 1 new instances...
azk: ◴ waiting for `php` system to start, trying connection to port fastcgi/tcp...
azk: ↑ starting `nginx` system, 1 new instances...
azk: ✓ checking `library/nginx:latest` image...
azk: ◴ waiting for `nginx` system to start, trying connection to port http/tcp...
┌───┬───────────┬───────────┬─────────────────────────────┬───────────────────────────────┬─────────────┐
│ │ System │ Instances │ Hostname/url │ Instances-Ports │ Provisioned │
├───┼───────────┼───────────┼─────────────────────────────┼───────────────────────────────┼─────────────┤
│ ↑ │ nginx │ 1 │ http://seminario.dev.azk.io │ 1-http:32789, 1-443:32788 │ - │
│ │ │ │ │ │ │
├───┼───────────┼───────────┼─────────────────────────────┼───────────────────────────────┼─────────────┤
│ ↑ │ php │ 1 │ dev.azk.io │ 1-fastcgi:9000 │ - │
├───┼───────────┼───────────┼─────────────────────────────┼───────────────────────────────┼─────────────┤
│ ↑ │ websocket │ 1 │ dev.azk.io │ 1-websocket:7888, 1-9000:32787 │ - │
│ │ │ │ │ │ │
└───┴───────────┴───────────┴─────────────────────────────┴───────────────────────────────┴─────────────┘
Após as instâncias estarem rodando, abra no navegador: http://seminario.dev.azk.io/
Para o modo apresentador (que permite trocar os slides): http://seminario.dev.azk.io/presenter Usuário: admin Senha: phprules
Certifique-se de ter instalado Vagrant, Virtualbox e o plugin vagrant-hostmanager
. Os plugins vagrant-cachier
e
vagrant-bindfs
são opcionais.
Esse repositório possui receitas de provisionamento com Vagrant criadas usando PuPHPet, portanto para rodar a aplicação
basta executar o comando vagrant up
na raiz do projeto, isso irá baixar uma imagem ubuntu 14.04, instalar e configurar
tudo que é necessário para rodar a aplicação. Porem esse processo pode levar um tempo.
Após concluído o processo de provisionamento acesse a maquina virtual via ssh uutilizando o comando vagrant ssh
e
inicie o servidor de slides com o seguinte comando no diretório /vagrant
:
sudo php artisan slides:server
Caso você deseje executar a aplicação diretamente no seu sistema você pode usar Apache ou NGINX configurando o virtual
host para apontar para o diretório public
desse repositório, ou executar o comando a seguir que irá levantar um
servidor de desenvolvimento local.
sudo php artisan serve
Algumas extensões do PHP e outras dependências devem estar habilitadas ou instaladas no seu sistema para que a aplicação
rode normalmente utilizando esse comando, você pode consultar a infraestrutura recomendada no arquivo de descrição do
PuPHPet localizado em puphpet/config.yaml
Existem duas forma de acessar os slides, como expectador ou como apresentador. Somente como apresentador você terá acesso aos controles dos slides, os expectadores apenas poderão vizualizar os slides que estiverem sendo controlados pelo apresentador.
Se não tiver executado com Vagrant substitua o endereço pelo endereço configurado no seu ambiente ou por http://localhost:8000 caso esteja executando com o servidor de desenvolvimento tanto ao acessar como apresentador quanto como expectador
Para acessar como expectador digite qualquer e-mail válido na caixa de e-mail e deixe a senha em branco. Para acessar como apresentador use as seguintes credenciais:
Email: [email protected]
Senha: phprules
O Projeto possui alguns slides de exemplo para você utilizar como base na sua apresentação, sinta-se a vontade para fazer os seus slides da forma que achar melhor, os slides de exemplo contem mais informações sobre como montar sua apresentação.
Esse é um trabalho em andamento, envie Pull Requests com seus Slides para esse repositório mas esteja ciente de que outros palestrantes e organizadores do evento também estarão realizando mudanças no projeto ao mesmo tempo, por isso procure não interferir nas demais alterações.
Caso tenha algum problema com a aplicação abra uma issue nesse mesmo respositório.
Se durante o provisionamento da maquina virtual você receber uma sequencia de erros com a seguinte mensagem:
Warning: Authentication failure. Retrying...
Acesso o diretório puphpet/files/dot/ssh
e remova todos os arquivos de dentro desse diretório exceto o arquivo
insecure_private_key
. Em seguida remova a maquina virtual e inicie o procedimento novamente com os seguintes comandos:
vagrant destroy
vagrant up
Identificamos um possível problema na instalação do memcached na maquina virtual, porem o problema parece não acontecer
em 100% das vezes, caso receba um erro informando que a classe memcached
não foi encontrada ao acessar os slides
execute os seguintes passos para corrigir os problemas
- Acesse a maquina virtual via ssh com
vagrant ssh
- Certifique-se que memcached e php5-memcached estão instalados com
sudo apt-get install memcached php5-memcached
- Crie um arquivo de configuração do memcached com
sudo touch /etc/php5/mods-available/memcached.ini
- Acesse esse arquivo com o seu editor de texto favorito. ex:
sudo vim /etc/php5/mods-available/memcached.ini
- Insira o seguinte conteúdo nesse arquivo
extension=memcached.so
. Salve e feche:wq
se estiver no vim - Execute o seguinte comando:
sudo php5enmod memcached
para habilitar a extensão - Reestart os serviços com
sudo service php5-fpm restart && sudo service memcached restart && sudo service nginx restart
Caso o problema persista abra uma issue nesse repositório para que possamos ajuda-lo.
Livre para o universo! :-D