@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.
Files changed (75) hide show
  1. package/dist/sdk/FirmaAuthzService.d.ts +41 -0
  2. package/dist/sdk/FirmaAuthzService.js +633 -0
  3. package/dist/sdk/FirmaBankService.d.ts +2 -1
  4. package/dist/sdk/FirmaBankService.js +4 -1
  5. package/dist/sdk/FirmaContractService.js +10 -12
  6. package/dist/sdk/FirmaCosmWasmService.d.ts +38 -0
  7. package/dist/sdk/FirmaCosmWasmService.js +667 -0
  8. package/dist/sdk/FirmaDistributionService.d.ts +2 -1
  9. package/dist/sdk/FirmaDistributionService.js +8 -5
  10. package/dist/sdk/FirmaFeeGrantService.js +3 -3
  11. package/dist/sdk/FirmaGovService.js +19 -19
  12. package/dist/sdk/FirmaIbcService.d.ts +15 -0
  13. package/dist/sdk/FirmaIbcService.js +144 -0
  14. package/dist/sdk/FirmaMobileSDK.d.ts +3 -1
  15. package/dist/sdk/FirmaMobileSDK.js +4 -1
  16. package/dist/sdk/FirmaNftService.js +6 -6
  17. package/dist/sdk/FirmaSDK.d.ts +7 -1
  18. package/dist/sdk/FirmaSDK.js +10 -1
  19. package/dist/sdk/FirmaStakingService.d.ts +18 -5
  20. package/dist/sdk/FirmaStakingService.js +20 -13
  21. package/dist/sdk/FirmaTokenService.js +12 -12
  22. package/dist/sdk/FirmaUtil.d.ts +18 -1
  23. package/dist/sdk/FirmaUtil.js +193 -0
  24. package/dist/sdk/FirmaWalletService.d.ts +3 -0
  25. package/dist/sdk/FirmaWalletService.js +18 -10
  26. package/dist/sdk/firmachain/amino/signer.d.ts +1 -2
  27. package/dist/sdk/firmachain/authz/AuthzQueryClient.d.ts +48 -0
  28. package/dist/sdk/firmachain/authz/AuthzQueryClient.js +142 -0
  29. package/dist/sdk/firmachain/authz/AuthzTxClient.d.ts +23 -0
  30. package/dist/sdk/firmachain/authz/AuthzTxClient.js +47 -0
  31. package/dist/sdk/firmachain/authz/AuthzTxTypes.d.ts +147 -0
  32. package/dist/sdk/firmachain/authz/AuthzTxTypes.js +358 -0
  33. package/dist/sdk/firmachain/authz/index.d.ts +3 -0
  34. package/dist/sdk/firmachain/authz/index.js +15 -0
  35. package/dist/sdk/firmachain/bank/BankTxClient.d.ts +4 -3
  36. package/dist/sdk/firmachain/bank/BankTxClient.js +5 -2
  37. package/dist/sdk/firmachain/common/ITxClient.d.ts +4 -1
  38. package/dist/sdk/firmachain/common/ITxClient.js +15 -0
  39. package/dist/sdk/firmachain/common/signingaminostargateclient.d.ts +50 -0
  40. package/dist/sdk/firmachain/common/signingaminostargateclient.js +267 -0
  41. package/dist/sdk/firmachain/common/signingstargateclient.d.ts +15 -8
  42. package/dist/sdk/firmachain/common/signingstargateclient.js +68 -9
  43. package/dist/sdk/firmachain/contract/ContractTxClient.d.ts +4 -3
  44. package/dist/sdk/firmachain/contract/ContractTxClient.js +5 -2
  45. package/dist/sdk/firmachain/cosmwasm/CosmWasmQueryClient.d.ts +52 -0
  46. package/dist/sdk/firmachain/cosmwasm/CosmWasmQueryClient.js +193 -0
  47. package/dist/sdk/firmachain/cosmwasm/CosmWasmTxClient.d.ts +38 -0
  48. package/dist/sdk/firmachain/cosmwasm/CosmWasmTxClient.js +59 -0
  49. package/dist/sdk/firmachain/cosmwasm/index.d.ts +3 -0
  50. package/dist/sdk/firmachain/cosmwasm/index.js +15 -0
  51. package/dist/sdk/firmachain/distribution/DistributionTxClient.d.ts +6 -5
  52. package/dist/sdk/firmachain/distribution/DistributionTxClient.js +7 -4
  53. package/dist/sdk/firmachain/feegrant/FeeGrantTxClient.d.ts +4 -3
  54. package/dist/sdk/firmachain/feegrant/FeeGrantTxClient.js +5 -2
  55. package/dist/sdk/firmachain/gov/GovTxClient.d.ts +5 -4
  56. package/dist/sdk/firmachain/gov/GovTxClient.js +6 -3
  57. package/dist/sdk/firmachain/ibc/IbcQueryClient.d.ts +34 -0
  58. package/dist/sdk/firmachain/ibc/IbcQueryClient.js +71 -0
  59. package/dist/sdk/firmachain/ibc/IbcTxClient.d.ts +13 -0
  60. package/dist/sdk/firmachain/ibc/IbcTxClient.js +39 -0
  61. package/dist/sdk/firmachain/ibc/index.d.ts +3 -0
  62. package/dist/sdk/firmachain/ibc/index.js +15 -0
  63. package/dist/sdk/firmachain/nft/NftTxClient.d.ts +5 -4
  64. package/dist/sdk/firmachain/nft/NftTxClient.js +6 -3
  65. package/dist/sdk/firmachain/staking/StakingQueryClient.d.ts +17 -4
  66. package/dist/sdk/firmachain/staking/StakingQueryClient.js +38 -18
  67. package/dist/sdk/firmachain/staking/StakingTxClient.d.ts +7 -6
  68. package/dist/sdk/firmachain/staking/StakingTxClient.js +8 -5
  69. package/dist/sdk/firmachain/token/TokenTxClient.d.ts +6 -5
  70. package/dist/sdk/firmachain/token/TokenTxClient.js +7 -4
  71. package/package.json +3 -1
  72. package/dist/sdk/firmachain/amino/secp256k1hdwallet.d.ts +0 -94
  73. package/dist/sdk/firmachain/amino/secp256k1hdwallet.js +0 -437
  74. package/dist/sdk/firmachain/amino/secp256k1wallet.d.ts +0 -23
  75. 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
