Skip to main content

Investfly SDK

Project description

About

Python-SDK to work with Investfly API. Investfly

Investfly offers a platform for developing automated stock trading strategies. Users can create trading strategies through an intuitive drag-and-drop interface or by coding in Python.

The Investfly SDK contains the API and tools needed to build and deploy Python-based trading strategies on the Investfly platform.

Although you can edit Python code in our browser-based editor, writing code in a familiar IDE (Pycharm, VSCode) is recommended due to all the benefits that rich IDE offers. This SDK and CLI that comes with it makes it possible to develop trading strategy locally using your favorite IDE and upload it your Investfly account.

Quickstart

SDK Installation and Setup

Investfly-SDK comes with all required Python classes used for strategy development as well as a command line tool (CLI) called investfly-cli

Using a terminal app, run the following commands.

Setup Project and Virtual Environment

mkdir investfly
cd investfly
python3 -m venv venv
source venv/bin/activate

Install investfly-sdk

pip install investfly-sdk

Launch investfly-cli

Install investfly-sdk also adds investfly-cli in your path inside the virtual environment. It can be launched simply by using investfly-cli command in the virtual env.

(venv) user@host$ investfly-cli 

investfly-cli$ -h
usage: investfly-cli [-h]
                     {login,logout,strategy.list,strategy.copysamples,strategy.create,strategy.download,strategy.update,strategy.backtest.start,strategy.backtest.stop,strategy.backtest.result,exit}
                     ...

positional arguments:
  {login,logout,strategy.list,strategy.copysamples,strategy.create,strategy.download,strategy.update,strategy.backtest.start,strategy.backtest.stop,strategy.backtest.result,exit}
                        Available Commands
    login               Login to Investfly
    logout              Logout from Investfly
    strategy.list       List Python Strategies
    strategy.copysamples
                        Copy Samples from SDK
    strategy.create     Create a new trading strategy
    strategy.download   Download one of your strategy and save it to a file
    strategy.update     Update strategy Python Code
    strategy.backtest.start
                        Start backtest for strategy
    strategy.backtest.stop
                        Stop backtest for strategy
    strategy.backtest.result
                        Get backtest result, waiting if backtest is still
                        running
    exit                Stop and Exit CLI

options:
  -h, --help            show this help message and exit

investfly-cli$ 

Test Installation

You can test the installation by using the CLI to login and logout of Investfly.

investfly-cli$ login -u <YOUR_USERNAME> -p <YOUR_PASSWORD>
Session(username='xxxxxx', clientId='xxxxx-kaj1p3lv', clientToken='b29c9acc-330a-4821-9187-282d827e3e91')

investfly-cli$ logout

Trading Strategy Development

Investfly-SDK comes with a starter strategy template and many sample strategies to help you get started quickly.

Copy Samples

investfly-cli$ copysamples
Samples copied to ./samples directory

Create New Strategy

You can use one of the samples to create a new strategy. Normally, you would make a copy of the sample strategy, edit the copy using your favorite IDE to create a new strategy. But for now, we'll use the unmodified sample

investfly-cli$ login -u <YOUR_USERNAME> -p <YOUR_PASSWORD>
Session(username='xxxxx', clientId='xxxxxx-krfs61aa', clientToken='766fad47-3e1e-4f43-a77a-72a95a395fec')

investfly-cli$ strategy.create -n MySmaCrossOverStrategy -f ./samples/strategies/SmaCrossOverStrategy.py
Created strategy 83

investfly-cli$ strategy.list
{'strategyId': 83, 'strategyName': 'MySmaCrossOverStrategy'}

Edit and Update Code

Edit and update ./samples/strategies/SmaCrossOverStrategy.py as you like. For testing, change the StandardSymbolsList.SP_100 to StandardSymbolsList.SP_500 inside getSecurityUniverseSelector function.

investfly-cli$ strategy.update --id 83 -f ./samples/strategies/SmaCrossOverStrategy.py
Code Updated

After the code is updated, next step is to backtest the strategy and deploy it live. You can do them by logging into Investfly with a web browser, navigating to the strategy page and invoking corresponding actions.

IDE Editor

The primary reason for publishing this SDK is so that you can use your favorite IDE Editor to write and update Python Code. We recommend using PyCharm community edition: https://www.jetbrains.com/pycharm/download

Using IDE editor will assist with auto-completion and type hints. Additionally, use type checking tools like mypy to check your code before deploying.

When using the IDE, open investfly directory created above as a project with your IDE. Make sure that Python Interpreter is configured to the virtual environment investfly/venv/bin/python created above.

API Docs

API Docs are published at https://www.investfly.com/guides/docs/index.html

Getting Help

Please email admin@investfly.com for any support or bug report

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

investfly_sdk-1.2.tar.gz (57.6 kB view details)

Uploaded Source

Built Distribution

investfly_sdk-1.2-py3-none-any.whl (65.4 kB view details)

Uploaded Python 3

File details

Details for the file investfly_sdk-1.2.tar.gz.

File metadata

  • Download URL: investfly_sdk-1.2.tar.gz
  • Upload date:
  • Size: 57.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.11.6

File hashes

Hashes for investfly_sdk-1.2.tar.gz
Algorithm Hash digest
SHA256 5bb5b4cbff4679a9626e0fd1fe509b31b4a4b6bd5b513893e223c2f4c29da4ac
MD5 62d4be2e6f6f5720153d5aea6fbc2943
BLAKE2b-256 b5278022159c2e1c4bc6b9408e804b4d5a986b550b8d702270ea2baed9673fb8

See more details on using hashes here.

File details

Details for the file investfly_sdk-1.2-py3-none-any.whl.

File metadata

  • Download URL: investfly_sdk-1.2-py3-none-any.whl
  • Upload date:
  • Size: 65.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.11.6

File hashes

Hashes for investfly_sdk-1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 34449a8699370e9d769053811400c22d29160bee85fd91e4fbc7b4657c6228cd
MD5 fe6fb9d632016f0d568d3811b4de3d20
BLAKE2b-256 48de8fa0cadd9e5ab1e78d4b42c4e4a66b60c5ebee3737d411647c647ef4eb7e

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page