GithubHelp home page GithubHelp logo

wooodhead / ghostfolio Goto Github PK

View Code? Open in Web Editor NEW

This project forked from ghostfolio/ghostfolio

0.0 1.0 0.0 6.76 MB

Open Source Wealth Management Software made for Humans

Home Page: https://ghostfol.io

License: GNU Affero General Public License v3.0

JavaScript 1.92% TypeScript 73.96% HTML 21.08% SCSS 2.81% Shell 0.06% Dockerfile 0.17%

ghostfolio's Introduction

Ghostfolio Logo

Ghostfolio

Open Source Wealth Management Software made for Humans

Live Demo | Ghostfolio Premium | Blog | Slack | Twitter

Build Status License: AGPL v3

Ghostfolio is an open source wealth management software built with web technology. The application empowers busy people to keep track of their wealth like stocks, ETFs or cryptocurrencies and make solid, data-driven investment decisions.

Ghostfolio Premium

Our official Ghostfolio Premium cloud offering is the easiest way to get started. Due to the time it saves, this will be the best option for most people. The revenue is used for covering the hosting costs.

If you prefer to run Ghostfolio on your own infrastructure (self-hosting), please find further instructions in the section Run with Docker.

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: Time-weighted rate of return (TWR) for Today, YTD, 1Y, 5Y, Max
  • โœ… Various charts
  • โœ… Static analysis to identify potential risks in your portfolio
  • โœ… Import and export transactions
  • โœ… 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.

Run with Docker (self-hosting)

Prerequisites

  • Docker
  • A local copy of this Git repository (clone)

a. Run environment

Run the following command to start the Docker images from Docker Hub:

docker-compose -f docker/docker-compose.yml up -d

Setup Database

Run the following command to setup the database once Ghostfolio is running:

docker-compose -f docker/docker-compose.yml exec ghostfolio yarn database:setup

b. Build and run environment

Run the following commands to build and start the Docker images:

docker-compose -f docker/docker-compose.build.yml build
docker-compose -f docker/docker-compose.build.yml up -d

Setup Database

Run the following command to setup the database once Ghostfolio is running:

docker-compose -f docker/docker-compose.build.yml exec ghostfolio yarn database:setup

Fetch Historical Data

Open http://localhost:3333 in your browser and accomplish these steps:

  1. Create a new user via Get Started (this first user will get the role ADMIN)
  2. Go to the Admin Control Panel and click Gather All Data to fetch historical data
  3. Click Sign out and check out the Live Demo

Upgrade Version

  1. Increase the version of the ghostfolio/ghostfolio Docker image in docker/docker-compose.yml
  2. Run the following command to start the new Docker image: docker-compose -f docker/docker-compose.yml up -d
  3. Then, run the following command to keep your database schema in sync: docker-compose -f docker/docker-compose.yml exec ghostfolio yarn database:migrate

Development

Prerequisites

Setup

  1. Run yarn install
  2. Run docker-compose -f docker/docker-compose.dev.yml up -d to start PostgreSQL and Redis
  3. Run yarn database:setup to initialize the database schema and populate your database with (example) data
  4. Start the server and the client (see Development)
  5. Create a new user via Get Started (this first user will get the role ADMIN)
  6. Go to the Admin Control Panel and click Gather All Data to fetch historical data
  7. Click Sign out and check out the Live Demo

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

Start Storybook

Run yarn start:storybook

Migrate Database

With the following command you can keep your database schema in sync:

yarn database:push

Testing

Run yarn test

Public API (experimental)

Import Activities

Request

POST http://localhost:3333/api/v1/import

Authorization: Bearer Token

Set the header as follows:

"Authorization": "Bearer eyJh..."

Body

{
  "activities": [
    {
      "currency": "USD",
      "dataSource": "YAHOO",
      "date": "2021-09-15T00:00:00.000Z",
      "fee": 19,
      "quantity": 5,
      "symbol": "MSFT"
      "type": "BUY",
      "unitPrice": 298.58
    }
  ]
}
Field Type Description
accountId string (optional) Id of the account
currency string CHF | EUR | USD etc.
dataSource string MANUAL (for type ITEM) | YAHOO
date string Date in the format ISO-8601
fee number Fee of the activity
quantity number Quantity of the activity
symbol string Symbol of the activity (suitable for dataSource)
type string BUY | DIVIDEND | ITEM | SELL
unitPrice number Price per unit of the activity

Response

Success

201 Created

Error

400 Bad Request

{
  "error": "Bad Request",
  "message": [
    "activities.1 is a duplicate activity"
  ]
}

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 join the Ghostfolio Slack channel, tweet to @ghostfolio_ or send an e-mail to [email protected]. We would love to hear from you.

License

ยฉ 2022 Ghostfolio

Licensed under the AGPLv3 License.

ghostfolio's People

Contributors

dtslvr avatar frozies avatar gizmodus avatar i-valchev avatar mantovanig avatar mfrey43 avatar olirafa avatar ronaldkonjer avatar vzickner avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.