{"id":37236360,"url":"https://github.com/dnj/laravel-account","last_synced_at":"2026-01-16T04:53:04.333Z","repository":{"id":59579409,"uuid":"538000259","full_name":"dnj/laravel-account","owner":"dnj","description":"Simple library that keeps your user's accounts and transactions record.","archived":false,"fork":false,"pushed_at":"2023-09-06T13:05:16.000Z","size":258,"stargazers_count":1,"open_issues_count":0,"forks_count":1,"subscribers_count":2,"default_branch":"master","last_synced_at":"2025-05-25T14:51:20.081Z","etag":null,"topics":["accounting","financial","laravel","php"],"latest_commit_sha":null,"homepage":"","language":"PHP","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/dnj.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2022-09-18T04:31:38.000Z","updated_at":"2023-01-30T07:13:45.000Z","dependencies_parsed_at":"2023-02-15T17:16:05.638Z","dependency_job_id":null,"html_url":"https://github.com/dnj/laravel-account","commit_stats":null,"previous_names":[],"tags_count":1,"template":false,"template_full_name":null,"purl":"pkg:github/dnj/laravel-account","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/dnj%2Flaravel-account","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/dnj%2Flaravel-account/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/dnj%2Flaravel-account/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/dnj%2Flaravel-account/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/dnj","download_url":"https://codeload.github.com/dnj/laravel-account/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/dnj%2Flaravel-account/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":28420814,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-01-14T10:47:48.104Z","status":"ssl_error","status_checked_at":"2026-01-14T10:46:19.031Z","response_time":107,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.6:443 state=error: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["accounting","financial","laravel","php"],"created_at":"2026-01-15T04:14:08.887Z","updated_at":"2026-01-15T04:14:09.475Z","avatar_url":"https://github.com/dnj.png","language":"PHP","funding_links":[],"categories":[],"sub_categories":[],"readme":"# Management user account and transaction inside laravel app\n\n[![Latest Version on Packagist][ico-version]][link-packagist]\n[![Total Downloads][ico-downloads]][link-downloads]\n[![Software License][ico-license]][link-license]\n[![Testing status][ico-workflow-test]][link-workflow-test]\n[![Open API][ico-openapi]][link-openapi]\n\n## Introduction\n\nThe dnj/laravel-account package provides easy way to manage accounts and transactions of the users in your app. The Package stores all data in the accounts and transactions table.\n* Latest versions of PHP and PHPUnit and PHPCsFixer\n* Best practices applied:\n    * [`README.md`][link-readme] (badges included)\n    * [`LICENSE`][link-license]\n    * [`composer.json`][link-composer-json]\n    * [`phpunit.xml`][link-phpunit]\n    * [`.gitignore`][link-gitignore]\n    * [`.php-cs-fixer.php`][link-phpcsfixer]\n    * [`Open Api 3`][link-openapi]\n* Some useful resources to start coding\n\n\n## Here's a demo of how you can use it:\n```php\nuse dnj\\Account\\Contracts\\IAccount;\nuse dnj\\Account\\Contracts\\IAccountManager;\nuse dnj\\Account\\Contracts\\AccountStatus;\nuse dnj\\Currency\\Contracts\\ICurrencyManager;\n\n$currencyManager = app(ICurrencyManager::class);\n$currency = $currencyManager-\u003efirstByCode(\"USD\");\n\n$accountManager = app(IAccountManager::class);\n\n/**\n * @var IAccount $account\n */\n$account = $accountManager-\u003ecreate(\n    title: 'Profits',\n    userId: Auth::user()-\u003eid,\n    currencyId: $currency-\u003egetId(),\n    status: AccountStatus::ACTIVE,\n    canSend: true,\n    canReceive: true,\n    meta: [\"key\" =\u003e \"value\"],\n    userActivityLog: true\n);\n```\n## Installation\nYou can install the package via composer:\n```bash\ncomposer require dnj/laravel-account\n```\n\nThe package will automatically register itself.\n\n\nAfter this you can create required tables by running the migrations:\n\n```bash\nphp artisan migrate\n```\n\nYou can optionally publish the config file with:\n\n```bash\nphp artisan vendor:publish --provider=\"dnj\\Account\\AccountServiceProvider\" --tag=\"config\"\n```\n\nConfig file:\n```php\nreturn [\n    // Define your user model class for connect accounts to users. Example: App\\User:class\n    'user_model' =\u003e null,\n    \n    // Enable http restful routes.\n    'route_enable' =\u003e true,\n    \n    // Prefix of routes. By default routes register with /api/{prefix}/{accounts|transactions} pattern.\n    'route_prefix' =\u003e null,\n];\n```\n\n## Working With Accounts\n\nCreate new account:\n```php\nuse dnj\\Account\\Contracts\\IAccount;\nuse dnj\\Account\\Contracts\\IAccountManager;\nuse dnj\\Account\\Contracts\\AccountStatus;\nuse dnj\\Currency\\Contracts\\ICurrencyManager;\n\n$currencyManager = app(ICurrencyManager::class);\n$currency = $currencyManager-\u003efirstByCode(\"USD\");\n\n$accountManager = app(IAccountManager::class);\n\n/**\n * @var IAccount $account\n */\n$account = $accountManager-\u003ecreate(\n    title: 'Profits',\n    userId: Auth::user()-\u003eid,\n    currencyId: $currency-\u003egetId(),\n    status: AccountStatus::ACTIVE,\n    canSend: true,\n    canReceive: true,\n    meta: [\"key\" =\u003e \"value\"],\n    userActivityLog: true\n);\n\n```\n\nUpdate account:\n```php\nuse dnj\\Account\\Contracts\\IAccountManager;\nuse dnj\\Account\\Contracts\\AccountStatus;\n\n$accountManager = app(IAccountManager::class);\n$account = $accountManager-\u003eupdate(\n    accountId: 2,\n    changes: array(\n        'status' =\u003e AccountStatus::DEACTIVE,\n    ),\n    userActivityLog: true\n);\n```\n\nDestroy account:\n```php\nuse dnj\\Account\\Contracts\\IAccountManager;\n\n$accountManager = app(IAccountManager::class);\n$accountManager-\u003edelete(\n    accountId: $account-\u003egetId(),\n    userActivityLog: true\n);\n```\n\n***\n\n## Working With Transactions\n\nCreate transaction:\n```php\nuse dnj\\Account\\Contracts\\IAccountManager;\nuse dnj\\Account\\Contracts\\ITransactionManager;\nuse dnj\\Account\\Contracts\\ITransaction;\nuse dnj\\Number\\Number;\n\n$accountManager = app(IAccountManager::class);\n\n$profits = $accountManager-\u003egetByID(1);\n$salary = $accountManager-\u003egetByID(2);\n\n$transactionManager = app(ITransactionManager::class);\n\n/**\n * @var ITransaction $transaction\n */\n$transaction = $transactionManager-\u003etransfer(\n    fromAccountId: $profits-\u003egetId(),\n    toAccountId: $salary-\u003egetId(),\n    amount: Number::fromInput(2501.55),\n    meta: [\n        'month' =\u003e '2023-01'\n    ],\n    force: false,\n    userActivityLog: true\n);\n\n```\n\n\nUpdate transaction:\n```php\nuse dnj\\Account\\Contracts\\ITransactionManager;\nuse dnj\\Account\\Contracts\\ITransaction;\n\n$transactionManager = app(ITransactionManager::class);\n\n/**\n * @var ITransaction $transaction\n */\n$transaction = $transactionManager-\u003eupdate(\n    transactionId: 55,\n    meta: [\n        'month' =\u003e '2023-01',\n        'over-time' =\u003e 21\n    ]\n);\n```\n\nRollback transaction:\n```php\nuse dnj\\Account\\Contracts\\ITransactionManager;\nuse dnj\\Account\\Contracts\\ITransaction;\n\n$transactionManager = app(ITransactionManager::class);\n\n/**\n * @var ITransaction $rollbackTransaction new transaction that just made for rollback\n */\n$rollbackTransaction = $transactionManager-\u003erollback(55);\n```\n\n## How to use package API\n\nA document in YAML format has been prepared for better familiarization and use of package web services. which is placed in the [`openapi.json`][link-openapi] file.\n\nTo use this file, you can import it on the [Swagger](link-swagger) site and see all available methods.\n\n\n## Contribution\n\nContributions are what make the open source community such an amazing place to learn, inspire, and create. Any contributions you make are greatly appreciated.\n\nIf you have a suggestion that would make this better, please fork the repo and create a pull request. You can also simply open an issue with the tag \"enhancement\". Don't forget to give the project a star! Thanks again!\n\n1. Fork the Project\n2. Create your Feature Branch (`git checkout -b feature/AmazingFeature`)\n3. Commit your Changes (`git commit -m 'Add some AmazingFeature'`)\n4. Push to the Branch (`git push origin feature/AmazingFeature`)\n5. Open a Pull Request\n\n\n## Testing\nYou can run unit tests with PHP Unit:\n\n```bash\n./vendor/bin/phpunit \n```\n## About\nWe'll try to maintain this project as simple as possible, but Pull Requests are welcomed!\n\n## License\n\nThe MIT License (MIT). Please see [License File][link-license] for more information.\n\n[ico-version]: https://img.shields.io/packagist/v/dnj/laravel-account.svg?style=flat-square\n[ico-license]: https://img.shields.io/badge/license-MIT-brightgreen.svg?style=flat-square\n[ico-downloads]: https://img.shields.io/packagist/dt/dnj/laravel-account.svg?style=flat-square\n[ico-workflow-test]: https://github.com/dnj/local-filesystem/actions/workflows/test.yaml/badge.svg\n[ico-openapi]: https://img.shields.io/endpoint?color=blue\u0026label=openAPI\u0026logo=%22%236BA539%22\u0026logoColor=blue\u0026style=for-the-badge\u0026url=https%3A%2F%2Fimg.shields.io%2Fendpoint%3Furl%3Dhttps%3A%2F%2Fgithub.com%2Fdnj%2Flaravel-account%2Fblob%2Fmaster%2FapiDocs%2Faccount.json\n\n[link-openapi]: https://github.com/dnj/laravel-account/blob/master/openapi.json\n[link-swagger]: https://petstore.swagger.io/?url=https://raw.githubusercontent.com/dnj/laravel-account/master/openapi.json\n[link-workflow-test]: https://github.com/dnj/laravel-account/actions/workflows/test.yaml\n[link-packagist]: https://packagist.org/packages/dnj/laravel-account\n[link-license]: https://github.com/dnj/laravel-account/blob/master/LICENSE\n[link-downloads]: https://packagist.org/packages/dnj/laravel-account\n[link-readme]: https://github.com/dnj/laravel-account/blob/master/README.md\n[link-composer-json]: https://github.com/dnj/laravel-account/blob/master/composer.json\n[link-phpunit]: https://github.com/dnj/laravel-account/blob/master/phpunit.xml\n[link-gitignore]: https://github.com/dnj/laravel-account/blob/master/.gitignore\n[link-phpcsfixer]: https://github.com/dnj/laravel-account/blob/master/.php-cs-fixer.php\n[link-author]: https://github.com/dnj\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdnj%2Flaravel-account","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fdnj%2Flaravel-account","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdnj%2Flaravel-account/lists"}