- static connectWithSigner(endpoint: string, signer: OfflineDirectSigner, registry: Registry): Promise<SigningStargateClient>;
22
- protected constructor(tmClient: Tendermint34Client | undefined, signer: OfflineDirectSigner, registry: Registry);
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*/, this.getSequence(signerAddress)];
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.prototype.toAccAddress = function (address) {
216
+ SigningStargateClient.toAccAddress = function (address) {
182
217
  return encoding_2.Bech32.decode(address).data;
183
218
  };
184
- SigningStargateClient.prototype.getAccount = function (address) {
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.prototype.getSequence = function (address) {
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.prototype.makeSignerInfos = function (signers, signMode) {
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.prototype.makeAuthInfoBytes = function (signers, feeAmount, gasLimit, granter, signMode) {
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.signer.getAccounts()];
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 = this.makeAuthInfoBytes([{ pubkey: pubkey, sequence: sequence }], fee.amount, gasLimit, fee.granter);
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.signer.signDirect(signerAddress, signDoc)];
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
- msgAddContractLog(data: MsgAddContractLog): MsgAddContractLogEncodeObject;
16
- msgCreateContractFile(data: MsgCreateContractFile): MsgCreateContractFileEncodeObject;
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.prototype.msgAddContractLog = function (data) {
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.prototype.msgCreateContractFile = function (data) {
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
+ }