A source-available invoice, quote, project and time-tracking app built with Laravel
Go to file
David Bomba 168cd7add0 Prevent duplicating contact/client name if they are the same! 2025-03-04 10:51:51 +11:00
.github Revert "exclude vendor folder from chmod" 2025-02-04 21:28:19 +11:00
app Prevent duplicating contact/client name if they are the same! 2025-03-04 10:51:51 +11:00
bootstrap Updated translations 2022-11-07 18:24:20 +11:00
config v5.11.48 2025-03-03 18:52:29 +11:00
database Location observers 2025-03-01 09:05:02 +11:00
lang Fixes for purchase order templates 2025-03-03 13:46:24 +11:00
openapi Prevent duplicating contact/client name if they are the same! 2025-03-04 10:51:09 +11:00
public Remove redundant js files 2025-02-06 18:01:26 +11:00
resources ts2 statement fixes 2025-02-26 14:31:32 +11:00
routes Locations 2025-02-21 10:33:41 +11:00
storage Fixes for tests 2023-11-01 14:09:47 +11:00
tests Location observers 2025-03-01 09:05:02 +11:00
.babelrc Enable ES6 class props with @babel/plugin-proposal-class-properties 2020-06-09 13:10:31 +02:00
.codacy.yml Update codacy.yml 2020-06-17 17:09:42 +02:00
.editorconfig
.env.ci Adjustments for env vars in tests 2024-12-09 14:24:27 +11:00
.env.dusk.example Fixes for reminder template emails 2020-11-08 08:17:30 +11:00
.env.example Fixes for vite config at build 2024-12-19 10:17:56 +11:00
.env.travis Laravel 7.x Shift (#40) 2020-09-06 19:38:10 +10:00
.gitattributes
.gitignore Update .gitignore file 2024-03-01 13:42:39 +01:00
.htaccess Minor fixes for .htaccess 2020-12-01 21:22:01 +11:00
.prettierrc Update .prettierrc formatting settings 2020-06-09 12:29:43 +02:00
CODE_OF_CONDUCT.md Code of Conduct 2021-05-03 21:23:39 +10:00
CONTRIBUTING.md Remove .htaccess from update script 2023-01-17 08:31:07 +11:00
LICENSE License update 2021-06-15 21:42:00 +10:00
README.md Event Schedule 2025-02-26 09:14:21 +11:00
VERSION.txt v5.11.48 2025-03-03 18:52:29 +11:00
_ide_helper_custom.php initial changings 2023-12-18 19:37:13 +01:00
artisan Fixes for verifyphone 2022-11-03 16:45:56 +11:00
codecov.yml
composer.json Fixes for static analysis 2025-02-25 07:31:40 +11:00
composer.lock Ensure we map attachments to einvoices 2025-02-28 11:39:52 +11:00
cypress.config.js commit .env.cypress 2023-02-18 10:17:55 +11:00
modules_statuses.json Fixes for stripe tokens 2024-10-07 13:51:45 +11:00
package-lock.json Updated translations 2025-02-06 17:54:56 +11:00
package.json Updated translations 2025-02-06 17:54:56 +11:00
phpstan.neon Fixes for static analysis 2025-02-25 07:31:40 +11:00
phpunit.xml Fixes for tests 2024-10-05 15:56:17 +10:00
postcss.config.cjs Migrate Tailwind config to CJS 2023-09-04 16:40:43 +02:00
preload.php fix syntax error preload.php 2025-01-14 15:15:11 +01:00
tailwind.config.cjs updated resources 2024-06-06 11:17:34 +10:00
vite.config.ts Updated translations 2025-02-06 17:54:56 +11:00
vite.config.ts.react Change paths for debian_docker filesystem 2024-11-24 17:29:05 +11:00
webpack.mix.js Added BACS to payment controller 2022-12-16 12:05:10 +01:00

README.md

Sublime's custom image

v5-develop phpunit Codacy Badge CLA assistant

Invoice Ninja 5

Invoice Ninja Version 5 is here! We've taken the best parts of version 4 and added the most requested features to create an invoicing application like no other. Check the Invoice Ninja YouTube Channel to get up to speed, or try the Demo now.

Choose your setup

  • Hosted: Our hosted version is a Software as a Service (SaaS) solution. You're up and running in under 5 minutes, with no need to worry about hosting or server infrastructure.
  • Self-Hosted: For those who prefer to manage their own hosting and server infrastructure. This version gives you full control and flexibility.

All Pro and Enterprise features from the hosted app are included in the open-source code. We offer a $30 per year white-label license to remove the Invoice Ninja branding from client-facing parts of the app.

Get social with us

Documentation

Installation Options and Clients

Mobile Apps

Desktop Apps

Self-Hosted Server Installation

Note: The self-hosted options do support the desktop and mobile apps.

[Advanced] Quick Hosting Setup

In addition to the official Invoice Ninja - Self-Hosted Installation Guide we have a few commands for you.

git clone --single-branch --branch v5-stable https://github.com/invoiceninja/invoiceninja.git
cp .env.example .env
composer i -o --no-dev

Please Note: Your APP_KEY in the .env file is used to encrypt data, if you lose this you will not be able to run the application.

Run if you want to load sample data, remember to configure .env

php artisan migrate:fresh --seed && php artisan db:seed && php artisan ninja:create-test-data

To run the web server

php artisan serve 

Navigate to (replace localhost with the appropriate domain)

http://localhost:8000/setup - To setup your configuration if you did not load sample data.
http://localhost:8000/ - For Administrator Logon

user: small@example.com
pass: password

http://localhost:8000/client/login - For Client Portal

user: user@example.com
pass: password

Developers Guide

In addition to the official Invoice Ninja - Developer Guide we've got your back with some insights.

App Design

The API and client portal have been developed using Laravel if you wish to contribute to this project familiarity with Laravel is essential.

When inspecting functionality of the API, the best place to start would be in the routes/api.php file which describes all of the availabe API endpoints. The controller methods then describe all the entry points into each domain of the application, ie InvoiceController / QuoteController

The average API request follows this path into the application.

  • Middleware processes the request initially inspecting the domain being requested + provides the authentication layer.
  • The request then passes into a Form Request (Type hinted in the controller methods) which is used to provide authorization and also validation of the request. If successful, the request is then passed into the controller method where it is digested, here is an example:
public function store(StoreInvoiceRequest $request)
{

    $invoice = $this->invoice_repo->save($request->all(), InvoiceFactory::create(auth()->user()->company()->id, auth()->user()->id));

    $invoice = $invoice->service()
                        ->fillDefaults()
                        ->triggeredActions($request)
                        ->adjustInventory()
                        ->save();

    event(new InvoiceWasCreated($invoice, $invoice->company, Ninja::eventVars(auth()->user() ? auth()->user()->id : null)));

    return $this->itemResponse($invoice);

}

Here for example we are storing a new invoice, we pass the validated request along with a factory into the invoice repository where it is processed and saved.

The returned invoice then passes through its service class (app/Services/Invoice) where various actions are performed.

A event is then fired which notifies listeners in the application (app/Providers/EventServiceProvider) which perform non blocking sub tasks

Finally the invoice is transformed (app/Transformers/) and returned as a response via Fractal.

Developer environment

Using the Quick Hosting Setup describe above you can quickly get started building out your development environment. Instead of using

composer i -o --no-dev

use

composer i -o

This provides the developer tools including phpunit which allows the test suite to be run.

If you are considering contributing back to the main repository, please add in any tests for new functionality / modifications. This will greatly increase the chances of your PR being accepted

Also, if you plan any additions for the main repository, you may want to discuss this with us first on Slack where we can assist with any technical information and provide advice.

Credits

Want More?

Checkout our other projects here!

Event Schedule

Security

If you find a security issue with this application, please send an email to contact@invoiceninja.com. Please follow responsible disclosure procedures if you detect an issue. For further information on responsible disclosure please read here.

License

Invoice Ninja is released under the Elastic License.
See LICENSE for details.