## Jit Proxy Client
npm install @juju-exchange/jit-proxy``JitProxyClient` will create and send transactions to the jit proxy program. Instantiate a jit proxy client with a drift client and a program Id. The current public key for the jit proxy program is
`J1TnP8zvVxbtF5KFp5xRmWuvG9McnhzmBd9XGfCyuxFP`. Example instantiation:
``
const jitProxyClient = new JitProxyClient({
driftClient,
programId: new PublicKey('J1TnP8zvVxbtF5KFp5xRmWuvG9McnhzmBd9XGfCyuxFP'),
});
A jitter takes `JitParams` and uses them to determine when and how to use the `JitProxyClient` to send a transaction. For bots to make use of the jitter, they should create a jitter instance, and then set the `JitParams` according to their strategy for each market they are market making. `JitParams` are set on the Jitter object using `updatePerpParams()` and `updateSpotParams()`. There are two kinds of Jitters that can be insantiated: `JitterShotgun` and `JitterSniper`. The difference between the two is how orders are sent.
For `JitterShotgun`, orders are sent immediately when detecting a new eligible auction. The JitterShotgun will try up to 10 times to fill the order, retrying every time the it receives back an error due to the order not crossing the bid/ask in the `JitParams` or the oracle price being invalid.
For `JitterSniper`, orders are sent only when it detects that an order might cross the bid/ask of the `JitParams`, waiting until the right slot, before sending up to 3 orders (retrying on errors). It will not send orders if the price of the order does not cross the bid/ask during the auction, unlike the JitterShotgun, which will immediately attempt.
Type definition for the JitParmas is below:
``
export type JitParams = {
bid: BN;
ask: BN;
minPosition: BN;
maxPosition: BN;
priceType: PriceType;
subAccountId?: number;
};
PriceType options are `ORACLE` and `LIMIT`. Limit price type is the BN representaiton of an absolute price; i.e., price type of LIMIT and a market of bid: 10, ask: 11 means your market is 10@11. Oracle price types are offsets relative to the oralce price for a given slot. They are always added to the oracle price, so if the oracle price is 10.5, to get a market of 10@11 when price type is oracle, bid and ask are -0.5 and 0.5 respectively (Remember that bid and ask are of BN type, this example is for illustration purposes only. Remember to use BN math operations).
Example set up for the JitterSniper (assuming parameters are already initialized/subscribed to). JitterShotgun is instantiated and initialized in a similar manner.
`
const jitProxyClient = new JitProxyClient({
driftClient,
programId: new PublicKey('J1TnP8zvVxbtF5KFp5xRmWuvG9McnhzmBd9XGfCyuxFP'),
});
const jitter = new JitterSniper({
auctionSubscriber,
driftClient,
slotSubscriber,
jitProxyClient,
});
await jitter.subscribe();
``