|  | hace 4 meses | |
|---|---|---|
| .github | hace 2 años | |
| app | hace 4 meses | |
| bootstrap | hace 6 meses | |
| config | hace 6 meses | |
| database | hace 4 meses | |
| public | hace 2 años | |
| resources | hace 5 meses | |
| routes | hace 6 meses | |
| storage | hace 6 meses | |
| tests | hace 4 meses | |
| .editorconfig | hace 2 años | |
| .env.example | hace 1 año | |
| .gitattributes | hace 2 años | |
| .gitignore | hace 2 años | |
| LICENSE | hace 2 años | |
| README.md | hace 4 meses | |
| artisan | hace 1 año | |
| composer.json | hace 6 meses | |
| composer.lock | hace 4 meses | |
| package-lock.json | hace 5 meses | |
| package.json | hace 10 meses | |
| phpunit.xml | hace 1 año | |
| pint.json | hace 10 meses | |
| postcss.config.js | hace 1 año | |
| vite.config.js | hace 7 meses | 
A Laravel and Filament-powered accounting platform featuring full double-entry accrual accounting, delivering modern automation for professional financial management.
The demo environment provides a complete experience of the application with the following setup:
This demo is ideal for evaluating the application’s multi-currency capabilities and core features without any installation required.
Note: As this is a public demo environment, please do not enter any sensitive or personal information.
While ERPSAAS is open-source, maintaining it requires significant time and resources. Your sponsorship directly supports ongoing development, bug fixes, and improved documentation.
As a solo developer, I can only provide limited free support. Sponsors receive priority assistance, input on feature priorities, and early access to updates. Even a small monthly contribution makes a significant difference in keeping this project actively maintained.
Become a sponsor: GitHub Sponsors
Please check the official laravel installation guide for server requirements before you start. Official Documentation
Clone the repository
git clone https://github.com/andrewdwallo/erpsaas.git
Switch to the repo folder
cd erpsaas
Install all the dependencies using composer and npm
composer install
npm install
Copy the example env file and make the required configuration changes in the .env file
cp .env.example .env
Generate a new application key
php artisan key:generate
Run the database migrations (Set the database connection in .env before migrating)
php artisan migrate
Build your assets & start the local development server
php artisan filament:assets
npm run build
npm run dev
Command list
git clone https://github.com/andrewdwallo/erpsaas.git
cd erpsaas
composer install
npm install
cp .env.example .env
php artisan key:generate
php artisan migrate
npm run build
npm run dev
You may populate the database to help you get started quickly
Open the DatabaseSeeder and set the property values as per your requirement
database/seeders/DatabaseSeeder.php
Default login information:
email: admin@erpsaas.com
password: password
Run the database seeder
php artisan db:seed
Note: It’s recommended to have a clean database before seeding. You can reset your database to a clean state at any point by running the following command:
php artisan migrate:fresh
To generate PDFs for reports, the application uses Laravel Snappy. The Laravel Snappy package is already included in the application, but you need to install Wkhtmltopdf separately.
Download and install Wkhtmltopdf
Alternatively, if you are using Homebrew on macOS, you can install it using the following command:
brew install wkhtmltopdf
Configure the binary paths
config/snappy.php).For detailed installation instructions, refer to the Laravel Snappy documentation.
This application offers support for real-time currency exchange rates. This feature is disabled by default. To enable it, you must first register for an API key at ExchangeRate-API. The application uses this service due to its generous provision of up to 1,500 free API calls per month, which should be enough for development and testing purposes.
Disclaimer: There is no affiliation between this application and ExchangeRate-API.
Once you have your API key, you can enable the feature by setting the CURRENCY_API_KEY environment variable in your
.env file.
After setting your API key in the .env file, it is essential to prepare your database to store the currency data.
Start by running a fresh database migration:
php artisan migrate:fresh
This ensures that your database is in the correct state to store the currency information. Afterward, use the following command to generate and populate the Currency List with supported currencies for the Live Currency page:
php artisan currency:init
This command fetches and stores the list of currencies supported by your configured exchange rate service.
Of course, you may use any service you wish to retrieve currency exchange rates. If you decide to use a different
service, you can update the config/services.php file with your choice:
'currency_api' => [
    'key' => env('CURRENCY_API_KEY'),
    'base_url' => 'https://v6.exchangerate-api.com/v6',
],
Then, adjust the implementation of the App\Services\CurrencyService class to use your chosen service.
Once enabled, the “Live Currency” feature provides access to a dedicated page in the application, listing all supported currencies from the configured exchange rate service. Users can view available currencies and update exchange rates for their company’s currencies as needed.
The application now supports automatic translation, leveraging machine translation services provided by AWS, as facilitated by the andrewdwallo/transmatic package. This integration significantly enhances the application’s accessibility for a global audience. The application currently offers support for several languages, including English, Arabic, German, Spanish, French, Indonesian, Italian, Dutch, Portuguese, Turkish, and Chinese, with English as the default language.
To utilize this feature for additional languages or custom translations:
Once you have configured the package, you may update the following method in the app/Models/Setting/Localization.php
file to generate translations based on the selected language in the application UI:
Change to the following:
public static function getAllLanguages(): array
{
    return Languages::getNames(app()->getLocale());
}
To integrate Plaid with your application for enhanced financial data connectivity, you must first
create an account with Plaid and obtain your credentials. Set your credentials in the .env file as follows:
PLAID_CLIENT_ID=your-client-id
PLAID_CLIENT_SECRET=your-secret
PLAID_ENVIRONMENT=sandbox # Can be sandbox, development, or production
PLAID_WEBHOOK_URL=https://my-static-domain.ngrok-free.app/api/plaid/webhook # Must have /api/plaid/webhook appended
The PLAID_WEBHOOK_URL is essential as it enables your application to receive real-time updates on transactions from
connected bank accounts. This webhook URL must contain a static domain, which can be obtained from services like ngrok
that offer a free static domain upon signup. Alternatively, you may use any other service that provides a static domain.
After integrating Plaid, you can connect your account on the “Connected Accounts” page and link your financial institution. Before importing transactions, ensure to run the following command to process the queued transactions:
php artisan queue:listen
This project includes testing using Pest. The current test suite covers some reporting features and other core functionality. While it’s not yet a fully comprehensive test suite, it provides a foundation for testing critical features.
Ensure that you create a separate testing database named erpsaas_test in your database management system (e.g.,
MySQL).
CREATE DATABASE erpsaas_test;
The testing process automatically handles refreshing and seeding the test database with each test run, so no manual migration is required. For more information on how to write and run tests using Pest, refer to the official documentation: Pest Documentation.
Note : It is recommended to read the documentation for all dependencies to get yourself familiar with how the application works.
This project is licensed under the MIT License - see the LICENSE file for details.