pronto / mobilebundle
A CMS bundle for mobile solutions
Installs: 668
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Watchers: 2
Forks: 1
Open Issues: 0
Language:JavaScript
Type:symfony-bundle
Requires
- php: ^8.1
- awps/font-awesome-php: ^4.7
- composer/semver: ^3.4
- doctrine/doctrine-fixtures-bundle: ^3.0
- doctrine/orm: ^2.17
- google/auth: ^1.33
- guzzlehttp/guzzle: ^7.8
- kreait/firebase-php: ^7.0
- league/flysystem: ^1.0
- league/oauth2-server-bundle: ^0.5
- myclabs/php-enum: ^1.7
- nyholm/psr7: ^1.3
- ramsey/uuid: ^3.9
- symfony/cache: ^6.4
- symfony/dotenv: ^6.4
- symfony/expression-language: ^6.4
- symfony/form: ^6.4
- symfony/mailer: ^6.4
- symfony/mime: ^6.4
- symfony/orm-pack: ^1.0
- symfony/proxy-manager-bridge: ^6.4
- symfony/routing: ^6.4
- symfony/security-bundle: ^6.4
- symfony/serializer: ^6.4
- symfony/templating: ^6.4
- symfony/translation: ^6.4
- symfony/twig-bundle: ^6.4
- symfony/validator: ^6.4
- troovers/browser: ^1.1
Requires (Dev)
- nelmio/alice: ^3.5.0
- rector/rector: ^0.18.11
- symfony/phpunit-bridge: ^6.4
- dev-master
- v3.0.7
- v3.0.6
- v3.0.5
- v3.0.4
- v3.0.3
- v3.0.2
- v3.0.1
- v3.0.0
- v3.0.0-beta3
- v3.0.0-beta2
- v3.0.0-beta1
- v3.0.0-alpha1
- v2.2.7
- v2.2.6
- v2.2.5
- 2.2.4
- 2.2.3
- 2.2.2
- 2.2.1
- 2.2.0
- 2.1.3
- 2.1.2
- 2.1.1
- 2.1.0
- 2.0.7-beta1
- 2.0.6-beta1
- 2.0.5-beta1
- 2.0.4-beta1
- 2.0.3-beta1
- 2.0.2-beta1
- 2.0.1-beta1
- 2.0.0-beta1
- 1.7.15
- 1.7.14
- 1.7.13
- 1.7.12
- 1.7.11
- 1.7.10
- 1.7.9
- 1.7.8
- 1.7.7
- 1.7.6
- 1.7.5
- 1.7.4
- 1.7.3
- 1.7.2
- 1.7.1
- 1.7.0
- 1.6.2
- 1.6.1
- 1.6.0
- 1.5.1
- 1.5.0
- 1.4.1
- 1.4.0
- 1.3.5
- 1.3.4
- 1.3.3
- 1.3.2
- 1.3.1
- 1.3.0
- 1.2.3
- 1.2.2
- 1.2.1
- 1.2.0
- 1.1.1
- 1.1.0
- 1.0.3
- 1.0.2
- 1.0.1
- 1.0.0
- 0.5.1
- 0.5.0
- 0.4.16
- 0.4.15
- 0.4.14
- 0.4.13
- 0.4.12
- 0.4.11
- 0.4.10
- 0.4.9
- 0.4.8
- 0.4.7
- 0.4.6
- 0.4.5
- 0.4.4
- 0.4.3
- 0.4.2
- 0.4.1
- 0.4.0
- 0.3.10
- 0.3.8
- 0.3.7
- 0.3.6
- 0.3.5
- 0.3.4
- 0.3.3
- 0.3.2
- 0.3.1
- 0.3.0
- 0.2.2
- 0.2.1
- 0.2.0
- 0.1.0
- dev-develop
- dev-feature/final
- dev-feature/oauth-migration
- dev-feature/redesign
- dev-feature/PRO-422
- dev-feature/inverse-relationships
- dev-feature/PRO-421
- dev-feature/PRO-366
This package is auto-updated.
Last update: 2024-12-06 14:04:33 UTC
README
Table of contents
Installation
Step 1. Install the skeleton
Open a command console and execute the following command to create a new project inside the folder: :
$ composer create-project pronto/mobile-skeleton <package-name>
This command requires you to have Composer installed globally, as explained in the installation chapter of the Composer documentation.
Step 2: Setup the database
Update your database connection inside the .env
file to match your configuration:
DATABASE_URL=mysql://db_user:db_password@127.0.0.1:3306/db_name
Then, create the database schema:
$ php bin/console doctrine:schema:create
And run the fixtures to provide initial data:
$ php bin/console doctrine:fixtures:load
This creates a first customer of the CMS, along with a super administrator.
Step 5: Test logging in
When you ran php bin/console doctrine:fixtures:load
, a customer with application and user account where created.
You can test your application by installing the web-server-bundle, which allows you to start a server and view your application at http://localhost:8000
. You can do this by installing the web-server-bundle:
$ composer require symfony/web-server-bundle --dev
And then running this command to start the server:
$ php bin/console server:run
You can now check if you're able to login at http://localhost:8000/login
with the following credentials: admin@example.com and password admin.
Step 6: Setup Firebase integrations
We use Firebase to send our push notifications and store information in the Firebase database. This information contains sign-ins of devices and app users. At a regular interval, these records are being fetched from the Firebase database and updated into the database of the CMS. This method is used to prevent a lot of requests to your server.
The CMS also stores notification templates in the cloud storage of Firebase. When a user receives a notification, there might be an html template which is being opened. That template is also retrieved from Firebase.
At last, APNS tokens need to be converted to Firebase tokens for iOS devices to be able to receive the notifications.
6.1 Create a Firebase project
You can do this by going to the Firebase Console and logging in with your Google account. You can now create a new project. After you have done this, you will be redirected to the project overview.
6.2 Create a new private key
Click on the settings icon and choose "Project settings". Next, click on the tab "Service accounts". You now have the ability to create a new private key. When you click this button, a service-account file will be downloaded.
For the MobileBundle to connect to your Firebase project, you need to rename this file to: google-service-account.json
and place it in the root of your project.
Upgrades
Most of the upgrades of the bundle do not require any changes for your main project. When changes are needed, they are listed here.
v1.6.* to v1.7.0
The service configuration is slightly changed in this version. When using Twig in your package, you'll need to update your packages/twig.yaml
file:
twig: globals: - pronto_mobile: '@pronto_mobile.global.app' + pronto_mobile: '@Pronto\MobileBundle\Service\ProntoMobile' entry_value_parser: '@Pronto\MobileBundle\Service\Collection\EntryValueParser' json_translator: '@Pronto\MobileBundle\Service\JsonTranslator'
MobileBundle configuration
The MobileBundle configuration is available in the config/packages/pronto_mobile.yaml
file. At the moment, there are not a lot of options here.
pronto_mobile: domain: 'pronto.am' uploads_folder: 'uploads' firebase: storage_decryption_password: 'ThisValueIsNotSoSecret'
Domain name
The domain is important for sending the emails. The domain name you provide here is the domain mails are being send from. So, with the default value, mails are sent from: noreply@pronto.am
.
Upoads folder
This option is quite obvious. You can specify in which folder the uploads are being stored. This also means that for now, the only storage option is local.
Firebase: Storage decryption password
This is the password that's being used to decrypt values from the logging table inside the Firebase Realtime Database. For obvious reasons, this value needs to be the same as the one you provide in the Android and iOS sdk of the MobileBundle.
Cronjobs
There are three cronjobs which need to run in the background to send push notifications, retrieve logging from Firebase and convert APNS tokens to Firebase tokens. Below are the commands you need to register on your server for these tasks to be executed in the background. You are free to change the interval at which they are executed.
crontab -e
* * * * * php /path/to/project/bin firebase:notifications:send // every minute */15 * * * * php /path/to/project/bin firebase:database:logs // every 15 minutes */15 * * * * php /path/to/project/bin firebase:tokens:convert // every 15 minutes
API Docs
Postman
A public Postman collection is available, with the currently available API routes.
APIDoc JS
The MobileBundle uses apidocjs to generate API docs. The docs are located inside the public/apidoc
folder.
OAuth2
The API docs don't list the routes for OAuth. The Android and Mobile sdk of the MobileBundle both use OAuth to connect to the API. If you're not familiar with OAuth, I suggest you visit https://www.oauth.com to get yourself up to date.
The routes for requesting an access token is: https://yourdomain.app/oauth/v2/token
. You can request an access token by using the client credentials, or using the username and password combination of an app user.
Request access token: Client Credentials
Documentation:https://www.oauth.com/oauth2-servers/access-tokens/client-credentials/
[POST] https://yourdomain.app/oauth/v2/token
{
"grant_type": "client_credentials",
"client_id": "1_66e8vp2mt2sccosk4w0ogswogsgww4wsokcw4wsc80w4s00woc",
"client_secret": "5s6e0r58qn8k0wggk808ogss4g08kgs0w8wgo84cc4s84sw4ck"
}
Request access token: Username and password
Documentation:https://www.oauth.com/oauth2-servers/access-tokens/password-grant/
[POST] https://yourdomain.app/oauth/v2/token
{
"grant_type": "password",
"username": "user@example.com",
"password": "1234luggage",
"client_id": "1_66e8vp2mt2sccosk4w0ogswogsgww4wsokcw4wsc80w4s00woc",
"client_secret": "5s6e0r58qn8k0wggk808ogss4g08kgs0w8wgo84cc4s84sw4ck"
}