Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/neiluJ/api-vue-boilerplate
[WiP] Ready-to-dev Symfony4 + API-Platform + VueJS client Application boilerplate
https://github.com/neiluJ/api-vue-boilerplate
api-platform boilerplate-application docker ready-to-use symfony vuejs webpack
Last synced: about 2 months ago
JSON representation
[WiP] Ready-to-dev Symfony4 + API-Platform + VueJS client Application boilerplate
- Host: GitHub
- URL: https://github.com/neiluJ/api-vue-boilerplate
- Owner: neiluJ
- License: mit
- Created: 2018-09-25T23:31:56.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2022-12-08T14:37:23.000Z (about 2 years ago)
- Last Synced: 2024-11-10T04:25:52.691Z (about 2 months ago)
- Topics: api-platform, boilerplate-application, docker, ready-to-use, symfony, vuejs, webpack
- Language: Vue
- Homepage:
- Size: 2.94 MB
- Stars: 4
- Watchers: 4
- Forks: 3
- Open Issues: 23
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# My API App Boilerplate
Ready-to-use Dockerized API app structure powered by:
* Symfony 4.4
* API Platform 2 (+ swagger for API documentation)
* VueJS + Vuex client structure
* Frontend toolkit (Webpack ready: SCSS, Icons/SVG sprites)
* Full docker dev stack with PHP 7.2 fpm + xdebug + nginx, node, varnish
* JWT-Ready with login implementationClone, Build, Enjoy.
## Usage
```bash
$ . aliases.sh
[api] $ stack up -d
```## Install
Create and EDIT an ```.env``` file:
```bash
$ cp .env.dist .env
``````bash
$ . aliases.sh
[api] $ stack up -d
[api] $ composer install -o
[api] $ npm install && npm run dev
```### Configure JWT
(find/configure passphrase in .env file)
```bash
[api] $ cli
site@php $ openssl genpkey -out config/jwt/private.pem -aes256 -algorithm rsa -pkeyopt rsa_keygen_bits:4096
site@php $ openssl pkey -in config/jwt/private.pem -out config/jwt/public.pem -pubout
```Login (users are stored in `config/packages/security.yaml`):
```bash
curl -X POST -H "Content-Type: application/json" http://localhost/api/login_check -d '{"username":"admin","password":"apiplatform"}'
```Encode a user password:
```bash
php bin/console security:encode-password
```> Read more about LexitJWTBundle: https://github.com/lexik/LexikJWTAuthenticationBundle/blob/master/Resources/doc/index.md
> Read more about Symfony Security: https://symfony.com/doc/current/security.html
### Upcoming/TODO features
* [ ] JWT-ready (with login form demo)
* [ ] Better http component (ie: understand api-platform responses)
* [x] Form validation component (sync with validation from api-platform)
* [x] CLI aliases
* [ ] Demo component with Greeting model## How to use/customize
#### Suggested browser extensions
* VueJS DevTools - [Chrome](https://chrome.google.com/webstore/detail/vuejs-devtools/nhdogjmejiglipccpnnnanhbledajbpd) / [Firefox](https://addons.mozilla.org/en-US/firefox/addon/vue-js-devtools/)
* Postman - [Chrome](https://chrome.google.com/webstore/detail/postman/fhbjgbiflinjbdggehcddcbncdddomop)
* JSON Viewer - [Chrome](https://chrome.google.com/webstore/detail/json-viewer/gbmdgpbipfallnflgajpaliibnhdgobh)#### PHPStorm Plugins
* Symfony
* .env files support
* VueJS#### Command Line Aliases
You have to source the ```aliases.sh``` file before using these aliases (on your host computer).
* *stack*: shortcut to docker-compose (ex: ```stack up -d```)
* *php*: runs php in the container (ex: ```php -i```)
* *npm*: runs npm in the container (ex: ```npm --version```)
* *console*: runs the symfony console in the container (ex: ```console ca:cl```)
* *cli*: enters the PHP CLI
* *composer*: runs composer in the container (ex: ```composer install -o```)
* *errorlog*: tails the httpd (nginx) error log
* *accesslog*: tails the httpd (nginx) access log
* *phplog*: tails the PHP-FPM error log#### API Endpoint
* Swagger/OpenAPI documentation is available at the API root: http://localhost/api
* You can change the API root url by changing the ```prefix``` in ```config/routes/api_platform.yaml```#### translations
* Translation files are shared with Symfony4
* Translations are stored in ```assets/translations``` in JSON format
* Add a new locale in ```assets/vue/main.js```:```js
import messagesEN from '../translations/messages.en.json'// ...
const i18n = new VueI18n({
locale: locale,
fallbackLocale: 'fr',
messages: {
fr: messagesFR,
en: messagesEN
}
});
```use in vue components:
```vue
{{ $t('app.welcome_msg') }}
```
use in twig/symfony:
```django{{ 'app.welcome_msg'|trans }}
```