Open Source Wealth Management Software. Angular + NestJS + Prisma + Nx + TypeScript 🤍
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
Go to file
Thomas 0d65136a9e
Revert "Remove unneeded dependencies (#197)" (#199)
3 years ago
.vscode Initial commit 3 years ago
apps Upgrade Nx to version 12.5.4 (#194) 3 years ago
docker Simplify project setup (#3) 3 years ago
libs/common Change from subscription to one time payment (#181) 3 years ago
prisma Feature/improve investments by sector (#172) 3 years ago
tools Initial commit 3 years ago
.editorconfig Initial commit 3 years ago
.env Reorder (#116) 3 years ago
.eslintrc.json Initial commit 3 years ago
.gitignore Clean up files (#7) 3 years ago
.prettierignore Initial commit 3 years ago
.prettierrc Initial commit 3 years ago
.travis.yml add yarn build:all to .travis.yml (#127) 3 years ago
.yarnrc Initial commit 3 years ago
CHANGELOG.md Feature/upgrade angular dependencies to version 12.0.x (#196) 3 years ago
LICENSE Add license (#8) 3 years ago
README.md Improve README.md (#198) 3 years ago
angular.json Feature/upgrade to angular 12 (#169) 3 years ago
decorate-angular-cli.js Initial commit 3 years ago
jest.config.js Introduce @ghostfolio/common lib (#102) 3 years ago
jest.preset.js Initial commit 3 years ago
nx.json Upgrade Nx to version 12.5.4 (#194) 3 years ago
package.json Revert "Remove unneeded dependencies (#197)" (#199) 3 years ago
replace.build.js Feature/setup subscription with stripe (#178) 3 years ago
tsconfig.base.json Introduce @ghostfolio/common lib (#102) 3 years ago
yarn.lock Revert "Remove unneeded dependencies (#197)" (#199) 3 years ago

README.md

Ghostfolio

Open Source Portfolio Tracker

Live Demo

Build Status License: AGPL v3

Ghostfolio is an open source portfolio tracker built with web technology. The software empowers busy people to have a sharp look of their financial assets and to make solid, data-driven investment decisions.

Why Ghostfolio?

Ghostfolio is for you if you are...

  • 💼 trading stocks, ETFs or cryptocurrencies on multiple platforms

  • 🏦 pursuing a buy & hold strategy

  • 🎯 interested in getting insights of your portfolio composition

  • 👻 valuing privacy and data ownership

  • 🧘 into minimalism

  • 🧺 caring about diversifying your financial resources

  • 🆓 interested in financial independence

  • 🙅 saying no to spreadsheets in 2021

  • 😎 still reading this list

Features

  • Create, update and delete transactions
  • Multi account management
  • Portfolio performance (Today, YTD, 1Y, 5Y, Max)
  • Various charts
  • Static analysis to identify potential risks in your portfolio
  • Dark Mode
  • Zen Mode
  • Mobile-first design

Technology Stack

Ghostfolio is a modern web application written in TypeScript and organized as an Nx workspace.

Backend

The backend is based on NestJS using PostgreSQL as a database together with Prisma and Redis for caching.

Frontend

The frontend is built with Angular and uses Angular Material with utility classes from Bootstrap.

Getting Started

Prerequisites

Setup

  1. Run yarn install
  2. Run cd docker
  3. Run docker compose up -d to start PostgreSQL and Redis
  4. Run cd - to go back to the project root directory
  5. Run yarn setup:database to initialize the database schema and populate your database with (example) data
  6. Start server and client (see Development)
  7. Login as Admin with the following Security Token: ae76872ae8f3419c6d6f64bf51888ecbcc703927a342d815fafe486acdb938da07d0cf44fca211a0be74a423238f535362d390a41e81e633a9ce668a6e31cdf9
  8. Go to the Admin Control Panel and click Gather All Data to fetch historical data
  9. Click Sign out and check out the Live Demo

Development

Please make sure you have completed the instructions from Setup.

Start server

  1. Debug: Run yarn watch:server and click "Launch Program" in Visual Studio Code
  2. Serve: Run yarn start:server

Start client

Run yarn start:client

Testing

Run yarn test

Contributing

Ghostfolio is 100% free and open source. We encourage and support an active and healthy community that accepts contributions from the public - including you.

Not sure what to work on? We have got some ideas. Please tweet to @ghostfolio_ or send an e-mail to hi@ghostfol.io. We would love to hear from you.

License

© 2021 Ghostfolio

Licensed under the AGPLv3 License.