@typus/typus-sdk 1.0.6 → 1.0.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/lib/config.json CHANGED
@@ -3,6 +3,7 @@
3
3
  "PORTFOLIO_PACKAGE": "0xebaa2ad3eacc230f309cd933958cc52684df0a41ae7ac214d186b80f830867d2",
4
4
  "REGISTRY": "0xdcb1f0c4d31528a67f89303e3a99e15b9e21c7e22b4123a0e43e90b3fae5ea1e",
5
5
  "MANAGER_CAP": "0x2792322e5d741565edf556c7fc5ae9b1329dfe4b81ae7773cb3ff59a4f2eb9dc",
6
+ "USER_SHARE_REGISTRY": "0xbc2092c8ddddfc1e1bd850879b8e16e4c504fd060d0d2e7e9a5a83117b59a953",
6
7
  "TOKEN_PACKAGE": "0xd175cff04f1d49574efb6f138bc3b9b7313915a57b5ca04141fb1cb4f66984b2",
7
8
  "ORACLE_PACKAGE": "0x1e2b124f746a339b3cf99b9f969393a96594519aafb1d06517aacfeeae20e7a5",
8
9
  "BTC_ORACLE": "0xa38d8946a4c90bb53dc93e69477e52c299ee7df71aa4078a593fc4c443775192",
@@ -11,6 +11,7 @@ export declare const DOGE_ORACLE: string;
11
11
  export declare const PORTFOLIO_PACKAGE: string;
12
12
  export declare const REGISTRY: string;
13
13
  export declare const MANAGER_CAP: string;
14
+ export declare const USER_SHARE_REGISTRY: string;
14
15
  export declare const MODULE = "single_collateral";
15
16
  export declare const TEST_MINT_TOKEN = "0x672612858fcb5c6abf944638253142820c251753";
16
17
  export declare const PRICE_DECIMAL = 8;
@@ -26,3 +27,10 @@ export declare const TOKEN_NAME_TO_MODULE: {
26
27
  USDC: string;
27
28
  };
28
29
  export declare const testnetConnection: Connection;
30
+ export declare const ACTIVE_SUB_VAULT_TAG: number;
31
+ export declare const DEACTIVATING_SUB_VAULT_TAG: number;
32
+ export declare const INACTIVE_SUB_VAULT_TAG: number;
33
+ export declare const WARMUP_SUB_VAULT_TAG: number;
34
+ export declare const BIDDER_SUB_VAULT_TAG: number;
35
+ export declare const PREMIUM_SUB_VAULT_TAG: number;
36
+ export declare const PERFORMANCE_FEE_SUB_VAULT_TAG: number;
package/lib/constants.js CHANGED
@@ -3,7 +3,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.testnetConnection = exports.TOKEN_NAME_TO_MODULE = exports.TOKEN_NAME = exports.TEST_MNEMONIC = exports.FAKE_TOKEN_TYPE_ARGUMENT = exports.DEFAULT_TYPE_ARGUMENT = exports.TOKEN_DECIMAL = exports.PRICE_DECIMAL = exports.TEST_MINT_TOKEN = exports.MODULE = exports.MANAGER_CAP = exports.REGISTRY = exports.PORTFOLIO_PACKAGE = exports.DOGE_ORACLE = exports.APT_ORACLE = exports.SUI_ORACLE = exports.ETH_ORACLE = exports.BTC_ORACLE = exports.TIME_ORACLE = exports.ORACLE_PACKAGE = exports.TOKEN_REGISTRY_SUI = exports.TOKEN_PACKAGE = void 0;
6
+ exports.PERFORMANCE_FEE_SUB_VAULT_TAG = exports.PREMIUM_SUB_VAULT_TAG = exports.BIDDER_SUB_VAULT_TAG = exports.WARMUP_SUB_VAULT_TAG = exports.INACTIVE_SUB_VAULT_TAG = exports.DEACTIVATING_SUB_VAULT_TAG = exports.ACTIVE_SUB_VAULT_TAG = exports.testnetConnection = exports.TOKEN_NAME_TO_MODULE = exports.TOKEN_NAME = exports.TEST_MNEMONIC = exports.FAKE_TOKEN_TYPE_ARGUMENT = exports.DEFAULT_TYPE_ARGUMENT = exports.TOKEN_DECIMAL = exports.PRICE_DECIMAL = exports.TEST_MINT_TOKEN = exports.MODULE = exports.USER_SHARE_REGISTRY = exports.MANAGER_CAP = exports.REGISTRY = exports.PORTFOLIO_PACKAGE = exports.DOGE_ORACLE = exports.APT_ORACLE = exports.SUI_ORACLE = exports.ETH_ORACLE = exports.BTC_ORACLE = exports.TIME_ORACLE = exports.ORACLE_PACKAGE = exports.TOKEN_REGISTRY_SUI = exports.TOKEN_PACKAGE = void 0;
7
7
  var sui_js_1 = require("@mysten/sui.js");
