@firmachain/firma-js 0.2.30 → 0.2.33
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/dist/sdk/FirmaAuthzService.d.ts +41 -0
- package/dist/sdk/FirmaAuthzService.js +633 -0
- package/dist/sdk/FirmaBankService.d.ts +2 -1
- package/dist/sdk/FirmaBankService.js +4 -1
- package/dist/sdk/FirmaContractService.js +10 -12
- package/dist/sdk/FirmaCosmWasmService.d.ts +38 -0
- package/dist/sdk/FirmaCosmWasmService.js +667 -0
- package/dist/sdk/FirmaDistributionService.d.ts +2 -1
- package/dist/sdk/FirmaDistributionService.js +8 -5
- package/dist/sdk/FirmaFeeGrantService.js +3 -3
- package/dist/sdk/FirmaGovService.js +19 -19
- package/dist/sdk/FirmaIbcService.d.ts +15 -0
- package/dist/sdk/FirmaIbcService.js +144 -0
- package/dist/sdk/FirmaMobileSDK.d.ts +3 -1
- package/dist/sdk/FirmaMobileSDK.js +4 -1
- package/dist/sdk/FirmaNftService.js +6 -6
- package/dist/sdk/FirmaSDK.d.ts +7 -1
- package/dist/sdk/FirmaSDK.js +10 -1
- package/dist/sdk/FirmaStakingService.d.ts +18 -5
- package/dist/sdk/FirmaStakingService.js +20 -13
- package/dist/sdk/FirmaTokenService.js +12 -12
- package/dist/sdk/FirmaUtil.d.ts +18 -1
- package/dist/sdk/FirmaUtil.js +193 -0
- package/dist/sdk/FirmaWalletService.d.ts +3 -0
- package/dist/sdk/FirmaWalletService.js +18 -10
- package/dist/sdk/firmachain/amino/signer.d.ts +1 -2
- package/dist/sdk/firmachain/authz/AuthzQueryClient.d.ts +48 -0
- package/dist/sdk/firmachain/authz/AuthzQueryClient.js +142 -0
- package/dist/sdk/firmachain/authz/AuthzTxClient.d.ts +23 -0
- package/dist/sdk/firmachain/authz/AuthzTxClient.js +47 -0
- package/dist/sdk/firmachain/authz/AuthzTxTypes.d.ts +147 -0
- package/dist/sdk/firmachain/authz/AuthzTxTypes.js +358 -0
- package/dist/sdk/firmachain/authz/index.d.ts +3 -0
- package/dist/sdk/firmachain/authz/index.js +15 -0
- package/dist/sdk/firmachain/bank/BankTxClient.d.ts +4 -3
- package/dist/sdk/firmachain/bank/BankTxClient.js +5 -2
- package/dist/sdk/firmachain/common/ITxClient.d.ts +4 -1
- package/dist/sdk/firmachain/common/ITxClient.js +15 -0
- package/dist/sdk/firmachain/common/signingaminostargateclient.d.ts +50 -0
- package/dist/sdk/firmachain/common/signingaminostargateclient.js +267 -0
- package/dist/sdk/firmachain/common/signingstargateclient.d.ts +15 -8
- package/dist/sdk/firmachain/common/signingstargateclient.js +68 -9
- package/dist/sdk/firmachain/contract/ContractTxClient.d.ts +4 -3
- package/dist/sdk/firmachain/contract/ContractTxClient.js +5 -2
- package/dist/sdk/firmachain/cosmwasm/CosmWasmQueryClient.d.ts +52 -0
- package/dist/sdk/firmachain/cosmwasm/CosmWasmQueryClient.js +193 -0
- package/dist/sdk/firmachain/cosmwasm/CosmWasmTxClient.d.ts +38 -0
- package/dist/sdk/firmachain/cosmwasm/CosmWasmTxClient.js +59 -0
- package/dist/sdk/firmachain/cosmwasm/index.d.ts +3 -0
- package/dist/sdk/firmachain/cosmwasm/index.js +15 -0
- package/dist/sdk/firmachain/distribution/DistributionTxClient.d.ts +6 -5
- package/dist/sdk/firmachain/distribution/DistributionTxClient.js +7 -4
- package/dist/sdk/firmachain/feegrant/FeeGrantTxClient.d.ts +4 -3
- package/dist/sdk/firmachain/feegrant/FeeGrantTxClient.js +5 -2
- package/dist/sdk/firmachain/gov/GovTxClient.d.ts +5 -4
- package/dist/sdk/firmachain/gov/GovTxClient.js +6 -3
- package/dist/sdk/firmachain/ibc/IbcQueryClient.d.ts +34 -0
- package/dist/sdk/firmachain/ibc/IbcQueryClient.js +71 -0
- package/dist/sdk/firmachain/ibc/IbcTxClient.d.ts +13 -0
- package/dist/sdk/firmachain/ibc/IbcTxClient.js +39 -0
- package/dist/sdk/firmachain/ibc/index.d.ts +3 -0
- package/dist/sdk/firmachain/ibc/index.js +15 -0
- package/dist/sdk/firmachain/nft/NftTxClient.d.ts +5 -4
- package/dist/sdk/firmachain/nft/NftTxClient.js +6 -3
- package/dist/sdk/firmachain/staking/StakingQueryClient.d.ts +17 -4
- package/dist/sdk/firmachain/staking/StakingQueryClient.js +38 -18
- package/dist/sdk/firmachain/staking/StakingTxClient.d.ts +7 -6
- package/dist/sdk/firmachain/staking/StakingTxClient.js +8 -5
- package/dist/sdk/firmachain/token/TokenTxClient.d.ts +6 -5
- package/dist/sdk/firmachain/token/TokenTxClient.js +7 -4
- package/package.json +3 -1
- package/dist/sdk/firmachain/amino/secp256k1hdwallet.d.ts +0 -94
- package/dist/sdk/firmachain/amino/secp256k1hdwallet.js +0 -437
- package/dist/sdk/firmachain/amino/secp256k1wallet.d.ts +0 -23
- package/dist/sdk/firmachain/amino/secp256k1wallet.js +0 -141
|
@@ -0,0 +1,267 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __extends = (this && this.__extends) || (function () {
|
|
3
|
+
var extendStatics = function (d, b) {
|
|
4
|
+
extendStatics = Object.setPrototypeOf ||
|
|
5
|
+
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
|
|
6
|
+
function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
|
|
7
|
+
return extendStatics(d, b);
|
|
8
|
+
};
|
|
9
|
+
return function (d, b) {
|
|
10
|
+
if (typeof b !== "function" && b !== null)
|
|
11
|
+
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
|
|
12
|
+
extendStatics(d, b);
|
|
13
|
+
function __() { this.constructor = d; }
|
|
14
|
+
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
|
|
15
|
+
};
|
|
16
|
+
})();
|
|
17
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
18
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
19
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
20
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
21
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
22
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
23
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
24
|
+
});
|
|
25
|
+
};
|
|
26
|
+
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
27
|
+
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
28
|
+
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
29
|
+
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
30
|
+
function step(op) {
|
|
31
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
32
|
+
while (_) try {
|
|
33
|
+
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;
|
|
34
|
+
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
35
|
+
switch (op[0]) {
|
|
36
|
+
case 0: case 1: t = op; break;
|
|
37
|
+
case 4: _.label++; return { value: op[1], done: false };
|
|
38
|
+
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
39
|
+
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
40
|
+
default:
|
|
41
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
42
|
+
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
43
|
+
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
44
|
+
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
45
|
+
if (t[2]) _.ops.pop();
|
|
46
|
+
_.trys.pop(); continue;
|
|
47
|
+
}
|
|
48
|
+
op = body.call(thisArg, _);
|
|
49
|
+
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
50
|
+
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
51
|
+
}
|
|
52
|
+
};
|
|
53
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
54
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
55
|
+
};
|
|
56
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
57
|
+
exports.SigningAminoStargateClient = exports.isMsgSignData = void 0;
|
|
58
|
+
var tendermint_rpc_1 = require("@cosmjs/tendermint-rpc");
|
|
59
|
+
//import { StdFee } from ".";
|
|
60
|
+
var accounts_1 = require("./accounts");
|
|
61
|
+
var stargateclient_1 = require("./stargateclient");
|
|
62
|
+
var axios_1 = __importDefault(require("axios"));
|
|
63
|
+
var any_1 = require("../google/protobuf/any");
|
|
64
|
+
var encoding_1 = require("@cosmjs/encoding");
|
|
65
|
+
var amino_1 = require("@cosmjs/amino");
|
|
66
|
+
var fast_deep_equal_1 = __importDefault(require("fast-deep-equal"));
|
|
67
|
+
var utils_1 = require("@cosmjs/utils");
|
|
68
|
+
var tx_1 = require("@cosmjs/launchpad/build/tx");
|
|
69
|
+
var amino_2 = require("@cosmjs/amino");
|
|
70
|
+
var crypto_1 = require("@cosmjs/crypto");
|
|
71
|
+
var crypto_2 = require("@cosmjs/crypto");
|
|
72
|
+
var utils_2 = require("@cosmjs/utils");
|
|
73
|
+
var encoding_2 = require("@cosmjs/encoding");
|
|
74
|
+
var amino_3 = require("@cosmjs/amino");
|
|
75
|
+
var FirmaUtil_1 = require("../../FirmaUtil");
|
|
76
|
+
function isMsgSignData(msg) {
|
|
77
|
+
var castedMsg = msg;
|
|
78
|
+
if (castedMsg.type !== "sign/MsgSignData")
|
|
79
|
+
return false;
|
|
80
|
+
if (!utils_1.isNonNullObject(castedMsg.value))
|
|
81
|
+
return false;
|
|
82
|
+
if (typeof castedMsg.value.signer !== "string")
|
|
83
|
+
return false;
|
|
84
|
+
if (typeof castedMsg.value.data !== "string")
|
|
85
|
+
return false;
|
|
86
|
+
return true;
|
|
87
|
+
}
|
|
88
|
+
exports.isMsgSignData = isMsgSignData;
|
|
89
|
+
var SigningAminoStargateClient = /** @class */ (function (_super) {
|
|
90
|
+
__extends(SigningAminoStargateClient, _super);
|
|
91
|
+
function SigningAminoStargateClient(tmClient, signer) {
|
|
92
|
+
var _this = _super.call(this, tmClient) || this;
|
|
93
|
+
_this.signer = signer;
|
|
94
|
+
return _this;
|
|
95
|
+
}
|
|
96
|
+
SigningAminoStargateClient.connectWithSigner = function (endpoint, signer, registry) {
|
|
97
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
98
|
+
var tmClient;
|
|
99
|
+
return __generator(this, function (_a) {
|
|
100
|
+
switch (_a.label) {
|
|
101
|
+
case 0:
|
|
102
|
+
this._endpoint = endpoint;
|
|
103
|
+
return [4 /*yield*/, tendermint_rpc_1.Tendermint34Client.connect(endpoint)];
|
|
104
|
+
case 1:
|
|
105
|
+
tmClient = _a.sent();
|
|
106
|
+
return [2 /*return*/, new SigningAminoStargateClient(tmClient, signer)];
|
|
107
|
+
}
|
|
108
|
+
});
|
|
109
|
+
});
|
|
110
|
+
};
|
|
111
|
+
SigningAminoStargateClient.prototype.experimentalAdr36Sign = function (signerAddress, data) {
|
|
112
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
113
|
+
var accountNumber, sequence, chainId, fee, memo, datas, msgs, accountFromSigner, signDoc, _a, signature, signed, signatureResult, decodeData, jsonData;
|
|
114
|
+
return __generator(this, function (_b) {
|
|
115
|
+
switch (_b.label) {
|
|
116
|
+
case 0:
|
|
117
|
+
accountNumber = 0;
|
|
118
|
+
sequence = 0;
|
|
119
|
+
chainId = "";
|
|
120
|
+
fee = {
|
|
121
|
+
gas: "0",
|
|
122
|
+
amount: [],
|
|
123
|
+
//granter: "" // added by DH
|
|
124
|
+
};
|
|
125
|
+
memo = "";
|
|
126
|
+
datas = Array.isArray(data) ? data : [data];
|
|
127
|
+
msgs = datas.map(function (d) { return ({
|
|
128
|
+
type: "sign/MsgSignData",
|
|
129
|
+
value: {
|
|
130
|
+
signer: signerAddress,
|
|
131
|
+
data: encoding_1.toBase64(d),
|
|
132
|
+
},
|
|
133
|
+
}); });
|
|
134
|
+
return [4 /*yield*/, this.signer.getAccounts()];
|
|
135
|
+
case 1:
|
|
136
|
+
accountFromSigner = (_b.sent()).find(function (account) { return account.address === signerAddress; });
|
|
137
|
+
if (!accountFromSigner) {
|
|
138
|
+
throw new Error("Failed to retrieve account from signer");
|
|
139
|
+
}
|
|
140
|
+
signDoc = amino_1.makeSignDoc(msgs, fee, chainId, memo, accountNumber, sequence);
|
|
141
|
+
return [4 /*yield*/, this.signer.signAmino(signerAddress, signDoc)];
|
|
142
|
+
case 2:
|
|
143
|
+
_a = _b.sent(), signature = _a.signature, signed = _a.signed;
|
|
144
|
+
if (!fast_deep_equal_1.default(signDoc, signed)) {
|
|
145
|
+
throw new Error("The signed document differs from the signing instruction. This is not supported for ADR-036.");
|
|
146
|
+
}
|
|
147
|
+
signatureResult = tx_1.makeStdTx(signDoc, signature);
|
|
148
|
+
decodeData = amino_1.decodeSignature(signatureResult.signatures[0]);
|
|
149
|
+
jsonData = {
|
|
150
|
+
type: "sign/MsgSignData",
|
|
151
|
+
signer: signatureResult.msg[0].value.signer,
|
|
152
|
+
data: signatureResult.msg[0].value.data,
|
|
153
|
+
pubkey: FirmaUtil_1.FirmaUtil.arrayBufferToBase64(decodeData.pubkey),
|
|
154
|
+
signature: FirmaUtil_1.FirmaUtil.arrayBufferToBase64(decodeData.signature)
|
|
155
|
+
};
|
|
156
|
+
return [2 /*return*/, jsonData];
|
|
157
|
+
}
|
|
158
|
+
});
|
|
159
|
+
});
|
|
160
|
+
};
|
|
161
|
+
SigningAminoStargateClient.experimentalAdr36Verify = function (data, checkMsg) {
|
|
162
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
163
|
+
var newSignature, signed, accountNumber, sequence, chainId, signedMessages, sourceMsg, signatures, signature, signBytes, prehashed, secpSignature, rawSecp256k1Pubkey, rawSignerAddress, ok;
|
|
164
|
+
return __generator(this, function (_a) {
|
|
165
|
+
switch (_a.label) {
|
|
166
|
+
case 0:
|
|
167
|
+
newSignature = amino_1.encodeSecp256k1Signature(FirmaUtil_1.FirmaUtil.base64ToArrayBuffer(data.pubkey), FirmaUtil_1.FirmaUtil.base64ToArrayBuffer(data.signature));
|
|
168
|
+
signed = {
|
|
169
|
+
fee: {
|
|
170
|
+
gas: "0",
|
|
171
|
+
amount: [],
|
|
172
|
+
},
|
|
173
|
+
msg: [{
|
|
174
|
+
type: data.type,
|
|
175
|
+
value: { signer: data.signer, data: data.data }
|
|
176
|
+
}],
|
|
177
|
+
signatures: [newSignature],
|
|
178
|
+
memo: ""
|
|
179
|
+
};
|
|
180
|
+
// Restrictions from ADR-036
|
|
181
|
+
if (signed.memo !== "")
|
|
182
|
+
throw new Error("Memo must be empty.");
|
|
183
|
+
if (signed.fee.gas !== "0")
|
|
184
|
+
throw new Error("Fee gas must 0.");
|
|
185
|
+
if (signed.fee.amount.length !== 0)
|
|
186
|
+
throw new Error("Fee amount must be an empty array.");
|
|
187
|
+
accountNumber = 0;
|
|
188
|
+
sequence = 0;
|
|
189
|
+
chainId = "";
|
|
190
|
+
signedMessages = signed.msg;
|
|
191
|
+
if (!signedMessages.every(isMsgSignData)) {
|
|
192
|
+
throw new Error("Found message that is not the expected type.");
|
|
193
|
+
}
|
|
194
|
+
if (signedMessages.length === 0) {
|
|
195
|
+
throw new Error("No message found. Without messages we cannot determine the signer address.");
|
|
196
|
+
}
|
|
197
|
+
sourceMsg = Buffer.from(signedMessages[0].value.data, 'base64').toString();
|
|
198
|
+
if (sourceMsg !== checkMsg) {
|
|
199
|
+
throw new Error("Different Msg error. source:" + sourceMsg + ", target:" + checkMsg);
|
|
200
|
+
}
|
|
201
|
+
signatures = signed.signatures;
|
|
202
|
+
if (signatures.length !== 1)
|
|
203
|
+
throw new Error("Must have exactly one signature to be supported.");
|
|
204
|
+
signature = signatures[0];
|
|
205
|
+
if (!amino_2.isSecp256k1Pubkey(signature.pub_key)) {
|
|
206
|
+
throw new Error("Only secp256k1 signatures are supported.");
|
|
207
|
+
}
|
|
208
|
+
signBytes = amino_2.serializeSignDoc(amino_1.makeSignDoc(signed.msg, signed.fee, chainId, signed.memo, accountNumber, sequence));
|
|
209
|
+
prehashed = crypto_1.sha256(signBytes);
|
|
210
|
+
secpSignature = crypto_2.Secp256k1Signature.fromFixedLength(encoding_2.fromBase64(signature.signature));
|
|
211
|
+
rawSecp256k1Pubkey = encoding_2.fromBase64(signature.pub_key.value);
|
|
212
|
+
rawSignerAddress = amino_3.rawSecp256k1PubkeyToRawAddress(rawSecp256k1Pubkey);
|
|
213
|
+
if (signedMessages.some(function (msg) { return !utils_2.arrayContentEquals(encoding_1.Bech32.decode(msg.value.signer).data, rawSignerAddress); })) {
|
|
214
|
+
throw new Error("Found mismatch between signer in message and public key");
|
|
215
|
+
}
|
|
216
|
+
return [4 /*yield*/, crypto_2.Secp256k1.verifySignature(secpSignature, prehashed, rawSecp256k1Pubkey)];
|
|
217
|
+
case 1:
|
|
218
|
+
ok = _a.sent();
|
|
219
|
+
return [2 /*return*/, ok];
|
|
220
|
+
}
|
|
221
|
+
});
|
|
222
|
+
});
|
|
223
|
+
};
|
|
224
|
+
/**
|
|
225
|
+
* Takes a bech32 encoded address and returns the data part. The prefix is ignored and discarded.
|
|
226
|
+
* This is called AccAddress in Cosmos SDK, which is basically an alias for raw binary data.
|
|
227
|
+
* The result is typically 20 bytes long but not restricted to that.
|
|
228
|
+
*/
|
|
229
|
+
SigningAminoStargateClient.prototype.toAccAddress = function (address) {
|
|
230
|
+
return encoding_1.Bech32.decode(address).data;
|
|
231
|
+
};
|
|
232
|
+
SigningAminoStargateClient.prototype.getAccount = function (address) {
|
|
233
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
234
|
+
var accAddress, hexAccAddress, axios, path, result, finalData, account, finalAccount, error_1;
|
|
235
|
+
return __generator(this, function (_a) {
|
|
236
|
+
switch (_a.label) {
|
|
237
|
+
case 0:
|
|
238
|
+
_a.trys.push([0, 2, , 3]);
|
|
239
|
+
accAddress = this.toAccAddress(address);
|
|
240
|
+
hexAccAddress = "0x01" + Buffer.from(accAddress).toString("hex");
|
|
241
|
+
axios = axios_1.default.create({
|
|
242
|
+
baseURL: SigningAminoStargateClient._endpoint,
|
|
243
|
+
headers: {
|
|
244
|
+
Accept: "application/json",
|
|
245
|
+
},
|
|
246
|
+
timeout: 15000
|
|
247
|
+
});
|
|
248
|
+
path = "/abci_query?path=\"/store/acc/key\"";
|
|
249
|
+
return [4 /*yield*/, axios.get(path, { params: { data: hexAccAddress } })];
|
|
250
|
+
case 1:
|
|
251
|
+
result = _a.sent();
|
|
252
|
+
finalData = result.data.result.response.value;
|
|
253
|
+
account = any_1.Any.decode(Buffer.from(finalData, "base64"));
|
|
254
|
+
finalAccount = accounts_1.accountFromAny(account);
|
|
255
|
+
return [2 /*return*/, finalAccount];
|
|
256
|
+
case 2:
|
|
257
|
+
error_1 = _a.sent();
|
|
258
|
+
return [2 /*return*/, undefined];
|
|
259
|
+
case 3: return [2 /*return*/];
|
|
260
|
+
}
|
|
261
|
+
});
|
|
262
|
+
});
|
|
263
|
+
};
|
|
264
|
+
SigningAminoStargateClient._endpoint = "";
|
|
265
|
+
return SigningAminoStargateClient;
|
|
266
|
+
}(stargateclient_1.StargateClient));
|
|
267
|
+
exports.SigningAminoStargateClient = SigningAminoStargateClient;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { EncodeObject, OfflineDirectSigner, Registry } from "@cosmjs/proto-signing";
|
|
2
2
|
import { Tendermint34Client } from "@cosmjs/tendermint-rpc";
|
|
3
|
-
import { TxRaw } from "cosmjs-types/cosmos/tx/v1beta1/tx";
|
|
3
|
+
import { SignDoc, TxRaw } from "cosmjs-types/cosmos/tx/v1beta1/tx";
|
|
4
4
|
import { StdFee } from ".";
|
|
5
5
|
import { Account } from "./accounts";
|
|
6
6
|
import { BroadcastTxResponse, StargateClient } from "./stargateclient";
|
|
@@ -13,14 +13,20 @@ export interface SequenceResponse {
|
|
|
13
13
|
readonly accountNumber: number;
|
|
14
14
|
readonly sequence: number;
|
|
15
15
|
}
|
|
16
|
+
export interface TxRawExt {
|
|
17
|
+
readonly txRaw: TxRaw;
|
|
18
|
+
readonly signature: string;
|
|
19
|
+
}
|
|
16
20
|
export declare class SigningStargateClient extends StargateClient {
|
|
17
21
|
private readonly signer;
|
|
18
22
|
private readonly registry;
|
|
19
23
|
private chainId;
|
|
20
24
|
private static _endpoint;
|
|
21
|
-
|
|
22
|
-
|
|
25
|
+
private getSigner;
|
|
26
|
+
static connectWithSigner(endpoint: string, signer: OfflineDirectSigner | undefined, registry: Registry): Promise<SigningStargateClient>;
|
|
27
|
+
protected constructor(tmClient: Tendermint34Client | undefined, signer: OfflineDirectSigner | undefined, registry: Registry);
|
|
23
28
|
signAndBroadcast(signerAddress: string, messages: readonly EncodeObject[], fee: StdFee, memo?: string): Promise<BroadcastTxResponse>;
|
|
29
|
+
static makeSignDocForSend(signerAddress: string, messages: readonly EncodeObject[], fee: StdFee, memo: string, serverUrl: string, chainId: string, registry: Registry): Promise<SignDoc>;
|
|
24
30
|
sign(signerAddress: string, messages: readonly EncodeObject[], fee: StdFee, memo: string, explicitSignerData?: SignerData): Promise<TxRaw>;
|
|
25
31
|
getChainId(): Promise<string>;
|
|
26
32
|
/**
|
|
@@ -28,10 +34,11 @@ export declare class SigningStargateClient extends StargateClient {
|
|
|
28
34
|
* This is called AccAddress in Cosmos SDK, which is basically an alias for raw binary data.
|
|
29
35
|
* The result is typically 20 bytes long but not restricted to that.
|
|
30
36
|
*/
|
|
31
|
-
private toAccAddress;
|
|
32
|
-
getAccount(address: string): Promise<Account | undefined>;
|
|
33
|
-
getSequence(address: string): Promise<SequenceResponse>;
|
|
34
|
-
private makeSignerInfos;
|
|
35
|
-
private makeAuthInfoBytes;
|
|
37
|
+
private static toAccAddress;
|
|
38
|
+
static getAccount(address: string): Promise<Account | undefined>;
|
|
39
|
+
static getSequence(address: string): Promise<SequenceResponse>;
|
|
40
|
+
private static makeSignerInfos;
|
|
41
|
+
private static makeAuthInfoBytes;
|
|
36
42
|
private signDirect;
|
|
43
|
+
signDirectForSignDoc(signerAddress: string, signDoc: SignDoc): Promise<TxRawExt>;
|
|
37
44
|
}
|
|
@@ -97,6 +97,9 @@ var SigningStargateClient = /** @class */ (function (_super) {
|
|
|
97
97
|
_this.signer = signer;
|
|
98
98
|
return _this;
|
|
99
99
|
}
|
|
100
|
+
SigningStargateClient.prototype.getSigner = function () {
|
|
101
|
+
return this.signer;
|
|
102
|
+
};
|
|
100
103
|
SigningStargateClient.connectWithSigner = function (endpoint, signer, registry) {
|
|
101
104
|
return __awaiter(this, void 0, void 0, function () {
|
|
102
105
|
var tmClient;
|
|
@@ -127,6 +130,38 @@ var SigningStargateClient = /** @class */ (function (_super) {
|
|
|
127
130
|
});
|
|
128
131
|
});
|
|
129
132
|
};
|
|
133
|
+
SigningStargateClient.makeSignDocForSend = function (signerAddress, messages, fee, memo, serverUrl, chainId, registry) {
|
|
134
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
135
|
+
var _a, accountNumber, sequence, account, rawSecp256k1Pubkey, pubkey, txBodyEncodeObject, txBodyBytes, gasLimit, authInfoBytes;
|
|
136
|
+
return __generator(this, function (_b) {
|
|
137
|
+
switch (_b.label) {
|
|
138
|
+
case 0:
|
|
139
|
+
SigningStargateClient._endpoint = serverUrl;
|
|
140
|
+
return [4 /*yield*/, SigningStargateClient.getSequence(signerAddress)];
|
|
141
|
+
case 1:
|
|
142
|
+
_a = _b.sent(), accountNumber = _a.accountNumber, sequence = _a.sequence;
|
|
143
|
+
return [4 /*yield*/, SigningStargateClient.getAccount(signerAddress)];
|
|
144
|
+
case 2:
|
|
145
|
+
account = _b.sent();
|
|
146
|
+
if (account == null)
|
|
147
|
+
throw new Error("Failed to retrieve account from signer");
|
|
148
|
+
rawSecp256k1Pubkey = encoding_1.fromBase64(account.pubkey.value);
|
|
149
|
+
pubkey = proto_signing_1.encodePubkey(encoding_3.encodeSecp256k1Pubkey(rawSecp256k1Pubkey));
|
|
150
|
+
txBodyEncodeObject = {
|
|
151
|
+
typeUrl: "/cosmos.tx.v1beta1.TxBody",
|
|
152
|
+
value: {
|
|
153
|
+
messages: messages,
|
|
154
|
+
memo: memo,
|
|
155
|
+
},
|
|
156
|
+
};
|
|
157
|
+
txBodyBytes = registry.encode(txBodyEncodeObject);
|
|
158
|
+
gasLimit = math_1.Int53.fromString(fee.gas).toNumber();
|
|
159
|
+
authInfoBytes = this.makeAuthInfoBytes([{ pubkey: pubkey, sequence: sequence }], fee.amount, gasLimit, fee.granter);
|
|
160
|
+
return [2 /*return*/, proto_signing_1.makeSignDoc(txBodyBytes, authInfoBytes, chainId, accountNumber)];
|
|
161
|
+
}
|
|
162
|
+
});
|
|
163
|
+
});
|
|
164
|
+
};
|
|
130
165
|
SigningStargateClient.prototype.sign = function (signerAddress, messages, fee, memo, explicitSignerData) {
|
|
131
166
|
return __awaiter(this, void 0, void 0, function () {
|
|
132
167
|
var signerData, _a, accountNumber, sequence, chainId;
|
|
@@ -136,7 +171,7 @@ var SigningStargateClient = /** @class */ (function (_super) {
|
|
|
136
171
|
if (!explicitSignerData) return [3 /*break*/, 1];
|
|
137
172
|
signerData = explicitSignerData;
|
|
138
173
|
return [3 /*break*/, 4];
|
|
139
|
-
case 1: return [4 /*yield*/,
|
|
174
|
+
case 1: return [4 /*yield*/, SigningStargateClient.getSequence(signerAddress)];
|
|
140
175
|
case 2:
|
|
141
176
|
_a = _b.sent(), accountNumber = _a.accountNumber, sequence = _a.sequence;
|
|
142
177
|
return [4 /*yield*/, this.getChainId()];
|
|
@@ -178,10 +213,10 @@ var SigningStargateClient = /** @class */ (function (_super) {
|
|
|
178
213
|
* This is called AccAddress in Cosmos SDK, which is basically an alias for raw binary data.
|
|
179
214
|
* The result is typically 20 bytes long but not restricted to that.
|
|
180
215
|
*/
|
|
181
|
-
SigningStargateClient.
|
|
216
|
+
SigningStargateClient.toAccAddress = function (address) {
|
|
182
217
|
return encoding_2.Bech32.decode(address).data;
|
|
183
218
|
};
|
|
184
|
-
SigningStargateClient.
|
|
219
|
+
SigningStargateClient.getAccount = function (address) {
|
|
185
220
|
return __awaiter(this, void 0, void 0, function () {
|
|
186
221
|
var accAddress, hexAccAddress, axios, path, result, finalData, account, finalAccount, error_1;
|
|
187
222
|
return __generator(this, function (_a) {
|
|
@@ -213,7 +248,7 @@ var SigningStargateClient = /** @class */ (function (_super) {
|
|
|
213
248
|
});
|
|
214
249
|
});
|
|
215
250
|
};
|
|
216
|
-
SigningStargateClient.
|
|
251
|
+
SigningStargateClient.getSequence = function (address) {
|
|
217
252
|
return __awaiter(this, void 0, void 0, function () {
|
|
218
253
|
var account;
|
|
219
254
|
return __generator(this, function (_a) {
|
|
@@ -232,7 +267,7 @@ var SigningStargateClient = /** @class */ (function (_super) {
|
|
|
232
267
|
});
|
|
233
268
|
});
|
|
234
269
|
};
|
|
235
|
-
SigningStargateClient.
|
|
270
|
+
SigningStargateClient.makeSignerInfos = function (signers, signMode) {
|
|
236
271
|
return signers.map(function (_a) {
|
|
237
272
|
var pubkey = _a.pubkey, sequence = _a.sequence;
|
|
238
273
|
return ({
|
|
@@ -244,7 +279,7 @@ var SigningStargateClient = /** @class */ (function (_super) {
|
|
|
244
279
|
});
|
|
245
280
|
});
|
|
246
281
|
};
|
|
247
|
-
SigningStargateClient.
|
|
282
|
+
SigningStargateClient.makeAuthInfoBytes = function (signers, feeAmount, gasLimit, granter, signMode) {
|
|
248
283
|
if (signMode === void 0) { signMode = signing_1.SignMode.SIGN_MODE_DIRECT; }
|
|
249
284
|
var authInfo = {
|
|
250
285
|
signerInfos: this.makeSignerInfos(signers, signMode),
|
|
@@ -262,7 +297,7 @@ var SigningStargateClient = /** @class */ (function (_super) {
|
|
|
262
297
|
var accountFromSigner, pubkey, txBodyEncodeObject, txBodyBytes, gasLimit, authInfoBytes, signDoc, _b, signature, signed;
|
|
263
298
|
return __generator(this, function (_c) {
|
|
264
299
|
switch (_c.label) {
|
|
265
|
-
case 0: return [4 /*yield*/, this.
|
|
300
|
+
case 0: return [4 /*yield*/, this.getSigner().getAccounts()];
|
|
266
301
|
case 1:
|
|
267
302
|
accountFromSigner = (_c.sent()).find(function (account) { return account.address === signerAddress; });
|
|
268
303
|
if (!accountFromSigner) {
|
|
@@ -278,9 +313,9 @@ var SigningStargateClient = /** @class */ (function (_super) {
|
|
|
278
313
|
};
|
|
279
314
|
txBodyBytes = this.registry.encode(txBodyEncodeObject);
|
|
280
315
|
gasLimit = math_1.Int53.fromString(fee.gas).toNumber();
|
|
281
|
-
authInfoBytes =
|
|
316
|
+
authInfoBytes = SigningStargateClient.makeAuthInfoBytes([{ pubkey: pubkey, sequence: sequence }], fee.amount, gasLimit, fee.granter);
|
|
282
317
|
signDoc = proto_signing_1.makeSignDoc(txBodyBytes, authInfoBytes, chainId, accountNumber);
|
|
283
|
-
return [4 /*yield*/, this.
|
|
318
|
+
return [4 /*yield*/, this.getSigner().signDirect(signerAddress, signDoc)];
|
|
284
319
|
case 2:
|
|
285
320
|
_b = _c.sent(), signature = _b.signature, signed = _b.signed;
|
|
286
321
|
return [2 /*return*/, tx_1.TxRaw.fromPartial({
|
|
@@ -292,6 +327,30 @@ var SigningStargateClient = /** @class */ (function (_super) {
|
|
|
292
327
|
});
|
|
293
328
|
});
|
|
294
329
|
};
|
|
330
|
+
SigningStargateClient.prototype.signDirectForSignDoc = function (signerAddress, signDoc) {
|
|
331
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
332
|
+
var accountFromSigner, _a, signature, signed, txRaw;
|
|
333
|
+
return __generator(this, function (_b) {
|
|
334
|
+
switch (_b.label) {
|
|
335
|
+
case 0: return [4 /*yield*/, this.getSigner().getAccounts()];
|
|
336
|
+
case 1:
|
|
337
|
+
accountFromSigner = (_b.sent()).find(function (account) { return account.address === signerAddress; });
|
|
338
|
+
if (!accountFromSigner) {
|
|
339
|
+
throw new Error("Failed to retrieve account from signer");
|
|
340
|
+
}
|
|
341
|
+
return [4 /*yield*/, this.getSigner().signDirect(signerAddress, signDoc)];
|
|
342
|
+
case 2:
|
|
343
|
+
_a = _b.sent(), signature = _a.signature, signed = _a.signed;
|
|
344
|
+
txRaw = tx_1.TxRaw.fromPartial({
|
|
345
|
+
bodyBytes: signed.bodyBytes,
|
|
346
|
+
authInfoBytes: signed.authInfoBytes,
|
|
347
|
+
signatures: [encoding_1.fromBase64(signature.signature)],
|
|
348
|
+
});
|
|
349
|
+
return [2 /*return*/, { txRaw: txRaw, signature: signature.signature }];
|
|
350
|
+
}
|
|
351
|
+
});
|
|
352
|
+
});
|
|
353
|
+
};
|
|
295
354
|
SigningStargateClient._endpoint = "";
|
|
296
355
|
return SigningStargateClient;
|
|
297
356
|
}(stargateclient_1.StargateClient));
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { EncodeObject } from "@cosmjs/proto-signing";
|
|
1
|
+
import { Registry, EncodeObject } from "@cosmjs/proto-signing";
|
|
2
2
|
import { MsgCreateContractFile, MsgAddContractLog } from "./ContractTxTypes";
|
|
3
3
|
import { ITxClient } from "../common/ITxClient";
|
|
4
4
|
import { FirmaWalletService } from "../../FirmaWalletService";
|
|
@@ -12,6 +12,7 @@ export interface MsgCreateContractFileEncodeObject extends EncodeObject {
|
|
|
12
12
|
}
|
|
13
13
|
export declare class ContractTxClient extends ITxClient {
|
|
14
14
|
constructor(wallet: FirmaWalletService, serverUrl: string);
|
|
15
|
-
|
|
16
|
-
|
|
15
|
+
static getRegistry(): Registry;
|
|
16
|
+
static msgAddContractLog(data: MsgAddContractLog): MsgAddContractLogEncodeObject;
|
|
17
|
+
static msgCreateContractFile(data: MsgCreateContractFile): MsgCreateContractFileEncodeObject;
|
|
17
18
|
}
|
|
@@ -29,10 +29,13 @@ var ContractTxClient = /** @class */ (function (_super) {
|
|
|
29
29
|
function ContractTxClient(wallet, serverUrl) {
|
|
30
30
|
return _super.call(this, wallet, serverUrl, registry) || this;
|
|
31
31
|
}
|
|
32
|
-
ContractTxClient.
|
|
32
|
+
ContractTxClient.getRegistry = function () {
|
|
33
|
+
return registry;
|
|
34
|
+
};
|
|
35
|
+
ContractTxClient.msgAddContractLog = function (data) {
|
|
33
36
|
return { typeUrl: "/firmachain.firmachain.contract.MsgAddContractLog", value: data };
|
|
34
37
|
};
|
|
35
|
-
ContractTxClient.
|
|
38
|
+
ContractTxClient.msgCreateContractFile = function (data) {
|
|
36
39
|
return { typeUrl: "/firmachain.firmachain.contract.MsgCreateContractFile", value: data };
|
|
37
40
|
};
|
|
38
41
|
return ContractTxClient;
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
export interface CodeInfo {
|
|
2
|
+
code_id: string;
|
|
3
|
+
creator: string;
|
|
4
|
+
data_hash: string;
|
|
5
|
+
}
|
|
6
|
+
export interface CodeData {
|
|
7
|
+
code_info: CodeInfo;
|
|
8
|
+
data: string;
|
|
9
|
+
}
|
|
10
|
+
export interface ContractInfo {
|
|
11
|
+
address: string;
|
|
12
|
+
contract_info: {
|
|
13
|
+
code_id: string;
|
|
14
|
+
creator: string;
|
|
15
|
+
admin: string;
|
|
16
|
+
label: string;
|
|
17
|
+
created: {
|
|
18
|
+
block_height: string;
|
|
19
|
+
tx_index: string;
|
|
20
|
+
};
|
|
21
|
+
ibc_port_id: string;
|
|
22
|
+
extension: {
|
|
23
|
+
"@type": string;
|
|
24
|
+
};
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
export interface ContractHistoryInfo {
|
|
28
|
+
operation: string;
|
|
29
|
+
code_id: string;
|
|
30
|
+
updated: {
|
|
31
|
+
block_height: string;
|
|
32
|
+
tx_index: string;
|
|
33
|
+
};
|
|
34
|
+
msg: string;
|
|
35
|
+
}
|
|
36
|
+
export interface ContractStateInfo {
|
|
37
|
+
key: string;
|
|
38
|
+
value: string;
|
|
39
|
+
}
|
|
40
|
+
export declare class CosmWasmQueryClient {
|
|
41
|
+
private readonly axios;
|
|
42
|
+
constructor(baseUrl: string);
|
|
43
|
+
getCodeInfoList(): Promise<CodeInfo[]>;
|
|
44
|
+
getCodeData(codeId: string): Promise<CodeData>;
|
|
45
|
+
getContractListFromCodeId(codeId: string): Promise<string[]>;
|
|
46
|
+
getContractInfo(contractAddress: string): Promise<ContractInfo>;
|
|
47
|
+
getContractHistory(contractAddress: string): Promise<ContractHistoryInfo[]>;
|
|
48
|
+
getContractRawQueryData(contractAddress: string, hexString: string): Promise<string>;
|
|
49
|
+
getContractSmartQueryData(contractAddress: string, query: string): Promise<string>;
|
|
50
|
+
getContractState(contractAddress: string): Promise<ContractStateInfo[]>;
|
|
51
|
+
getPinnedCodeList(): Promise<string[]>;
|
|
52
|
+
}
|