This application is a partner management system. Basically, the Comarev admins register the interested companies that want to give a discount on their products/services to the Comarev contributors who are also registered in the system. Then, when the contributor buys something at the company (Comarev partner), they just have to scan a QR Code emitted in our dashboard and the system will return if they are ok with the payment (contribution), or not. If so, the contributor can get a discount.
Please check the WHO_WE_ARE section for more information.
Please feel free to contribute! While we welcome all contributions to this app, pull-requests that address outstanding Issues and have appropriate test coverage for them will be strongly prioritized.
Please check the Contributing section for more information.
Check our board for more details about what we're building.
- Comarev API MVP
The core of this system is ready and running on production. But there are lot of improvements we can do and we need your help!
Clone the project from Github:
git clone [email protected]:comarev/comarev.git && cd comarev
Install dependencies:
bundle install
Create a .env file by copying the existing one:
cp .env.example .env
Go to the .env file and set this:
PG_HOST=<your_database_host>
PG_USERNAME=<your_database_username>
PG_PASSWORD=<your_database_password>
Prepare database.yml:
cp config/database.example.yml config/database.yml
Create the database:
bundle exec rails db:create
Run migrations:
bundle exec rails db:migrate
Run database seeds:
# to populate with some users
bundle exec rails db:seed
Run the server:
bundle exec rails s
Run tests:
bundle exec rspec
You will need to install docker-compose
Prepare database.yml & .env
cp config/database.example.yml config/database.yml && cp .env.example .env
Build the app image
docker-compose build
Database setup:
docker-compose run --rm api rails db:setup
Start the containers:
docker-compose up
Them you should have the comarev-api running on localhost:3000
There will be this users to login:
admin: [email protected]
regular: [email protected]
with password: 123456
, for both
To stop the containers run:
docker-compose down
A user can be an admin
, manager
, emplyoee
or a customer
.
- Admins are the Comarev employees and can constrol the entire system. They are able to create the other kind of users. To become an admin, the user need the
admin
attibutetrue
. - Managers are the company managers. They can emmit their QR Code and also check if a user is able to get discount. To become a manager, the user needs to be assigned to a company.
- Employees do the same as managers, but they can't invite other employees or manage the company config.
- Customers are the Comarev contributors. They are supposed to pay invoices and get discounts. If the user is neither an admin nor a manager, he's a customer.
A company is a comarev partner. They offer discounts to the Comarev contributors.
A invoice is created for a user. When all invoices are paid, the user is able to get a discount. Invoices can only be created and mark as paid by an admin user, but customers can visualize them.
If you found this project useful, then please consider leaving a ⭐ on Github, thanks :D
Mauricio Lima 💻 📖 |
Gabriel Belgamo 💻 |
Bruno Viveiros 💻 |
RenanRambul 💻 |
Thiago Antonello Vargas 💻 |
This project follows the all-contributors specification. Contributions of any kind welcome!