8
8
  var config_json_1 = __importDefault(require("./config.json"));
9
9
  var mnemonic_json_1 = __importDefault(require("./mnemonic.json"));
@@ -22,6 +22,7 @@ exports.DOGE_ORACLE = config_json_1.default.DOGE_ORACLE;
22
22
  exports.PORTFOLIO_PACKAGE = config_json_1.default.PORTFOLIO_PACKAGE;
23
23
  exports.REGISTRY = config_json_1.default.REGISTRY;
24
24
  exports.MANAGER_CAP = config_json_1.default.MANAGER_CAP;
25
+ exports.USER_SHARE_REGISTRY = config_json_1.default.USER_SHARE_REGISTRY;
25
26
  exports.MODULE = "single_collateral";
26
27
  //publish from typus-dov/typus-dov
27
28
  exports.TEST_MINT_TOKEN = "0x672612858fcb5c6abf944638253142820c251753";
@@ -41,3 +42,10 @@ exports.testnetConnection = new sui_js_1.Connection({
41
42
  fullnode: "https://fullnode.testnet.sui.io:443/",
42
43
  faucet: "https://faucet.testnet.sui.io/gas",
43
44
  });
45
+ exports.ACTIVE_SUB_VAULT_TAG = 0;
46
+ exports.DEACTIVATING_SUB_VAULT_TAG = 1;
47
+ exports.INACTIVE_SUB_VAULT_TAG = 2;
48
+ exports.WARMUP_SUB_VAULT_TAG = 3;
49
+ exports.BIDDER_SUB_VAULT_TAG = 4;
50
+ exports.PREMIUM_SUB_VAULT_TAG = 5;
51
+ exports.PERFORMANCE_FEE_SUB_VAULT_TAG = 6;
@@ -38,15 +38,22 @@ var __generator = (this && this.__generator) || function (thisArg, body) {
38
38
  Object.defineProperty(exports, "__esModule", { value: true });
39
39
  var getBid_1 = require("../utils/auction/getBid");
40
40
  var sui_js_1 = require("@mysten/sui.js");
41
- var provider = new sui_js_1.JsonRpcProvider(sui_js_1.devnetConnection); //for read only operations
41
+ var getVaultData_1 = require("../utils/getVaultData");
42
+ var constants_1 = require("../constants");
43
+ var provider = new sui_js_1.JsonRpcProvider(constants_1.testnetConnection); //for read only operations
42
44
  (function () { return __awaiter(void 0, void 0, void 0, function () {
43
- var vault, bid;
45
+ var index, portfolioVaults, portfolioVault, bid;
44
46
  return __generator(this, function (_a) {
45
47
  switch (_a.label) {
46
48
  case 0:
47
- vault = "0x0ba9a1e3b6389e412c609feef563b1407a63272a";
48
- return [4 /*yield*/, (0, getBid_1.getBid)(vault, provider)];
49
+ index = "1";
50
+ return [4 /*yield*/, (0, getVaultData_1.getVaultDataFromRegistry)(constants_1.REGISTRY, provider, index)];
49
51
  case 1:
52
+ portfolioVaults = _a.sent();
53
+ portfolioVault = portfolioVaults[0];
54
+ console.log(portfolioVault);
55
+ return [4 /*yield*/, (0, getBid_1.getBid)(portfolioVault, provider)];
56
+ case 2:
50
57
  bid = _a.sent();
51
58
  console.log(bid);
52
59
  return [2 /*return*/];
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,58 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ var __generator = (this && this.__generator) || function (thisArg, body) {
12
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
13
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
14
+ function verb(n) { return function (v) { return step([n, v]); }; }
15
+ function step(op) {
16
+ if (f) throw new TypeError("Generator is already executing.");
17
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
18
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
19
+ if (y = 0, t) op = [op[0] & 2, t.value];
20
+ switch (op[0]) {
21
+ case 0: case 1: t = op; break;
22
+ case 4: _.label++; return { value: op[1], done: false };
23
+ case 5: _.label++; y = op[1]; op = [0]; continue;
24
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
25
+ default:
26
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
27
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
28
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
29
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
30
+ if (t[2]) _.ops.pop();
31
+ _.trys.pop(); continue;
32
+ }
33
+ op = body.call(thisArg, _);
34
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
35
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
36
+ }
37
+ };
38
+ Object.defineProperty(exports, "__esModule", { value: true });
39
+ var constants_1 = require("../constants");
40
+ var getVaultData_1 = require("../utils/getVaultData");
41
+ var sui_js_1 = require("@mysten/sui.js");
42
+ var connection = new sui_js_1.Connection({ fullnode: "https://rpc-testnet.suiscan.xyz:443" });
43
+ var provider = new sui_js_1.JsonRpcProvider(connection); //for read only operations
44
+ (function () { return __awaiter(void 0, void 0, void 0, function () {
45
+ var USER, res;
46
+ return __generator(this, function (_a) {
47
+ switch (_a.label) {
48
+ case 0:
49
+ USER = "0xb6c7e3b1c61ee81516a8317f221daa035f1503e0ac3ae7a50b61834bc7a3ead9";
50
+ return [4 /*yield*/, (0, getVaultData_1.getUserShares)(constants_1.USER_SHARE_REGISTRY, provider, USER)];
51
+ case 1:
52
+ res = _a.sent();
53
+ console.log("shares: ");
54
+ console.log(res);
55
+ return [2 /*return*/];
56
+ }
57
+ });
58
+ }); })();
@@ -48,12 +48,12 @@ var provider = new sui_js_1.JsonRpcProvider(constants_1.testnetConnection); //fo
48
48
  switch (_a.label) {
49
49
  case 0:
50
50
  sender = "0xb6c7e3b1c61ee81516a8317f221daa035f1503e0ac3ae7a50b61834bc7a3ead9";
51
- oracle = constants_1.ETH_ORACLE;
51
+ oracle = constants_1.BTC_ORACLE;
52
52
  index = "1";
53
- return [4 /*yield*/, (0, getVaultData_1.getVaultDataFromRegistry)(constants_1.REGISTRY, provider)];
53
+ return [4 /*yield*/, (0, getVaultData_1.getVaultDataFromRegistry)(constants_1.REGISTRY, provider, index)];
54
54
  case 1:
55
55
  portfolioVaults = _a.sent();
56
- portfolioVault = portfolioVaults.find(function (portfolioVault) { return portfolioVault.info.index == index; });
56
+ portfolioVault = portfolioVaults[0];
57
57
  console.log(portfolioVault);
58
58
  console.log(portfolioVault.config.activeVaultConfig.payoffConfigs);
59
59
  return [4 /*yield*/, (0, getAuctionMaxSize_1.getAuctionMaxSize)(constants_1.PORTFOLIO_PACKAGE, constants_1.MODULE, portfolioVault.typeArgs, constants_1.REGISTRY, portfolioVault.info.index, oracle)];
@@ -48,10 +48,10 @@ var provider = new sui_js_1.JsonRpcProvider(constants_1.testnetConnection); //fo
48
48
  case 0:
49
49
  sender = "0xb6c7e3b1c61ee81516a8317f221daa035f1503e0ac3ae7a50b61834bc7a3ead9";
50
50
  index = "1";
51
- return [4 /*yield*/, (0, getVaultData_1.getVaultDataFromRegistry)(constants_1.REGISTRY, provider)];
51
+ return [4 /*yield*/, (0, getVaultData_1.getVaultDataFromRegistry)(constants_1.REGISTRY, provider, index)];
52
52
  case 1:
53
53
  portfolioVaults = _a.sent();
54
- portfolioVault = portfolioVaults.find(function (portfolioVault) { return portfolioVault.info.index == index; });
54
+ portfolioVault = portfolioVaults[0];
55
55
  console.log(portfolioVault);
56
56
  return [4 /*yield*/, (0, getUserStatus_1.getUserStatus)(constants_1.PORTFOLIO_PACKAGE, constants_1.MODULE, portfolioVault.typeArgs, constants_1.REGISTRY, portfolioVault.info.index, sender)];
57
57
  case 2:
@@ -40,7 +40,7 @@ var constants_1 = require("../../constants");
40
40
  var sui_js_1 = require("@mysten/sui.js");
41
41
  var getVaultData_1 = require("../../utils/getVaultData");
42
42
  var getNewBidTx_1 = require("../../utils/portfolio/user/getNewBidTx");
43
- var provider = new sui_js_1.JsonRpcProvider(sui_js_1.devnetConnection); //for read only operations
43
+ var provider = new sui_js_1.JsonRpcProvider(constants_1.testnetConnection); //for read only operations
44
44
  var keypair = sui_js_1.Ed25519Keypair.deriveKeypair(constants_1.TEST_MNEMONIC);
45
45
  var signer = new sui_js_1.RawSigner(keypair, provider);
46
46
  (function () { return __awaiter(void 0, void 0, void 0, function () {
@@ -49,12 +49,12 @@ var signer = new sui_js_1.RawSigner(keypair, provider);
49
49
  return __generator(this, function (_d) {
50
50
  switch (_d.label) {
51
51
  case 0:
52
- size = "100000000";
53
- index = "0";
54
- return [4 /*yield*/, (0, getVaultData_1.getVaultDataFromRegistry)(constants_1.REGISTRY, provider)];
52
+ size = "330000000";
53
+ index = "1";
54
+ return [4 /*yield*/, (0, getVaultData_1.getVaultDataFromRegistry)(constants_1.REGISTRY, provider, index)];
55
55
  case 1:
56
56
  portfolioVaults = _d.sent();
57
- portfolioVault = portfolioVaults.find(function (portfolioVault) { return portfolioVault.info.index == index; });
57
+ portfolioVault = portfolioVaults[0];
58
58
  console.log(portfolioVault);
59
59
  bToken = portfolioVault.typeArgs[1];
60
60
  typeArguments = portfolioVault.typeArgs;
@@ -1,3 +1,3 @@
1
1
  import { JsonRpcProvider } from "@mysten/sui.js";
2
- import { Bid } from "../fetchData";
3
- export declare function getBid(vault: string, provider: JsonRpcProvider): Promise<Bid[]>;
2
+ import { Bid, PortfolioVault } from "../fetchData";
3
+ export declare function getBid(portfolioVault: PortfolioVault, provider: JsonRpcProvider): Promise<Bid[]>;
@@ -38,33 +38,26 @@ var __generator = (this && this.__generator) || function (thisArg, body) {
38
38
  Object.defineProperty(exports, "__esModule", { value: true });
39
39
  exports.getBid = void 0;
40
40
  var constants_1 = require("../../constants");
41
- function getBid(vault, provider) {
41
+ function getBid(portfolioVault, provider) {
42
42
  return __awaiter(this, void 0, void 0, function () {
43
- var obj, bidTable, obj2, ids, tmp, bids;
43
+ var obj2, ids, tmp, bids;
44
44
  return __generator(this, function (_a) {
45
45
  switch (_a.label) {
46
- case 0: return [4 /*yield*/, provider.getObject({ id: vault })];
46
+ case 0: return [4 /*yield*/, provider.getDynamicFields({ parentId: portfolioVault.auction.bids })];
47
47
  case 1:
48
- obj = _a.sent();
49
- if (obj.error) {
50
- console.log("obj not exists");
51
- return [2 /*return*/, []];
52
- }
53
- bidTable = obj.details.data.fields.value.fields.auction.fields.bids.fields.id.id;
54
- return [4 /*yield*/, provider.getDynamicFields({ parentId: bidTable })];
55
- case 2:
56
48
  obj2 = (_a.sent()).data;
57
49
  ids = obj2.map(function (e) { return e.objectId; });
58
50
  return [4 /*yield*/, provider.multiGetObjects({
59
51
  ids: ids,
60
52
  options: { showContent: true },
61
53
  })];
62
- case 3:
54
+ case 2:
63
55
  tmp = _a.sent();
64
56
  bids = tmp.map(function (e) {
65
57
  var _a;
66
58
  //@ts-ignore
67
59
  var bidData = (_a = e.data) === null || _a === void 0 ? void 0 : _a.content.fields.value.fields;
60
+ // console.log(bidData);
68
61
  var res = {
69
62
  price: bidData.price,
70
63
  size: Number(bidData.size / Math.pow(10, constants_1.TOKEN_DECIMAL)).toString(),
@@ -78,6 +78,8 @@ export interface Auction {
78
78
  endTsMs: string;
79
79
  priceConfig: PriceConfig;
80
80
  index: string;
81
+ bids: string;
82
+ ownerships: string;
81
83
  totalBidSize: string;
82
84
  ableToRemoveBid: boolean;
83
85
  }
@@ -2,3 +2,9 @@ import { JsonRpcProvider } from "@mysten/sui.js";
2
2
  import { PortfolioVault } from "./fetchData";
3
3
  export declare function getVaultDataFromRegistry(registry: string, provider: JsonRpcProvider, index?: string): Promise<PortfolioVault[]>;
4
4
  export declare function getNodesKeyFromLinkedList(linkedList: string, provider: JsonRpcProvider): Promise<string[]>;
5
+ export declare function getUserShares(user_share_registry: string, provider: JsonRpcProvider, user: string): Promise<Share[]>;
6
+ export interface Share {
7
+ index: string;
8
+ tag: string;
9
+ value: string;
10
+ }
@@ -47,7 +47,7 @@ var __values = (this && this.__values) || function(o) {
47
47
  throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
48
48
  };
49
49
  Object.defineProperty(exports, "__esModule", { value: true });
50
- exports.getNodesKeyFromLinkedList = exports.getVaultDataFromRegistry = void 0;
50
+ exports.getUserShares = exports.getNodesKeyFromLinkedList = exports.getVaultDataFromRegistry = void 0;
51
51
  var fetchData_1 = require("./fetchData");
52
52
  function getVaultDataFromRegistry(registry, provider, index) {
53
53
  return __awaiter(this, void 0, void 0, function () {
@@ -166,6 +166,8 @@ function getVaultDataFromRegistry(registry, provider, index) {
166
166
  endTsMs: auction.end_ts_ms,
167
167
  priceConfig: priceConfigRes,
168
168
  index: auction.index,
169
+ bids: auction.bids.fields.id.id,
170
+ ownerships: auction.ownerships.fields.id.id,
169
171
  totalBidSize: auction.total_bid_size,
170
172
  ableToRemoveBid: auction.able_to_remove_bid,
171
173
  };
@@ -228,3 +230,38 @@ function getNodesKeyFromLinkedList(linkedList, provider) {
228
230
  });
229
231
  }
230
232
  exports.getNodesKeyFromLinkedList = getNodesKeyFromLinkedList;
233
+ function getUserShares(user_share_registry, provider, user) {
234
+ return __awaiter(this, void 0, void 0, function () {
235
+ var user_shares, objsInfo, shares;
236
+ return __generator(this, function (_a) {
237
+ switch (_a.label) {
238
+ case 0: return [4 /*yield*/, provider.getDynamicFields({
239
+ parentId: user_share_registry,
240
+ })];
241
+ case 1:
242
+ user_shares = (_a.sent()).data;
243
+ // console.log(user_shares);
244
+ user_shares = user_shares.filter(function (user_share) { return user_share.name.value.user == user; });
245
+ return [4 /*yield*/, provider.multiGetObjects({
246
+ ids: user_shares.map(function (user_share) { return user_share.objectId; }),
247
+ options: { showContent: true },
248
+ })];
249
+ case 2:
250
+ objsInfo = _a.sent();
251
+ shares = [];
252
+ objsInfo.forEach(function (info) {
253
+ // @ts-ignore
254
+ var fields = info.data.content.fields;
255
+ var share = {
256
+ index: fields.name.fields.index,
257
+ tag: fields.name.fields.tag,
258
+ value: fields.value.fields.value,
259
+ };
260
+ shares.push(share);
261
+ });
262
+ return [2 /*return*/, shares];
263
+ }
264
+ });
265
+ });
266
+ }
267
+ exports.getUserShares = getUserShares;
package/package.json CHANGED
@@ -2,9 +2,9 @@
2
2
  "name": "@typus/typus-sdk",
3
3
  "author": "Typus",
4
4
  "description": "typus sdk",
5
- "version": "1.0.6",
5
+ "version": "1.0.8",
6
6
  "dependencies": {
7
- "@mysten/sui.js": "^0.31.0",
7
+ "@mysten/sui.js": "^0.32.0",
8
8
  "@types/node": "^17.0.0",
9
9
  "bignumber.js": "^9.1.1",
10
10
  "bs58": "^4.0.1",