g3n1us / pub
Open Source Publication Software
Installs: 37
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 2
Forks: 0
Open Issues: 1
Language:HTML
Type:php
Requires
- laravel/scout: ^3.0
- laravel/socialite: ^3.0
- league/flysystem: ^1.0
- league/flysystem-aws-s3-v3: ^1.0
- league/flysystem-dropbox: ^1.0
- michelf/php-markdown: ^1.6
- phpoffice/phpword: v0.13.*
Requires (Dev)
- raveren/kint: ^1.0
This package is auto-updated.
Last update: 2024-11-18 07:19:19 UTC
README
An opiniated, Laravel based CMS for publications with deep AWS integration, installable via Composer
Getting Started
The best way to get started using Pub is by setting up a dedicated EC2 instance. An instance profile should be set up with administrator priveleges. This way, the installer can set up an S3 bucket and other AWS resources for use with the application. After setup is complete, the extra priveleges that are not needed of the profile should be removed.
IMPORTANT! The instance should not be made publicly accessible at any time during setup and be sure to remove the extra priveleges from the instance profile
Installation
Install Laravel as normal. https://laravel.com/docs/installation
It is best to install Pub on top of a fresh Laravel installation. The Pub CLI installer will set up database connections, AWS resources, Google login and Dropbox integration.
After Laravel is installed, setup the basic authentication scaffolding by running:
php artisan make:auth
php artisan migrate
Note: if you get the error:
SQLSTATE[42000]: Syntax error or access violation: 1071 Specified key was too long; max key length is 767 bytes
Add the following to theboot()
method ofAppServiceProvider
:Schema::defaultStringLength(191);
Install via Composer:
composer require g3n1us/pub
Note: you may have to include
"minimum-stability": "dev"
in your composer.json while Pub is still in development.
After this you must add the Pub service providers array in config/app.php
.
'providers' => [
/*
* Laravel Framework Service Providers...
*/
Illuminate\Auth\AuthServiceProvider::class,
Illuminate\Broadcasting\BroadcastServiceProvider::class,
// ...
G3n1us\Pub\Providers\PubProvider::class,
G3n1us\Pub\Providers\PubRouteProvider::class,
G3n1us\Pub\Providers\DropboxServiceProvider::class,
],
Once this is done, you can run setup via our CLI Artisan command:
php artisan pub
This will walk you through setup.
Post Setup
After setup is complete, publish your assets from the Pub package to the site:
php artisan vendor:publish
composer dump autoload
There are some other optional steps you can take:
Seed the site with placeholder content:
php artisan db:seed --class=PubDatabaseSeeder
If you'd like to send mail out of the box, you'll need to either set up an smtp and add it's credentials to the .env file. Or you can change
MAIL_DRIVER=smtp
to
MAIL_DRIVER=sendmail
to send email using the built in sendmail executable.
Note: Don't use this for production! You should use a dedicated mail option. Check out
config/mail.php
to set this and other mail related options.
Cheers! 🍻 🍻