- ✨ How to install
- 🚀 Git Workflow
- 🕸️ How to contribute
- 🚩 Cheatsheet
- 🔒 Database
- 🔥 Production mode
- 🌎 Test the app in your phone
- 🔧 PHP GD library
- 📧 Email verification
- 🎢 Deployment
- 😖 Throubleshooting with deployment
- 💣 Graphical access to Heroku Database
- 💘 Reset to a specific commit
Git clone
.- Execute
npm install and composer install
. - Copy .env.example file to .env on the root folder.
- Change database name to
laravel_vue_reverse_recipes
. - Create a file
.env
in the root and copy the content of.env.example
inside it. - Run
php artisan key:generate
. - Run
php artisan migrate
. - Run
php artisan serve
.
To run scripts from package.json when files change (TailwindCSS) execute npm run watch
in another terminal. Don't close it.
- Main branch: this branch includes the last version of the web (production).
- Develop branch: this branch has all the changes waiting to be merged into the main branch.
- Feature branch: new feature until it is complete.
If you want to make changes into the project, do the following:
- Create a new feature branch, for example,
feature/create-navbar
. - Make changes and test them.
- If everything is correct, commit those changes and push to Github.
- Switch to the
develop
branch and merge those changes. For example,git checkout develop
, to switch to develop branch, and thengit merge feature/create-navbar
. - Test everything and, if it's ok, commit and push to GitHub.
- Once several changes have been made to the
develop branch
it's time to merge withmain
to create stable version of the project.git checkout main
andgit merge develop
. Thengit push
. - Delete the feature branch
git branch -d feature/create-navbar
.
- Show branches:
git branch
- Create branch:
git branch <branch>
- Create branch and switch:
git checkout -b <branch>
- Switch to another branch:
git checkout <branch>
- Delete branch:
git branch -d <branch>
- Push branch to Github:
git push --set-upstream origin <branch>
- Delete remote branch:
git push origin -d <branch>
- Update remote branches:
git remote update origin --prune
- Create tag:
git tag v0.1.0
- List tags:
git tag -l
- Push tag to Github:
git push origin <tag>
To create the storage link you need to type php artisan storage:link
and then change the current APP_URL
inside .env
file to APP_URL=http://localhost:8000
or whatever you use.
In order to create database you need to run php artisan migrate
. After that, execute php artisan db:seed
. Make sure you only execute that last command once.
To test the app in production mode set those variables in .env
file:
APP_ENV=production
APP_DEBUG=false
Restart the server to apply the changes.
Run a local serve with: php artisan serve --host [YOUR IP] --port 8000
. Now, you will be able to access from http://[YOUR IP]:8000.
If you are a Windows user, and you are using XAMPP, in order to see the images when you export a recipe as PDF you need to go to your PHP folder inside XAMPP, open php.ini
and uncomment the option ;extension=gd
.
The set the GD extension available also in deployment, you need to add it into the composer.json
file.
{
"require": {
"ext-gd": "*"
}
}
Then, run a composer update
command.
DEPRECATED
The proper configuration is similar to this:
MAIL_MAILER=smtp
MAIL_HOST=smtp.mailtrap.io
MAIL_PORT=2525
MAIL_USERNAME=<Your Mailtrap username>
MAIL_PASSWORD=<Your Mailtrap password>
MAIL_ENCRYPTION=tls
MAIL_FROM_ADDRESS="<Your custom address>"
MAIL_FROM_NAME="${APP_NAME}"
You need to configure your .env
file with something like this (if you are using Gmail):
MAIL_MAILER=smtp
MAIL_HOST=smtp.gmail.com
MAIL_PORT=465
MAIL_USERNAME=<Enter your Gmail address>
MAIL_PASSWORD=<Enter your Gmail password>
MAIL_ENCRYPTION=ssl
MAIL_FROM_ADDRESS="<Enter your custom address>"
MAIL_FROM_NAME="${APP_NAME}"
In Gmail configuration, you need to activate the Less secure app access
option.
Add the project to Heroku using the Heroku CLI or by connecting the project to GitHub. Follow the steps shown in Heroku documentation. For a Laravel/Vue project do:
- Create
Procfile
for Laravel withweb: vendor/bin/heroku-php-apache2 public/
inside of it. See documentation for more info. - Add Node JS buildpack using Heroku interface or running in Heroku CLI this command:
heroku buildpacks:add heroku/nodejs
. - Go inside console in Activity > Open app > Run console and execute the
Heroku run bash
. Then do aphp artisan key:generate --show
. - Add database plugin, in this case, ClearDB. Probably you will need to add a credit card (but it's free).
- Add variables without double quotes.
Variable name | Value |
---|---|
APP_NAME | Reverse Recipes |
APP_ENV | production |
APP_DEBUG | true |
APP_KEY | the key of step 2 (base:...) |
DATABASE_URL | your cleardb url |
MAIL_MAILER | smtp |
MAIL_HOST | smtp.mailtrap.io |
MAIL_PORT | 2525 |
MAIL_USERNAME | your username |
MAIL_PASSWORD | your password |
MAIL_ENCRYPTION | tls |
MAIL_FROM_ADDRESS | your custom address |
MAIL_FROM_NAME | your app name |
- In the Heroku console (see step 2) run
heroku run php artisan migrate
,heroku run php artisan db:seed
andheroku run php artisan storage:link
.
In app/Provides/AppServiceProvider.php
add:
use Illuminate\Support\Facades\URL;
public function boot()
{
if(env('APP_ENV') !== 'local') {
URL::forceScheme('https');
}
}
In packaje.json
add:
{
"scripts": {
"postinstall": "npm run production"
}
}
In app/Http/Middleware/TrustProxies.php
add:
protected $proxies = '*';
protected $headers =
Request::HEADER_X_FORWARDED_FOR |
Request::HEADER_X_FORWARDED_HOST |
Request::HEADER_X_FORWARDED_PORT |
Request::HEADER_X_FORWARDED_PROTO |
Request::HEADER_X_FORWARDED_AWS_ELB;
See documentation for more information at the end of the post.
Heroku doesn't persist images in storage folder due to documentation, so you will need to set up, for example, an Amazon S3 service to storage files.
I'm not sure if this is mandatory, but we added the secure_asset()
function in app.blade.php
as follows. Probably it's necessary to add in styles
and scripts
too.
<link rel="icon" type="image/x-icon" {{ secure_asset('./favicon.ico') }}>
In order to use a graphical database interface (such as Heidi SQL) you need to run heroku config --app=YOURAPPNAME
inside your project, then use the data in the DATABASE_URL
variable as following to connect with Heidi SQL. This configuration was tested using ClearDB plugin inside Heroku.
mysql://<username>:<password>@<host>/<database>?reconnect=true
Name | Value |
---|---|
Host name | <host> |
User | <user> |
Password | <password> |
Port | 3306 |
Database | <database> |
If you want to revert some changes do the following: git reset --hard <commit-hash>
then push the changes with git push -f <remote> <branch>
.