It uses the SEC 13F filings to show the current portfolios for your chosen institutional investors, their position changes from the previous quarter and a cumulative portfolio consisting of all their positions. Something akin to DataRoma or GuruFocus, less feature rich, but more customizable as you have the code.
It can be run either from the command line or deployed to Azure as a web application using Azure Functions, DocumentDB and Azure Queue as backend.
Explore the application running on Azure here.
- Make installing the app simpler by automating the complex steps below
- Implement some form of identity so that each person connecting to the web site has its own list of gurus
- Do a security review (i.e. any SQL injection kind of attack accessing DocumentDB? How to remove the Function Key from javascript?)
- Implement the concept of groups so that each user can create sub-lists of gurus according to whatever criteria they choose
- Implement history for each position in the web app as presented in the console app so that you can see the history of buying and selling for a guru for a position (already in Console app)
- Implement assigning separate weights for each guru to get a weighted-adjusted hyper-portfolio (already in Console app)
- How to make the UI look cool:
- Apply a good CSS to the whole thing
- Add pie charts of positions inside a portfolio and gurus inside hyper-portfolio
- Identify with up arrows increases, asterix-like graphic new buy and down arrow sells
- Specially highlights the most interesting trades (i.e. more than 20% increase of a top 10 position)
These instructions will get you a copy of the project up and running on your local machine for development and testing purposes.
You need to install:
- Visual Studio Tools for Azure Functions Preview
- Vue.js: best through the CLI
Installing and running the console application is trivial:
- Clone the repository
- Open the solution in the root directory in Visual Studio 2015
- Set
ConsoleFollower
as your startup project - Debug/Start Debugging
Installing and running the web application to test it locally is not easy:
- Fork the repository so that you have your own Github copy of it
- Create a new Azure Function Application
- Create a new DocumentDB in Azure and call it
guru-portfolios
- Create a new Azure Storage Queue in Azure in the storage account created automatically in step 2
- Clone the repository
- Copy
GuruBackend\appsettings.json.template
toGuruBackend\appsettings.json
and modify it to point to the resources created in step 3. and 4. - Exclude
GuruBackend\appsettings.json
from git as you don`t want to share your account key with the world - Open the solution in the root directory in Visual Studio 2015
- Set
GuruBackend
as your startup project - Debug/Start Debugging
- Open cmd.exe in
GuruFrontend\src\
and runnpm run dev
- Your default browser opens up and you can start running the application
Deploying the whole thing to Azure is difficult:
- Set up continous deployment pointing to your github repository as described here
- Add the variables in your
GuruBackend\appsettings.json
file to your Azure Function Application by clicking onFunction App Settings
and thenConfigure App Settings
- Add a PROJECT variable with value GuruBackend to your Azure Function Application by clicking on
Function App Settings
and thenConfigure App Settings
- Run all the functions to and look at the logs for success (to call the GetXXX ones you may want to use something like Postman)
- Create a new Azure Web Application (i.e. choose simple HTML5 App)
- Go to App Deployment/Deployment Options, disconnect it from the existing deployment and connect it to the github repository
- Add a PROJECT variable with value GuruFrontEnd to your Azure Web Application by clicking on Application Settings
- Go back to the Azure Function App in step 2. and click on App Settings -> CORS and add the website for the application you created in step 19.
- Point a browser to your new web App
- YOU ARE DONE
- If you modify GuruLoader or GuruBackend, simply do a build in VS and Push to Github
- If you modify GuruFrontEnd, open a cmd in GuruFrontEnd/ and run 'npm dev build', the Push to Github
Tests are run as usual from inside the Visual Studio UI.
This project is licensed under the MIT License - see the LICENSE file for details