🚨 NOTE: We've archived the original repo but are leaving it here for posterity. We're still actively building Synth but focusing less on the OSS side of the app and more on the "community" parts of the data.
Synth aims to build a modern fintech stack and data platform for modern businesses.
We're aiming to be hyper-transparent, fully open-source and community-driven.
This codebase is currently in a very early stage of development.
In addition, much of the data that is used in the app is not open-source (due to licensing restrictions). We're working on making as much of the data open-source as possible, but the reality is that some of the data will need to be licensed from third parties in order to be useful.
Where possible we'll at least provide sample data so that you can get the app working locally.
The codebase is vanilla Rails and Postgres. Quite a simple setup.
You'll need:
- ruby >3 (specific version is in
Gemfile
) - postgresql (if using stock
config/database.yml
)
cd maybe
bundle install
rails db:setup
You can then run the rails web server:
bin/dev
And visit http://localhost:3000
- Currently the app relies either Google or GitHub for authentication. The easiest of which to set up is GitHub.
- In order to successfully run
rails db:setup
you will also need to create a GeoNames account to be used by the Timezone gem.
You can find the necessary API keys in .env.example
, which you can copy to .env
and fill in the values.
It's still very early days for this so your mileage will vary here and lots of things will break.
But almost any contribution will be beneficial at this point. Check the current Issues to see where you can jump in!
If you've got an improvement, just send in a pull request!
- Fork it
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create new Pull Request
If you've got feature ideas, simply open a new issues!