Python SDK for IIFL Trading APIs
Project description
IIFL Securities Python SDK
Python SDK for IIFL Trading APIs
Documentation
Read the docs hosted here
Features
- Order placement, modification and cancellation
- Fetching user info including holdings, positions, margin and order book.
- Fetching live market feed.
- Fetching order status and trade information.
Installation
pip install IIFLapis
Usage
Configuring API keys
Get your API keys from https://api.iiflsecurities.com/api-keys.html
Configure these keys in a file named keys.conf
in the same directory as your python script exists
A sample keys.conf
is given below:
[KEYS]
APP_NAME=YOUR_APP_NAME_HERE
APP_SOURCE=YOUR_APP_SOURCE_HERE
USER_ID=YOUR_USER_ID_HERE
PASSWORD=YOUR_PASSWORD_HERE
USER_KEY=YOUR_USER_KEY_HERE
ENCRYPTION_KEY=YOUR_ENCRYPTION_KEY_HERE
OCP_KEY=YOUR_OCP_KEY_HERE
Authentication
from IIFLapis import IIFLClient
client = IIFLClient(client_code="client_code", passwd="password", dob="YYYYMMDD", email_id="email",contact_number="Contact Number")
client.client_login() #For Customer Login
client.partner_login() #For Partner Login
After successful authentication, you should get a Logged in!!
message
Market Feed
#NOTE : Symbol has to be in the same format as specified in the example below.
req_list_=[{"Exch":"N","ExchType":"C","ScripCode":"22"},
{"Exch":"N","ExchType":"C","ScripCode":"2885"}]
client.fetch_market_feed(req_list=req_list_, count=2,client_id="client_code")
Historical Candle Data
#To fetch historical candle data, jwt token needs to be validated first.
client.jwt_validation("client_code")
#After successful jwt validation, historical data can be fetched.
client.historical_candles(exch='n',exchType='c',scripcode='1660',interval='30m',fromdate='2021-04-01',todate='2021-04-30',client_id="client_code")
Fetching user info
# Fetches client profile
client.profile(client_id = "client_code")
# Fetches holdings
client.holdings(client_id = "client_code")
# Fetches DP holdings
client.dp_holdings(client_id = "client_code")
# Fetches margin
client.margin(client_id = "client_code")
# Fetches net positions
client.net_positions(client_id = "client_code")
# Fetches net wise positions
client.net_position_netwise(client_id = "client_code")
# Fetches the order book of the client
client.order_book(client_id = "client_code")
# Fetches the trade book of the client
client.trade_book(client_id = "client_code")
Fetching transactions info
# Fetches equity transactions
client.equity_transactions(client_id="client_code", from_date="20210201", to_date="20210301")
# Fetches future transactions
client.future_transactions(client_id="client_code", from_date="20210201", to_date="20210301")
# Fetches option transactions
client.option_transactions(client_id="client_code", from_date="20210201", to_date="20210301")
# Fetches mutual funds transactions
client.mf_transactions(client_id="client_code", from_date="20210201", to_date="20210301")
# Fetches DP transactions
client.dp_transactions(client_id="client_code", from_date="20210201", to_date="20210301")
# Fetches ledger
client.ledger(client_id="client_code", from_date="20210201", to_date="20210301")
Scrip codes reference:
Note : Use these Links for getting scrip codes
CSV Scrip Dump: https://api.iiflsecurities.com/scrip-master.html
Enums
Following are the enums which can be imported and used for placing more complex orders.
class Exchange(Enum):
NSE = "N"
BSE = "B"
MCX = "M"
class ExchangeSegment(Enum):
CASH = "C"
DERIVATIVE = "D"
CURRENCY = "U"
class OrderType(Enum):
BUY = "BUY"
SELL = "SELL"
class OrderValidity(Enum):
DAY = 0
GTD = 1
GTC = 2
IOC = 3
EOS = 4
FOK = 6
class AHPlaced(Enum):
AFTER_MARKET_CLOSED = "Y"
NORMAL_ORDER = "N"
Placing an order
# Note: This is an indicative order.
from IIFLapis.order import Order, OrderType, Exchange, ExchangeSegment, OrderValidity, AHPlaced
test_order = Order(order_type="BUY", scrip_code=2885, quantity=1, exchange="N",
exchange_segment="C", price=1164, is_intraday=False, atmarket=False, order_id=2,
remote_order_id="1", exch_order_id="0", DisQty=0, stoploss_price=0,
is_stoploss_order=False, ioc_order= False, is_vtd=False,ahplaced = AHPlaced.NORMAL_ORDER,
public_ip='192.168.1.1', order_validity=OrderValidity.DAY, traded_qty=0)
client.place_order(order=test_order,client_id='client_code',order_requester_code='order_requester_code')
Modifying an order
test_order = Order(order_type="BUY", scrip_code=2885, quantity=1, exchange="N",
exchange_segment="C", price=1164, is_intraday=False, atmarket=False, order_id=2,
remote_order_id="1", exch_order_id="12345678", DisQty=0, stoploss_price=0,
is_stoploss_order=False, ioc_order= False, is_vtd=False, ahplaced = "N",
vtd=f"/Date({NEXT_DAY_TIMESTAMP})/", public_ip='192.168.1.1',
order_validity=OrderValidity.DAY, traded_qty=0)
client.modify_order(order=test_order,client_id='client_code',order_requester_code='order_requester_code')
Canceling an order
test_order = Order(order_type='B', scrip_code=1660, quantity=1,exchange='N',exchange_segment='C',exch_order_id='12345678')
client.cancel_order(order=test_order,client_id='client_code',order_requester_code='order_requester_code')
Fetching Order Status and Trade Information
from IIFLapis.order import Exchange
req_list= [
{
"Exch": "N",
"ExchType": "C",
"ScripCode": 20374,
"ExchOrderID": "1000000015310807"
}]
# Fetches the trade details
client.fetch_trade_info(req_list=req_list,client_id='client_code')
req_list_= [
{
"Exch": "N",
"ExchType": "C",
"ScripCode": 20374,
"RemoteOrderID": "90980441"
}]
# Fetches the order status
client.fetch_order_status(req_list=req_list_,client_id='client_code')
Trading with Option Strategies Built-in Function
- Following functions can help you trade with built-in strategies at market price.
- The symbol can be in upper case or lower case.
- The expiry date should follow a format of "DD Mmm YYYY", e.g. '24 Jun 2021'.
- Following functions don't check margin before placing orders.
- Please ensure proper margin before placing an order.
Note: The built-in functions are capable of placing orders in mutli-legs of pre-defined strategies. Please use at your own risk.
#Short Straddle
client.short_straddle(symbol='BANKNIFTY',expiry='24 Jun 2021',strike_price='36100',qty='75',isIntra=True,client_id='client_code',order_requester_code='order_requester_code',RemoteOrderID='XYZ010101')
#Long Straddle
client.long_straddle(symbol='BANKNIFTY',expiry='24 Jun 2021',strike_price='36100',qty='75',isIntra=True,client_id='client_code',order_requester_code='order_requester_code',RemoteOrderID='XYZ010101')
#Short Strangle
client.short_strangle(symbol='BANKNIFTY',expiry='24 Jun 2021',strike_price=['36100','36200'],qty='75',isIntra=True,client_id='client_code',order_requester_code='order_requester_code',RemoteOrderID='XYZ010101')
#Long Strangle
client.long_strangle(symbol='BANKNIFTY',expiry='24 Jun 2021',strike_price=['36100','36200'],qty='75',isIntra=True,client_id='client_code',order_requester_code='order_requester_code',RemoteOrderID='XYZ010101')
#Iron Fly
client.iron_fly(symbol='BANKNIFTY',expiry='24 Jun 2021',buy_strike_price=['36100','36300'],sell_strike_price='36200',qty=75,isIntra=True,client_id='client_code',order_requester_code='order_requester_code',RemoteOrderID='XYZ010101')
#Iron Condor
client.iron_condor(symbol='BANKNIFTY',expiry='24 Jun 2021',buy_strike_price=['36100','36300'],sell_strike_price=['36100','36300'],qty=75,isIntra=True,client_id='client_code',order_requester_code='order_requester_code',RemoteOrderID='XYZ010101')
#Put Calendar
client.put_calendar(symbol='BANKNIFTY',expiry=['24 Jun 2021','01 Jul 2021'],strike_price='36100',qty='75',isIntra=True,client_id='client_code',order_requester_code='order_requester_code',RemoteOrderID='XYZ010101')
#Call Calendar
client.call_calendar(symbol='BANKNIFTY',expiry=['24 Jun 2021','01 Jul 2021'],strike_price='36100',qty='75',isIntra=True,client_id='client_code',order_requester_code='order_requester_code',RemoteOrderID='XYZ010101')
TODO
- Write tests.
Credits
This package was created with Cookiecutter and the audreyr/cookiecutter-pypackage project template.
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
Built Distribution
File details
Details for the file IIFLapis-2.1.1.tar.gz
.
File metadata
- Download URL: IIFLapis-2.1.1.tar.gz
- Upload date:
- Size: 17.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.23.0 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.9.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | fd2efc7cac3d11154f959c03c79b53b12a4d771cf97c5cce2e045aec4c7d70ab |
|
MD5 | 683b6466edd0253f8a24f26f4e66015d |
|
BLAKE2b-256 | 63ddd9eda4c12679f30dd1b51821555b954e4935d34dc42c03525d07f7ce48fd |
File details
Details for the file IIFLapis-2.1.1-py2.py3-none-any.whl
.
File metadata
- Download URL: IIFLapis-2.1.1-py2.py3-none-any.whl
- Upload date:
- Size: 12.2 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.23.0 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.9.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | cc469cc02eba89350ba8a70cf172ed13b6c9f75923a497df23139fde606ce95d |
|
MD5 | f0a99347f3ce6c1664f8bfc87a321e0a |
|
BLAKE2b-256 | d95e043dc3937c84d31fc76000c75934db1114b8769734a14e504d252c8a9565 |