OpenSourceBilling is a simple web application to create and send invoices, receive payments, manage clients and companies. It generates reports of Item sales, payments, and collected revenues. It supports multi languages and multi currencies. This application is developed in Ruby on Rails v4.2.7.1. and Ruby v2.3.7. This document describes OSB application setup on Ubuntu 14.04 LTS machine.
- Attractive, responsive and adaptive user interface
- A nice looking dashboard with graph and key metrics
- Create and send invoices to your clients
- Recurring invoices
- Export invoices to PDF
- Create and send estimates to your clients
- Convert estimate to invoice
- Export estimates to PDF
- Receive payments against sent invoices
- Partial payments tracking
- Receive payments through Paypal and credit card
- Filters for listing pages
- Full text search feature using elastic search
- Time Tracking for running projects
- Generate invoice from project log hours
- Manage billing for your multiple sister companies under one account
- Import data from Freshbooks and QuickBooks
- Reports like
Payments Collected
,Aged Accounts Receivable
,Revenue By Client
,Items Sales
and more to come
Try Demo here
This is 2.0
release. You may contribute by having any suggestion or reporting the bugs you find.
MySql is an open-source relational database management system. Run the following command to install database:
sudo apt-get install mysql-server mysql-client libmysqlclient-dev
Git is version control system we used for OSB. Run the following command to install git.
sudo apt-get install git
Run the following command to install ruby dependencies:
sudo apt-get update
sudo apt-get install git-core curl zlib1g-dev build-essential libssl-dev libreadline-dev libyaml-dev libsqlite3-dev sqlite3 libxml2-dev libxslt1-dev libcurl4-openssl-dev python-software-properties libffi-dev libncurses5-dev automake libtool bison libffi-dev imagemagick libmagickcore-dev libmagickwand-dev libicu-dev
You may need access to dependent pecl libraries, most which can be found by
sudo add-apt-repository ppa:ondrej/php
Run the following commands to install stable version:
curl -L https://get.rvm.io | bash -s stable
source ~/.rvm/scripts/rvm
rvm install 2.3.7
rvm use 2.3.7 --default
Bundler is a tool that allows you to install multiple gem versions, run this command to install bundler:
gem install bundler
To clone project code from GitHub, give your GitHub account credential for authentication while cloning project.
git clone https://github.com/vteams/open-source-billing
cd open-source-billing
bundle install
Copy config/config.yml.copy to config/config.yml to set your configurations.
Edit config/config.yml with your own paypal settings:
paypal:
login: YOUR_PAYPAL_LOGIN
password: YOUR_PAYPAL_PASSWORD
signature: YOUR_PAYPAL_SIGNATURE
business: YOUR_PAYPAL_BUSINESS
Edit config/config.yml with your own application settings:
app_host: APP_HOST_HERE # e.g. osb.mydomain.com
app_protocol: http
Using following command in terminal to get path of wkhtmltopdf library path that is already installed on system.
which wkhtmltopdf
Edit config/config.yml with your own application wkhtmltopdf path.
wkhtmltopdf_path: YOUR_WKHTMLTOPDF_PATH
Edit config/config.yml with your own application smtp settings.
smtp_setting:
address: smtp.gmail.com
port: 587
authentication: :plain
enable_starttls_auto: true
user_name: YOUR_EMAIL_HERE
password: YOUR_PASSWORD_HERE
Edit config/config.yml with your own QuickBooksApp's oauth_consumer_key and oauth_consumer_secret.
quickbooks:
# QuickBooksApp's account key and secret
consumer_key: YOUR_QUICKBOOKS_APP_CLIENT_ID
consumer_secret: YOUR_QUICKBOOKS_APP_CLIENT_SECRET
Run following command on terminal to generate secret key
rake secret
copy this (newly generated) secret key from terminal and past it to the value of encryption_key in config.yml file.
encryption_key: ENTER-YOUR-ENCRYPTED-KEY-HERE
Copy config/database.yml.copy to config/database.yml and set your mysql username/password. After that run following command from terminal to create MySQL database specified in database.yml file.
rake db:create
rake db:migrate
Loading default values in database
rake db:seed
You need to start delayed_job for email delivery and other background tasks required for properly functionality of OSB by using following command
RAILS_ENV=development bin/delayed_job start
Your application is ready to use. Run rails server using following command:
rails server
and use your application in browser by typing in url: localhost:3000
You can also configure Apache, Nginx or any other web/application server of your choice to execute OSB in production mode.
Git clone this repo
$ git clone https://github.com/akhenda/open-source-billing.git
$ cd open-source-billing
Copy & fill the env file with necessary details.
$ cp .env.sample .env
Copy config/database.yml.copy
to config/database.yml
, config/application.yml.copy
to config/application.yml
, config/config.yml.copy
to config/config.yml
to set your configurations.
$ cp config/database.yml.copy config/database.yml
$ cp config/application.yml.copy config/application.yml
$ cp config/config.yml.copy config/config.yml
Copy one of the environments e.g. production from config/environments/production.rb.copy
to config/environments/production.rb
$ cp config/environments/production.rb.copy config/environments/production.rb
- (Optional) Setup
docker-mysqldump-googledrive
by following the instructions on this README. Consequently, copy the credentials folder to~/.credentials/docker-mysqldump-googledrive
. - Build and run the containers
Make sure the
db
container is up before starting the other containers.
$ docker-compose build
$ docker-compose up -d db cache
$ docker-compose up -d pma db_backup app
- Run DB Migrations NB: You may need to change mysql port if the default 3306 is in use.
$ docker-compose run --rm app rake db:migrate db:seed
- Fork it
- Create your feature branch (
git checkout -b my-awesome-feature
) - Commit your changes (
git commit -am 'Added some feature'
) - Push to the branch (
git push origin my-awesome-feature
) - Create new Pull Request
Mia Mian +1 (858) 586 7777
E-mail: mia@presstgers.com | fahad@presstigers.com | support@opensourcebilling.org
Homepage: http://www.opensourcebilling.org/