Socket
Socket
Sign inDemoInstall

deso-protocol

Package Overview
Dependencies
52
Maintainers
4
Versions
213
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

Comparing version 2.6.8-beta.1 to 2.6.8-beta.2

2

package.json
{
"name": "deso-protocol",
"version": "2.6.8-beta.1",
"version": "2.6.8-beta.2",
"license": "MIT",

@@ -5,0 +5,0 @@ "description": "Client side typescript/javascript SDK for building web3 applications for the DeSo blockchain.",

@@ -39,3 +39,5 @@ import { KeyPair, Network, jwtAlgorithm } from './types.js';

export declare const decryptChatMessage: (recipientSeedHex: string, publicDecryptionKey: string, cipherTextHex: string) => Promise<string>;
export declare const decrypt: (privateDecryptionKey: Uint8Array | string, cipherTextHex: string) => Promise<string>;
export declare const decrypt: (privateDecryptionKey: Uint8Array | string, hexString: string, { retrying }?: {
retrying?: boolean | undefined;
}) => Promise<string>;
export declare const getSharedPrivateKey: (privKey: Uint8Array, pubKey: Uint8Array) => Uint8Array;

@@ -42,0 +44,0 @@ export declare const decodePublicKey: (publicKeyBase58Check: string) => Promise<Uint8Array>;

@@ -264,18 +264,27 @@ import { sha256 } from '@noble/hashes/sha256';

};
export const decrypt = async (privateDecryptionKey, cipherTextHex) => {
const cipherBytes = ecUtils.hexToBytes(cipherTextHex);
export const decrypt = async (privateDecryptionKey, hexString, { retrying = false } = {}) => {
const bytes = ecUtils.hexToBytes(hexString);
const metaLength = 113;
if (cipherBytes.length < metaLength) {
if (bytes.length < metaLength) {
throw new Error('invalid cipher text. data too small.');
}
if (!(cipherBytes[0] >= 2 && cipherBytes[0] <= 4)) {
throw new Error('invalid cipher text.');
if (!(bytes[0] >= 2 && bytes[0] <= 4)) {
// this could be a case where the hex string has been double encoded...
// so we try decoding and calling again. If it fails again, we just throw.
if (!retrying) {
return decrypt(privateDecryptionKey, new TextDecoder().decode(bytes), {
retrying: true,
});
}
else {
throw new Error('invalid cipher text.');
}
}
const privateKey = normalizeSeed(privateDecryptionKey);
const ephemPublicKey = cipherBytes.slice(0, 65);
const cipherTextLength = cipherBytes.length - metaLength;
const iv = cipherBytes.slice(65, 65 + 16);
const cipherAndIv = cipherBytes.slice(65, 65 + 16 + cipherTextLength);
const ephemPublicKey = bytes.slice(0, 65);
const cipherTextLength = bytes.length - metaLength;
const counter = bytes.slice(65, 65 + 16);
const cipherAndIv = bytes.slice(65, 65 + 16 + cipherTextLength);
const cipherText = cipherAndIv.slice(16);
const msgMac = cipherBytes.slice(65 + 16 + cipherTextLength);
const msgMac = bytes.slice(65 + 16 + cipherTextLength);
const sharedSecretKey = await getSharedPrivateKey(privateKey, ephemPublicKey);

@@ -289,3 +298,3 @@ const encryptionKey = sharedSecretKey.slice(0, 16);

const cryptoKey = await globalThis.crypto.subtle.importKey('raw', encryptionKey, 'AES-CTR', true, ['decrypt']);
const decryptedBuffer = await globalThis.crypto.subtle.decrypt({ name: 'AES-CTR', counter: iv, length: 128 }, cryptoKey, cipherText);
const decryptedBuffer = await globalThis.crypto.subtle.decrypt({ name: 'AES-CTR', counter, length: 128 }, cryptoKey, cipherText);
return new TextDecoder().decode(decryptedBuffer);

@@ -363,2 +372,2 @@ };

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"crypto-utils.js","sourceRoot":"","sources":["../../../src/identity/crypto-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { sha256 } from '@noble/hashes/sha256';\nimport {\n  Point,\n  sign as ecSign,\n  utils as ecUtils,\n  getPublicKey,\n  getSharedSecret as nobleGetSharedSecret,\n} from '@noble/secp256k1';\nimport bs58 from 'bs58';\nimport { PUBLIC_KEY_PREFIXES } from './constants.js';\nimport { TransactionV0 } from './transaction-transcoders.js';\nimport { KeyPair, Network, jwtAlgorithm } from './types.js';\n\n// Browser friendly version of node's Buffer.concat.\nexport function concatUint8Arrays(arrays: Uint8Array[], length?: number) {\n  if (length === undefined) {\n    length = arrays.reduce((acc, array) => acc + array.length, 0);\n  }\n  const result = new Uint8Array(length);\n  let offset = 0;\n  for (let i = 0; i < arrays.length; i++) {\n    if (offset + arrays[i].length > length) {\n      result.set(arrays[i].slice(0, length - offset), offset);\n      break;\n    }\n    result.set(arrays[i], offset);\n    offset += arrays[i].length;\n  }\n  return result;\n}\n\nexport const uvarint64ToBuf = (uint: number): Uint8Array => {\n  const result: number[] = [];\n  while (uint >= 0x80) {\n    result.push(Number((BigInt(uint) & BigInt(0xff)) | BigInt(0x80)));\n    uint = Number(BigInt(uint) >> BigInt(7));\n  }\n  result.push(uint | 0);\n\n  return new Uint8Array(result);\n};\n\nexport const bufToUvarint64 = (buffer: Uint8Array): [number, Uint8Array] => {\n  let x = BigInt(0);\n  let s = BigInt(0);\n\n  // TODO: fix linting error\n  // eslint-disable-next-line no-constant-condition\n  for (let i = 0; true; i++) {\n    const byte = buffer[i];\n\n    if (i > 9 || (i == 9 && byte > 1)) {\n      throw new Error('uint64 overflow');\n    }\n\n    if (byte < 0x80) {\n      return [\n        Number(BigInt(x) | (BigInt(byte) << BigInt(s))),\n        buffer.slice(i + 1),\n      ];\n    }\n\n    x |= BigInt(byte & 0x7f) << BigInt(s);\n    s += BigInt(7);\n  }\n};\n\nexport const uint64ToBufBigEndian = (uint: number) => {\n  const result = [];\n  while (BigInt(uint) >= BigInt(0xff)) {\n    result.push(Number(BigInt(uint) & BigInt(0xff)));\n    uint = Number(BigInt(uint) >> BigInt(8));\n  }\n  result.push(Number(BigInt(uint) | BigInt(0)));\n  while (result.length < 8) {\n    result.push(0);\n  }\n  return new Uint8Array(result.reverse());\n};\n\nexport const varint64ToBuf = (int: number) => {\n  let ux = BigInt(int) << BigInt(1);\n  if (int < 0) {\n    ux = ~ux;\n  }\n  return uvarint64ToBuf(Number(ux));\n};\n\nexport const bufToVarint64 = (buffer: Uint8Array): [number, Uint8Array] => {\n  const [ux, n] = bufToUvarint64(buffer);\n  let x = BigInt(ux) >> BigInt(1);\n  if (ux & 1) {\n    x = ~x;\n  }\n  return [Number(x), n];\n};\n\ninterface Base58CheckOptions {\n  network: Network;\n}\n\n// We are not using the native web crypto API to actually generate keys\n// because it does not support the secp256k1 curve. Instead, we are using\n// https://github.com/paulmillr/noble-secp256k1 which is a browser friendly\n// alternative to the node elliptic package which is far smaller and only\n// focuses on supporting the ec algorithm we are actually interested in here.\n// If the web crypto API ever adds support for secp256k1, we should change\n// this to use it.\n//\n// See the following for more info:\n// https://github.com/w3c/webcrypto/issues/82\n//\n// If you don't provide a seed, a random one will be generated for you and a\n// random key pair will be returned. If you do provide a seed, it should be a\n// randomly generated 32 byte value (Uint8Array of length 32 or hex string of\n// length 64)\nexport const keygen = (seed?: string | Uint8Array): KeyPair => {\n  const privateKey = seed ? normalizeSeed(seed) : ecUtils.randomBytes(32);\n  const seedHex = ecUtils.bytesToHex(privateKey);\n\n  return {\n    seedHex,\n    private: privateKey,\n    public: getPublicKey(privateKey, true /* isCompressed */),\n  };\n};\n\nconst normalizeSeed = (seed: string | Uint8Array): Uint8Array => {\n  if (typeof seed === 'string') {\n    return ecUtils.hexToBytes(seed);\n  } else {\n    return seed;\n  }\n};\n\n/**\n *\n * @param data could be a hex string or a byte array (Uint8Array)\n * @returns\n */\nexport const sha256X2 = (data: Uint8Array | string): Uint8Array => {\n  const d = typeof data === 'string' ? ecUtils.hexToBytes(data) : data;\n  return sha256(sha256(d));\n};\n\nexport const publicKeyToBase58Check = (\n  publicKeyBytes: Uint8Array,\n  options?: Base58CheckOptions\n): string => {\n  const prefix = PUBLIC_KEY_PREFIXES[options?.network ?? 'mainnet'].deso;\n  // This is the same as the implementation in the bs58check package, but we\n  // slightly modify it to use the browser friendly version of Buffer.concat.\n  // See: https://github.com/bitcoinjs/bs58check/blob/12b3e700f355c5c49d0be3f8fc29be6c66e753e9/base.js#L1\n  const bytes = new Uint8Array([...prefix, ...publicKeyBytes]);\n  const checksum = sha256X2(bytes);\n  return bs58.encode(concatUint8Arrays([bytes, checksum], bytes.length + 4));\n};\n\nexport interface SignOptions {\n  isDerivedKey: boolean;\n}\n\nexport const sign = (msgHashHex: string, privateKey: Uint8Array) => {\n  return ecSign(msgHashHex, privateKey, {\n    // For details about the signing options see: https://github.com/paulmillr/noble-secp256k1#signmsghash-privatekey\n    canonical: true,\n    der: true,\n    extraEntropy: true,\n    recovered: true,\n  });\n};\n\nexport const signTx = async (\n  txHex: string,\n  seedHex: string,\n  options?: SignOptions\n): Promise<string> => {\n  const transactionBytes = ecUtils.hexToBytes(txHex);\n  const [_, v1FieldsBuffer] = TransactionV0.fromBytes(transactionBytes);\n  const signatureIndex = transactionBytes.length - v1FieldsBuffer.length - 1;\n  const v0FieldsWithoutSignature = transactionBytes.slice(0, signatureIndex);\n  const hashedTxBytes = sha256X2(transactionBytes);\n  const transactionHashHex = ecUtils.bytesToHex(hashedTxBytes);\n  const privateKey = ecUtils.hexToBytes(seedHex);\n  const [signatureBytes, recoveryParam] = await sign(\n    transactionHashHex,\n    privateKey\n  );\n\n  const signatureLength = uvarint64ToBuf(signatureBytes.length);\n\n  if (options?.isDerivedKey) {\n    signatureBytes[0] += 1 + recoveryParam;\n  }\n\n  const signedTransactionBytes = ecUtils.concatBytes(\n    v0FieldsWithoutSignature,\n    signatureLength,\n    signatureBytes,\n    v1FieldsBuffer\n  );\n\n  return ecUtils.bytesToHex(signedTransactionBytes);\n};\n\nexport const getSignedJWT = async (\n  seedHex: string,\n  alg: jwtAlgorithm,\n  {\n    derivedPublicKeyBase58Check,\n    // TODO: actually support this... or remove it.\n    expiration,\n  }: {\n    derivedPublicKeyBase58Check?: string;\n    expiration?: number;\n  }\n): Promise<string> => {\n  const header = JSON.stringify({ alg, typ: 'JWT' });\n  const issuedAt = Math.floor(Date.now() / 1000);\n  const thirtyMinFromNow = issuedAt + 30 * 60;\n  const payload = JSON.stringify({\n    ...(derivedPublicKeyBase58Check ? { derivedPublicKeyBase58Check } : {}),\n    iat: issuedAt,\n    exp: thirtyMinFromNow,\n  });\n\n  const jwt = `${urlSafeBase64(header)}.${urlSafeBase64(payload)}`;\n  const [signature] = await sign(\n    ecUtils.bytesToHex(sha256(new Uint8Array(new TextEncoder().encode(jwt)))),\n    ecUtils.hexToBytes(seedHex)\n  );\n  const encodedSignature = derToJoseEncoding(signature);\n\n  return `${jwt}.${encodedSignature}`;\n};\n\nfunction urlSafeBase64(str: string) {\n  return window\n    .btoa(str)\n    .replace(/\\+/g, '-')\n    .replace(/\\//g, '_')\n    .replace(/=/g, '');\n}\n\nexport const encryptChatMessage = (\n  senderSeedHex: string,\n  recipientPublicKeyBase58Check: string,\n  message: string\n) => {\n  const privateKey = ecUtils.hexToBytes(senderSeedHex);\n  const recipientPublicKey = bs58PublicKeyToBytes(\n    recipientPublicKeyBase58Check\n  );\n  const sharedPrivateKey = getSharedPrivateKey(privateKey, recipientPublicKey);\n  const sharedPublicKey = getPublicKey(sharedPrivateKey);\n\n  return encrypt(sharedPublicKey, message);\n};\n\n/**\n * @param publicEncryptionKey could be in raw bytes or base58check format\n * @param plaintext\n * @returns cipher text as a hex string\n */\nexport const encrypt = async (\n  publicKey: Uint8Array | string,\n  plaintext: string\n): Promise<string> => {\n  const ephemPrivateKey = ecUtils.randomBytes(32);\n  const ephemPublicKey = getPublicKey(ephemPrivateKey);\n  const publicKeyBytes =\n    typeof publicKey === 'string' ? bs58PublicKeyToBytes(publicKey) : publicKey;\n  const privKey = getSharedPrivateKey(ephemPrivateKey, publicKeyBytes);\n  const encryptionKey = privKey.slice(0, 16);\n  const iv = ecUtils.randomBytes(16);\n  const macKey = sha256(privKey.slice(16));\n  const bytes = new TextEncoder().encode(plaintext);\n  const cryptoKey = await globalThis.crypto.subtle.importKey(\n    'raw',\n    encryptionKey,\n    'AES-CTR',\n    true,\n    ['encrypt']\n  );\n  const cipherBytes = await globalThis.crypto.subtle.encrypt(\n    {\n      name: 'AES-CTR',\n      counter: iv,\n      length: 128,\n    },\n    cryptoKey,\n    bytes\n  );\n  const hmac = await ecUtils.hmacSha256(\n    macKey,\n    new Uint8Array([...iv, ...new Uint8Array(cipherBytes)])\n  );\n\n  return ecUtils.bytesToHex(\n    new Uint8Array([\n      ...ephemPublicKey,\n      ...iv,\n      ...new Uint8Array(cipherBytes),\n      ...hmac,\n    ])\n  );\n};\n\nexport const bs58PublicKeyToCompressedBytes = (str: string) => {\n  if (!str) {\n    return new Uint8Array(33);\n  }\n  const pubKeyUncompressed = bs58PublicKeyToBytes(str);\n  return Point.fromHex(ecUtils.bytesToHex(pubKeyUncompressed)).toRawBytes(true);\n};\n\nexport const bs58PublicKeyToBytes = (str: string) => {\n  const bytes = bs58.decode(str);\n  const payload = bytes.slice(0, -4);\n  const checksumA = bytes.slice(-4);\n  const checksumB = sha256X2(payload);\n\n  if (\n    (checksumA[0] ^ checksumB[0]) |\n    (checksumA[1] ^ checksumB[1]) |\n    (checksumA[2] ^ checksumB[2]) |\n    (checksumA[3] ^ checksumB[3])\n  ) {\n    throw new Error('Invalid checksum');\n  }\n\n  return Point.fromHex(ecUtils.bytesToHex(payload.slice(3))).toRawBytes(false);\n};\n\nconst regexMainnet = /^BC[1-9A-HJ-NP-Za-km-z]{53}$/;\nconst regexTestnet = /^tBC[1-9A-HJ-NP-Za-km-z]{51}$/;\n\nexport const isValidBS58PublicKey = (publicKey: string, isTestnet = false) => {\n  const regexPattern = isTestnet ? regexTestnet : regexMainnet;\n  if (!regexPattern.test(publicKey)) {\n    return false;\n  }\n  try {\n    bs58PublicKeyToBytes(publicKey);\n    return true;\n  } catch (e) {\n    return false;\n  }\n};\n\nconst isValidHmac = (candidate: Uint8Array, knownGood: Uint8Array) => {\n  if (candidate.length !== knownGood.length) {\n    return false;\n  }\n\n  for (let i = 0; i < knownGood.length; i++) {\n    if (candidate[i] !== knownGood[i]) {\n      return false;\n    }\n  }\n\n  return true;\n};\n\nexport const decryptChatMessage = async (\n  recipientSeedHex: string,\n  publicDecryptionKey: string,\n  cipherTextHex: string\n) => {\n  const privateKey = ecUtils.hexToBytes(recipientSeedHex);\n  const publicKey = await bs58PublicKeyToBytes(publicDecryptionKey);\n  const sharedPrivateKey = await getSharedPrivateKey(privateKey, publicKey);\n  return decrypt(sharedPrivateKey, cipherTextHex);\n};\n\nexport const decrypt = async (\n  privateDecryptionKey: Uint8Array | string,\n  cipherTextHex: string\n) => {\n  const cipherBytes = ecUtils.hexToBytes(cipherTextHex);\n  const metaLength = 113;\n\n  if (cipherBytes.length < metaLength) {\n    throw new Error('invalid cipher text. data too small.');\n  }\n\n  if (!(cipherBytes[0] >= 2 && cipherBytes[0] <= 4)) {\n    throw new Error('invalid cipher text.');\n  }\n\n  const privateKey = normalizeSeed(privateDecryptionKey);\n  const ephemPublicKey = cipherBytes.slice(0, 65);\n  const cipherTextLength = cipherBytes.length - metaLength;\n  const iv = cipherBytes.slice(65, 65 + 16);\n  const cipherAndIv = cipherBytes.slice(65, 65 + 16 + cipherTextLength);\n  const cipherText = cipherAndIv.slice(16);\n  const msgMac = cipherBytes.slice(65 + 16 + cipherTextLength);\n  const sharedSecretKey = await getSharedPrivateKey(privateKey, ephemPublicKey);\n  const encryptionKey = sharedSecretKey.slice(0, 16);\n  const macKey = sha256(sharedSecretKey.slice(16));\n  const hmacKnownGood = await ecUtils.hmacSha256(macKey, cipherAndIv);\n\n  if (!isValidHmac(msgMac, hmacKnownGood)) {\n    throw new Error('incorrect MAC');\n  }\n\n  const cryptoKey = await globalThis.crypto.subtle.importKey(\n    'raw',\n    encryptionKey,\n    'AES-CTR',\n    true,\n    ['decrypt']\n  );\n\n  const decryptedBuffer = await globalThis.crypto.subtle.decrypt(\n    { name: 'AES-CTR', counter: iv, length: 128 },\n    cryptoKey,\n    cipherText\n  );\n\n  return new TextDecoder().decode(decryptedBuffer);\n};\n\nexport const getSharedPrivateKey = (\n  privKey: Uint8Array,\n  pubKey: Uint8Array\n) => {\n  const sharedSecret = getSharedSecret(privKey, pubKey);\n\n  return kdf(sharedSecret, 32);\n};\n\nexport const decodePublicKey = async (publicKeyBase58Check: string) => {\n  const decoded = await bs58PublicKeyToBytes(publicKeyBase58Check);\n  const withPrefixRemoved = decoded.slice(3);\n  const senderPubKeyHex = ecUtils.bytesToHex(withPrefixRemoved);\n\n  return Point.fromHex(senderPubKeyHex).toRawBytes(false);\n};\n\nexport const getSharedSecret = (privKey: Uint8Array, pubKey: Uint8Array) => {\n  // passing true to compress the public key, and then slicing off the first byte\n  // matches the implementation of derive in the elliptic package.\n  // https://github.com/paulmillr/noble-secp256k1/issues/28#issuecomment-946538037\n  return nobleGetSharedSecret(privKey, pubKey, true).slice(1);\n};\n\n// taken from reference implementation in the deso chat app:\n// https://github.com/deso-protocol/access-group-messaging-app/blob/cd5c237f5e5729196aac0da161d0851bde78092c/src/services/crypto-utils.service.tsx#L91\nexport const kdf = (secret: Uint8Array, outputLength: number) => {\n  let ctr = 1;\n  let written = 0;\n  let result = new Uint8Array();\n\n  while (written < outputLength) {\n    const hash = sha256(\n      new Uint8Array([\n        ...new Uint8Array([ctr >> 24, ctr >> 16, ctr >> 8, ctr]),\n        ...secret,\n      ])\n    );\n    result = new Uint8Array([...result, ...hash]);\n    written += 32;\n    ctr += 1;\n  }\n\n  return result;\n};\n\n// This is a modified version of the derToJose function from\n// https://github.com/Brightspace/node-ecdsa-sig-formatter/blob/ca25a2fd5ae9dd85036081632936e802a47a1289/src/ecdsa-sig-formatter.js#L32\n// The original package is not browser friendly and requires node polyfills. We\n// also don't need to be quite as defensive as the original package since we\n// have full control of the input.\nfunction derToJoseEncoding(signature: Uint8Array) {\n  const paramBytes = 32;\n\n  let offset = 3;\n  const rLength = signature[offset];\n  offset += 1;\n  const rOffset = offset;\n  offset += rLength + 1;\n  const sLength = signature[offset];\n  offset += 1;\n  const sOffset = offset;\n  offset += sLength;\n\n  const rPadding = paramBytes - rLength;\n  const sPadding = paramBytes - sLength;\n\n  const outPut = new Uint8Array(rPadding + rLength + sPadding + sLength);\n\n  for (offset = 0; offset < rPadding; ++offset) {\n    outPut[offset] = 0;\n  }\n\n  outPut.set(\n    signature.slice(rOffset + Math.max(-rPadding, 0), rOffset + rLength),\n    offset\n  );\n\n  offset = paramBytes;\n\n  for (const o = offset; offset < o + sPadding; ++offset) {\n    outPut[offset] = 0;\n  }\n\n  outPut.set(\n    signature.slice(sOffset + Math.max(-sPadding, 0), sOffset + sLength),\n    offset\n  );\n\n  const outputChars = outPut.reduce(\n    (data, byte) => data + String.fromCharCode(byte),\n    ''\n  );\n\n  return urlSafeBase64(outputChars);\n}\n\nexport function deriveAccessGroupKeyPair(\n  privateKeyHex: string,\n  groupKeyName: string\n): KeyPair {\n  const secretHash = sha256X2(privateKeyHex);\n  const keyNameHash = sha256X2(new TextEncoder().encode(groupKeyName));\n  const privateKey = sha256X2(new Uint8Array([...secretHash, ...keyNameHash]));\n\n  return keygen(privateKey);\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"crypto-utils.js","sourceRoot":"","sources":["../../../src/identity/crypto-utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AAC9C,OAAO,EACL,KAAK,EACL,IAAI,IAAI,MAAM,EACd,KAAK,IAAI,OAAO,EAChB,YAAY,EACZ,eAAe,IAAI,oBAAoB,GACxC,MAAM,kBAAkB,CAAC;AAC1B,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AACrD,OAAO,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAG7D,oDAAoD;AACpD,MAAM,UAAU,iBAAiB,CAAC,MAAoB,EAAE,MAAe;IACrE,IAAI,MAAM,KAAK,SAAS,EAAE;QACxB,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,CAAC,GAAG,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;KAC/D;IACD,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC,MAAM,CAAC,CAAC;IACtC,IAAI,MAAM,GAAG,CAAC,CAAC;IACf,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QACtC,IAAI,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,MAAM,EAAE;YACtC,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC,EAAE,MAAM,CAAC,CAAC;YACxD,MAAM;SACP;QACD,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC;QAC9B,MAAM,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;KAC5B;IACD,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,IAAY,EAAc,EAAE;IACzD,MAAM,MAAM,GAAa,EAAE,CAAC;IAC5B,OAAO,IAAI,IAAI,IAAI,EAAE;QACnB,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAClE,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;KAC1C;IACD,MAAM,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC;IAEtB,OAAO,IAAI,UAAU,CAAC,MAAM,CAAC,CAAC;AAChC,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,MAAkB,EAAwB,EAAE;IACzE,IAAI,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;IAClB,IAAI,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;IAElB,0BAA0B;IAC1B,iDAAiD;IACjD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,EAAE;QACzB,MAAM,IAAI,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAEvB,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,IAAI,GAAG,CAAC,CAAC,EAAE;YACjC,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC;SACpC;QAED,IAAI,IAAI,GAAG,IAAI,EAAE;YACf,OAAO;gBACL,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;gBAC/C,MAAM,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC;aACpB,CAAC;SACH;QAED,CAAC,IAAI,MAAM,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC;QACtC,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC;KAChB;AACH,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAAC,IAAY,EAAE,EAAE;IACnD,MAAM,MAAM,GAAG,EAAE,CAAC;IAClB,OAAO,MAAM,CAAC,IAAI,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,EAAE;QACnC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACjD,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;KAC1C;IACD,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC9C,OAAO,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE;QACxB,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;KAChB;IACD,OAAO,IAAI,UAAU,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC;AAC1C,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,GAAW,EAAE,EAAE;IAC3C,IAAI,EAAE,GAAG,MAAM,CAAC,GAAG,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC;IAClC,IAAI,GAAG,GAAG,CAAC,EAAE;QACX,EAAE,GAAG,CAAC,EAAE,CAAC;KACV;IACD,OAAO,cAAc,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;AACpC,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,MAAkB,EAAwB,EAAE;IACxE,MAAM,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC;IACvC,IAAI,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC;IAChC,IAAI,EAAE,GAAG,CAAC,EAAE;QACV,CAAC,GAAG,CAAC,CAAC,CAAC;KACR;IACD,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;AACxB,CAAC,CAAC;AAMF,uEAAuE;AACvE,yEAAyE;AACzE,2EAA2E;AAC3E,yEAAyE;AACzE,6EAA6E;AAC7E,0EAA0E;AAC1E,kBAAkB;AAClB,EAAE;AACF,mCAAmC;AACnC,6CAA6C;AAC7C,EAAE;AACF,4EAA4E;AAC5E,6EAA6E;AAC7E,6EAA6E;AAC7E,aAAa;AACb,MAAM,CAAC,MAAM,MAAM,GAAG,CAAC,IAA0B,EAAW,EAAE;IAC5D,MAAM,UAAU,GAAG,IAAI,CAAC,CAAC,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;IACxE,MAAM,OAAO,GAAG,OAAO,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;IAE/C,OAAO;QACL,OAAO;QACP,OAAO,EAAE,UAAU;QACnB,MAAM,EAAE,YAAY,CAAC,UAAU,EAAE,IAAI,CAAC,kBAAkB,CAAC;KAC1D,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,aAAa,GAAG,CAAC,IAAyB,EAAc,EAAE;IAC9D,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE;QAC5B,OAAO,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;KACjC;SAAM;QACL,OAAO,IAAI,CAAC;KACb;AACH,CAAC,CAAC;AAEF;;;;GAIG;AACH,MAAM,CAAC,MAAM,QAAQ,GAAG,CAAC,IAAyB,EAAc,EAAE;IAChE,MAAM,CAAC,GAAG,OAAO,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACrE,OAAO,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAC3B,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,sBAAsB,GAAG,CACpC,cAA0B,EAC1B,OAA4B,EACpB,EAAE;IACV,MAAM,MAAM,GAAG,mBAAmB,CAAC,OAAO,EAAE,OAAO,IAAI,SAAS,CAAC,CAAC,IAAI,CAAC;IACvE,0EAA0E;IAC1E,2EAA2E;IAC3E,uGAAuG;IACvG,MAAM,KAAK,GAAG,IAAI,UAAU,CAAC,CAAC,GAAG,MAAM,EAAE,GAAG,cAAc,CAAC,CAAC,CAAC;IAC7D,MAAM,QAAQ,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IACjC,OAAO,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC,KAAK,EAAE,QAAQ,CAAC,EAAE,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC;AAC7E,CAAC,CAAC;AAMF,MAAM,CAAC,MAAM,IAAI,GAAG,CAAC,UAAkB,EAAE,UAAsB,EAAE,EAAE;IACjE,OAAO,MAAM,CAAC,UAAU,EAAE,UAAU,EAAE;QACpC,iHAAiH;QACjH,SAAS,EAAE,IAAI;QACf,GAAG,EAAE,IAAI;QACT,YAAY,EAAE,IAAI;QAClB,SAAS,EAAE,IAAI;KAChB,CAAC,CAAC;AACL,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,MAAM,GAAG,KAAK,EACzB,KAAa,EACb,OAAe,EACf,OAAqB,EACJ,EAAE;IACnB,MAAM,gBAAgB,GAAG,OAAO,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;IACnD,MAAM,CAAC,CAAC,EAAE,cAAc,CAAC,GAAG,aAAa,CAAC,SAAS,CAAC,gBAAgB,CAAC,CAAC;IACtE,MAAM,cAAc,GAAG,gBAAgB,CAAC,MAAM,GAAG,cAAc,CAAC,MAAM,GAAG,CAAC,CAAC;IAC3E,MAAM,wBAAwB,GAAG,gBAAgB,CAAC,KAAK,CAAC,CAAC,EAAE,cAAc,CAAC,CAAC;IAC3E,MAAM,aAAa,GAAG,QAAQ,CAAC,gBAAgB,CAAC,CAAC;IACjD,MAAM,kBAAkB,GAAG,OAAO,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;IAC7D,MAAM,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;IAC/C,MAAM,CAAC,cAAc,EAAE,aAAa,CAAC,GAAG,MAAM,IAAI,CAChD,kBAAkB,EAClB,UAAU,CACX,CAAC;IAEF,MAAM,eAAe,GAAG,cAAc,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;IAE9D,IAAI,OAAO,EAAE,YAAY,EAAE;QACzB,cAAc,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,aAAa,CAAC;KACxC;IAED,MAAM,sBAAsB,GAAG,OAAO,CAAC,WAAW,CAChD,wBAAwB,EACxB,eAAe,EACf,cAAc,EACd,cAAc,CACf,CAAC;IAEF,OAAO,OAAO,CAAC,UAAU,CAAC,sBAAsB,CAAC,CAAC;AACpD,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,YAAY,GAAG,KAAK,EAC/B,OAAe,EACf,GAAiB,EACjB,EACE,2BAA2B;AAC3B,+CAA+C;AAC/C,UAAU,GAIX,EACgB,EAAE;IACnB,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC,CAAC;IACnD,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC;IAC/C,MAAM,gBAAgB,GAAG,QAAQ,GAAG,EAAE,GAAG,EAAE,CAAC;IAC5C,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC;QAC7B,GAAG,CAAC,2BAA2B,CAAC,CAAC,CAAC,EAAE,2BAA2B,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QACvE,GAAG,EAAE,QAAQ;QACb,GAAG,EAAE,gBAAgB;KACtB,CAAC,CAAC;IAEH,MAAM,GAAG,GAAG,GAAG,aAAa,CAAC,MAAM,CAAC,IAAI,aAAa,CAAC,OAAO,CAAC,EAAE,CAAC;IACjE,MAAM,CAAC,SAAS,CAAC,GAAG,MAAM,IAAI,CAC5B,OAAO,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,UAAU,CAAC,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EACzE,OAAO,CAAC,UAAU,CAAC,OAAO,CAAC,CAC5B,CAAC;IACF,MAAM,gBAAgB,GAAG,iBAAiB,CAAC,SAAS,CAAC,CAAC;IAEtD,OAAO,GAAG,GAAG,IAAI,gBAAgB,EAAE,CAAC;AACtC,CAAC,CAAC;AAEF,SAAS,aAAa,CAAC,GAAW;IAChC,OAAO,MAAM;SACV,IAAI,CAAC,GAAG,CAAC;SACT,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC;SACnB,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC;SACnB,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;AACvB,CAAC;AAED,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAChC,aAAqB,EACrB,6BAAqC,EACrC,OAAe,EACf,EAAE;IACF,MAAM,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;IACrD,MAAM,kBAAkB,GAAG,oBAAoB,CAC7C,6BAA6B,CAC9B,CAAC;IACF,MAAM,gBAAgB,GAAG,mBAAmB,CAAC,UAAU,EAAE,kBAAkB,CAAC,CAAC;IAC7E,MAAM,eAAe,GAAG,YAAY,CAAC,gBAAgB,CAAC,CAAC;IAEvD,OAAO,OAAO,CAAC,eAAe,EAAE,OAAO,CAAC,CAAC;AAC3C,CAAC,CAAC;AAEF;;;;GAIG;AACH,MAAM,CAAC,MAAM,OAAO,GAAG,KAAK,EAC1B,SAA8B,EAC9B,SAAiB,EACA,EAAE;IACnB,MAAM,eAAe,GAAG,OAAO,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;IAChD,MAAM,cAAc,GAAG,YAAY,CAAC,eAAe,CAAC,CAAC;IACrD,MAAM,cAAc,GAClB,OAAO,SAAS,KAAK,QAAQ,CAAC,CAAC,CAAC,oBAAoB,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;IAC9E,MAAM,OAAO,GAAG,mBAAmB,CAAC,eAAe,EAAE,cAAc,CAAC,CAAC;IACrE,MAAM,aAAa,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IAC3C,MAAM,EAAE,GAAG,OAAO,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;IACnC,MAAM,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;IACzC,MAAM,KAAK,GAAG,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;IAClD,MAAM,SAAS,GAAG,MAAM,UAAU,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CACxD,KAAK,EACL,aAAa,EACb,SAAS,EACT,IAAI,EACJ,CAAC,SAAS,CAAC,CACZ,CAAC;IACF,MAAM,WAAW,GAAG,MAAM,UAAU,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CACxD;QACE,IAAI,EAAE,SAAS;QACf,OAAO,EAAE,EAAE;QACX,MAAM,EAAE,GAAG;KACZ,EACD,SAAS,EACT,KAAK,CACN,CAAC;IACF,MAAM,IAAI,GAAG,MAAM,OAAO,CAAC,UAAU,CACnC,MAAM,EACN,IAAI,UAAU,CAAC,CAAC,GAAG,EAAE,EAAE,GAAG,IAAI,UAAU,CAAC,WAAW,CAAC,CAAC,CAAC,CACxD,CAAC;IAEF,OAAO,OAAO,CAAC,UAAU,CACvB,IAAI,UAAU,CAAC;QACb,GAAG,cAAc;QACjB,GAAG,EAAE;QACL,GAAG,IAAI,UAAU,CAAC,WAAW,CAAC;QAC9B,GAAG,IAAI;KACR,CAAC,CACH,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,8BAA8B,GAAG,CAAC,GAAW,EAAE,EAAE;IAC5D,IAAI,CAAC,GAAG,EAAE;QACR,OAAO,IAAI,UAAU,CAAC,EAAE,CAAC,CAAC;KAC3B;IACD,MAAM,kBAAkB,GAAG,oBAAoB,CAAC,GAAG,CAAC,CAAC;IACrD,OAAO,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,UAAU,CAAC,kBAAkB,CAAC,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;AAChF,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAAC,GAAW,EAAE,EAAE;IAClD,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;IAC/B,MAAM,OAAO,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IACnC,MAAM,SAAS,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IAClC,MAAM,SAAS,GAAG,QAAQ,CAAC,OAAO,CAAC,CAAC;IAEpC,IACE,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;QAC7B,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;QAC7B,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;QAC7B,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC,EAC7B;QACA,MAAM,IAAI,KAAK,CAAC,kBAAkB,CAAC,CAAC;KACrC;IAED,OAAO,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;AAC/E,CAAC,CAAC;AAEF,MAAM,YAAY,GAAG,8BAA8B,CAAC;AACpD,MAAM,YAAY,GAAG,+BAA+B,CAAC;AAErD,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAAC,SAAiB,EAAE,SAAS,GAAG,KAAK,EAAE,EAAE;IAC3E,MAAM,YAAY,GAAG,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,YAAY,CAAC;IAC7D,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE;QACjC,OAAO,KAAK,CAAC;KACd;IACD,IAAI;QACF,oBAAoB,CAAC,SAAS,CAAC,CAAC;QAChC,OAAO,IAAI,CAAC;KACb;IAAC,OAAO,CAAC,EAAE;QACV,OAAO,KAAK,CAAC;KACd;AACH,CAAC,CAAC;AAEF,MAAM,WAAW,GAAG,CAAC,SAAqB,EAAE,SAAqB,EAAE,EAAE;IACnE,IAAI,SAAS,CAAC,MAAM,KAAK,SAAS,CAAC,MAAM,EAAE;QACzC,OAAO,KAAK,CAAC;KACd;IAED,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QACzC,IAAI,SAAS,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE;YACjC,OAAO,KAAK,CAAC;SACd;KACF;IAED,OAAO,IAAI,CAAC;AACd,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,kBAAkB,GAAG,KAAK,EACrC,gBAAwB,EACxB,mBAA2B,EAC3B,aAAqB,EACrB,EAAE;IACF,MAAM,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC,gBAAgB,CAAC,CAAC;IACxD,MAAM,SAAS,GAAG,MAAM,oBAAoB,CAAC,mBAAmB,CAAC,CAAC;IAClE,MAAM,gBAAgB,GAAG,MAAM,mBAAmB,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC;IAC1E,OAAO,OAAO,CAAC,gBAAgB,EAAE,aAAa,CAAC,CAAC;AAClD,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,OAAO,GAAG,KAAK,EAC1B,oBAAyC,EACzC,SAAiB,EACjB,EAAE,QAAQ,GAAG,KAAK,EAAE,GAAG,EAAE,EACR,EAAE;IACnB,MAAM,KAAK,GAAG,OAAO,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;IAC5C,MAAM,UAAU,GAAG,GAAG,CAAC;IAEvB,IAAI,KAAK,CAAC,MAAM,GAAG,UAAU,EAAE;QAC7B,MAAM,IAAI,KAAK,CAAC,sCAAsC,CAAC,CAAC;KACzD;IAED,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE;QACrC,uEAAuE;QACvE,0EAA0E;QAC1E,IAAI,CAAC,QAAQ,EAAE;YACb,OAAO,OAAO,CAAC,oBAAoB,EAAE,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE;gBACpE,QAAQ,EAAE,IAAI;aACf,CAAC,CAAC;SACJ;aAAM;YACL,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAC;SACzC;KACF;IAED,MAAM,UAAU,GAAG,aAAa,CAAC,oBAAoB,CAAC,CAAC;IACvD,MAAM,cAAc,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IAC1C,MAAM,gBAAgB,GAAG,KAAK,CAAC,MAAM,GAAG,UAAU,CAAC;IACnD,MAAM,OAAO,GAAG,KAAK,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC;IACzC,MAAM,WAAW,GAAG,KAAK,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,gBAAgB,CAAC,CAAC;IAChE,MAAM,UAAU,GAAG,WAAW,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;IACzC,MAAM,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,EAAE,GAAG,EAAE,GAAG,gBAAgB,CAAC,CAAC;IACvD,MAAM,eAAe,GAAG,MAAM,mBAAmB,CAAC,UAAU,EAAE,cAAc,CAAC,CAAC;IAC9E,MAAM,aAAa,GAAG,eAAe,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IACnD,MAAM,MAAM,GAAG,MAAM,CAAC,eAAe,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;IACjD,MAAM,aAAa,GAAG,MAAM,OAAO,CAAC,UAAU,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;IAEpE,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,aAAa,CAAC,EAAE;QACvC,MAAM,IAAI,KAAK,CAAC,eAAe,CAAC,CAAC;KAClC;IAED,MAAM,SAAS,GAAG,MAAM,UAAU,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CACxD,KAAK,EACL,aAAa,EACb,SAAS,EACT,IAAI,EACJ,CAAC,SAAS,CAAC,CACZ,CAAC;IAEF,MAAM,eAAe,GAAG,MAAM,UAAU,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAC5D,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,EACzC,SAAS,EACT,UAAU,CACX,CAAC;IAEF,OAAO,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;AACnD,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,mBAAmB,GAAG,CACjC,OAAmB,EACnB,MAAkB,EAClB,EAAE;IACF,MAAM,YAAY,GAAG,eAAe,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;IAEtD,OAAO,GAAG,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC;AAC/B,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,eAAe,GAAG,KAAK,EAAE,oBAA4B,EAAE,EAAE;IACpE,MAAM,OAAO,GAAG,MAAM,oBAAoB,CAAC,oBAAoB,CAAC,CAAC;IACjE,MAAM,iBAAiB,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAC3C,MAAM,eAAe,GAAG,OAAO,CAAC,UAAU,CAAC,iBAAiB,CAAC,CAAC;IAE9D,OAAO,KAAK,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;AAC1D,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,OAAmB,EAAE,MAAkB,EAAE,EAAE;IACzE,+EAA+E;IAC/E,gEAAgE;IAChE,gFAAgF;IAChF,OAAO,oBAAoB,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;AAC9D,CAAC,CAAC;AAEF,4DAA4D;AAC5D,sJAAsJ;AACtJ,MAAM,CAAC,MAAM,GAAG,GAAG,CAAC,MAAkB,EAAE,YAAoB,EAAE,EAAE;IAC9D,IAAI,GAAG,GAAG,CAAC,CAAC;IACZ,IAAI,OAAO,GAAG,CAAC,CAAC;IAChB,IAAI,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;IAE9B,OAAO,OAAO,GAAG,YAAY,EAAE;QAC7B,MAAM,IAAI,GAAG,MAAM,CACjB,IAAI,UAAU,CAAC;YACb,GAAG,IAAI,UAAU,CAAC,CAAC,GAAG,IAAI,EAAE,EAAE,GAAG,IAAI,EAAE,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC;YACxD,GAAG,MAAM;SACV,CAAC,CACH,CAAC;QACF,MAAM,GAAG,IAAI,UAAU,CAAC,CAAC,GAAG,MAAM,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC;QAC9C,OAAO,IAAI,EAAE,CAAC;QACd,GAAG,IAAI,CAAC,CAAC;KACV;IAED,OAAO,MAAM,CAAC;AAChB,CAAC,CAAC;AAEF,4DAA4D;AAC5D,uIAAuI;AACvI,+EAA+E;AAC/E,4EAA4E;AAC5E,kCAAkC;AAClC,SAAS,iBAAiB,CAAC,SAAqB;IAC9C,MAAM,UAAU,GAAG,EAAE,CAAC;IAEtB,IAAI,MAAM,GAAG,CAAC,CAAC;IACf,MAAM,OAAO,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC;IAClC,MAAM,IAAI,CAAC,CAAC;IACZ,MAAM,OAAO,GAAG,MAAM,CAAC;IACvB,MAAM,IAAI,OAAO,GAAG,CAAC,CAAC;IACtB,MAAM,OAAO,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC;IAClC,MAAM,IAAI,CAAC,CAAC;IACZ,MAAM,OAAO,GAAG,MAAM,CAAC;IACvB,MAAM,IAAI,OAAO,CAAC;IAElB,MAAM,QAAQ,GAAG,UAAU,GAAG,OAAO,CAAC;IACtC,MAAM,QAAQ,GAAG,UAAU,GAAG,OAAO,CAAC;IAEtC,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC,QAAQ,GAAG,OAAO,GAAG,QAAQ,GAAG,OAAO,CAAC,CAAC;IAEvE,KAAK,MAAM,GAAG,CAAC,EAAE,MAAM,GAAG,QAAQ,EAAE,EAAE,MAAM,EAAE;QAC5C,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;KACpB;IAED,MAAM,CAAC,GAAG,CACR,SAAS,CAAC,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,EACpE,MAAM,CACP,CAAC;IAEF,MAAM,GAAG,UAAU,CAAC;IAEpB,KAAK,MAAM,CAAC,GAAG,MAAM,EAAE,MAAM,GAAG,CAAC,GAAG,QAAQ,EAAE,EAAE,MAAM,EAAE;QACtD,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;KACpB;IAED,MAAM,CAAC,GAAG,CACR,SAAS,CAAC,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,EACpE,MAAM,CACP,CAAC;IAEF,MAAM,WAAW,GAAG,MAAM,CAAC,MAAM,CAC/B,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,CAAC,IAAI,GAAG,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,EAChD,EAAE,CACH,CAAC;IAEF,OAAO,aAAa,CAAC,WAAW,CAAC,CAAC;AACpC,CAAC;AAED,MAAM,UAAU,wBAAwB,CACtC,aAAqB,EACrB,YAAoB;IAEpB,MAAM,UAAU,GAAG,QAAQ,CAAC,aAAa,CAAC,CAAC;IAC3C,MAAM,WAAW,GAAG,QAAQ,CAAC,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC;IACrE,MAAM,UAAU,GAAG,QAAQ,CAAC,IAAI,UAAU,CAAC,CAAC,GAAG,UAAU,EAAE,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC;IAE7E,OAAO,MAAM,CAAC,UAAU,CAAC,CAAC;AAC5B,CAAC","sourcesContent":["import { sha256 } from '@noble/hashes/sha256';\nimport {\n  Point,\n  sign as ecSign,\n  utils as ecUtils,\n  getPublicKey,\n  getSharedSecret as nobleGetSharedSecret,\n} from '@noble/secp256k1';\nimport bs58 from 'bs58';\nimport { PUBLIC_KEY_PREFIXES } from './constants.js';\nimport { TransactionV0 } from './transaction-transcoders.js';\nimport { KeyPair, Network, jwtAlgorithm } from './types.js';\n\n// Browser friendly version of node's Buffer.concat.\nexport function concatUint8Arrays(arrays: Uint8Array[], length?: number) {\n  if (length === undefined) {\n    length = arrays.reduce((acc, array) => acc + array.length, 0);\n  }\n  const result = new Uint8Array(length);\n  let offset = 0;\n  for (let i = 0; i < arrays.length; i++) {\n    if (offset + arrays[i].length > length) {\n      result.set(arrays[i].slice(0, length - offset), offset);\n      break;\n    }\n    result.set(arrays[i], offset);\n    offset += arrays[i].length;\n  }\n  return result;\n}\n\nexport const uvarint64ToBuf = (uint: number): Uint8Array => {\n  const result: number[] = [];\n  while (uint >= 0x80) {\n    result.push(Number((BigInt(uint) & BigInt(0xff)) | BigInt(0x80)));\n    uint = Number(BigInt(uint) >> BigInt(7));\n  }\n  result.push(uint | 0);\n\n  return new Uint8Array(result);\n};\n\nexport const bufToUvarint64 = (buffer: Uint8Array): [number, Uint8Array] => {\n  let x = BigInt(0);\n  let s = BigInt(0);\n\n  // TODO: fix linting error\n  // eslint-disable-next-line no-constant-condition\n  for (let i = 0; true; i++) {\n    const byte = buffer[i];\n\n    if (i > 9 || (i == 9 && byte > 1)) {\n      throw new Error('uint64 overflow');\n    }\n\n    if (byte < 0x80) {\n      return [\n        Number(BigInt(x) | (BigInt(byte) << BigInt(s))),\n        buffer.slice(i + 1),\n      ];\n    }\n\n    x |= BigInt(byte & 0x7f) << BigInt(s);\n    s += BigInt(7);\n  }\n};\n\nexport const uint64ToBufBigEndian = (uint: number) => {\n  const result = [];\n  while (BigInt(uint) >= BigInt(0xff)) {\n    result.push(Number(BigInt(uint) & BigInt(0xff)));\n    uint = Number(BigInt(uint) >> BigInt(8));\n  }\n  result.push(Number(BigInt(uint) | BigInt(0)));\n  while (result.length < 8) {\n    result.push(0);\n  }\n  return new Uint8Array(result.reverse());\n};\n\nexport const varint64ToBuf = (int: number) => {\n  let ux = BigInt(int) << BigInt(1);\n  if (int < 0) {\n    ux = ~ux;\n  }\n  return uvarint64ToBuf(Number(ux));\n};\n\nexport const bufToVarint64 = (buffer: Uint8Array): [number, Uint8Array] => {\n  const [ux, n] = bufToUvarint64(buffer);\n  let x = BigInt(ux) >> BigInt(1);\n  if (ux & 1) {\n    x = ~x;\n  }\n  return [Number(x), n];\n};\n\ninterface Base58CheckOptions {\n  network: Network;\n}\n\n// We are not using the native web crypto API to actually generate keys\n// because it does not support the secp256k1 curve. Instead, we are using\n// https://github.com/paulmillr/noble-secp256k1 which is a browser friendly\n// alternative to the node elliptic package which is far smaller and only\n// focuses on supporting the ec algorithm we are actually interested in here.\n// If the web crypto API ever adds support for secp256k1, we should change\n// this to use it.\n//\n// See the following for more info:\n// https://github.com/w3c/webcrypto/issues/82\n//\n// If you don't provide a seed, a random one will be generated for you and a\n// random key pair will be returned. If you do provide a seed, it should be a\n// randomly generated 32 byte value (Uint8Array of length 32 or hex string of\n// length 64)\nexport const keygen = (seed?: string | Uint8Array): KeyPair => {\n  const privateKey = seed ? normalizeSeed(seed) : ecUtils.randomBytes(32);\n  const seedHex = ecUtils.bytesToHex(privateKey);\n\n  return {\n    seedHex,\n    private: privateKey,\n    public: getPublicKey(privateKey, true /* isCompressed */),\n  };\n};\n\nconst normalizeSeed = (seed: string | Uint8Array): Uint8Array => {\n  if (typeof seed === 'string') {\n    return ecUtils.hexToBytes(seed);\n  } else {\n    return seed;\n  }\n};\n\n/**\n *\n * @param data could be a hex string or a byte array (Uint8Array)\n * @returns\n */\nexport const sha256X2 = (data: Uint8Array | string): Uint8Array => {\n  const d = typeof data === 'string' ? ecUtils.hexToBytes(data) : data;\n  return sha256(sha256(d));\n};\n\nexport const publicKeyToBase58Check = (\n  publicKeyBytes: Uint8Array,\n  options?: Base58CheckOptions\n): string => {\n  const prefix = PUBLIC_KEY_PREFIXES[options?.network ?? 'mainnet'].deso;\n  // This is the same as the implementation in the bs58check package, but we\n  // slightly modify it to use the browser friendly version of Buffer.concat.\n  // See: https://github.com/bitcoinjs/bs58check/blob/12b3e700f355c5c49d0be3f8fc29be6c66e753e9/base.js#L1\n  const bytes = new Uint8Array([...prefix, ...publicKeyBytes]);\n  const checksum = sha256X2(bytes);\n  return bs58.encode(concatUint8Arrays([bytes, checksum], bytes.length + 4));\n};\n\nexport interface SignOptions {\n  isDerivedKey: boolean;\n}\n\nexport const sign = (msgHashHex: string, privateKey: Uint8Array) => {\n  return ecSign(msgHashHex, privateKey, {\n    // For details about the signing options see: https://github.com/paulmillr/noble-secp256k1#signmsghash-privatekey\n    canonical: true,\n    der: true,\n    extraEntropy: true,\n    recovered: true,\n  });\n};\n\nexport const signTx = async (\n  txHex: string,\n  seedHex: string,\n  options?: SignOptions\n): Promise<string> => {\n  const transactionBytes = ecUtils.hexToBytes(txHex);\n  const [_, v1FieldsBuffer] = TransactionV0.fromBytes(transactionBytes);\n  const signatureIndex = transactionBytes.length - v1FieldsBuffer.length - 1;\n  const v0FieldsWithoutSignature = transactionBytes.slice(0, signatureIndex);\n  const hashedTxBytes = sha256X2(transactionBytes);\n  const transactionHashHex = ecUtils.bytesToHex(hashedTxBytes);\n  const privateKey = ecUtils.hexToBytes(seedHex);\n  const [signatureBytes, recoveryParam] = await sign(\n    transactionHashHex,\n    privateKey\n  );\n\n  const signatureLength = uvarint64ToBuf(signatureBytes.length);\n\n  if (options?.isDerivedKey) {\n    signatureBytes[0] += 1 + recoveryParam;\n  }\n\n  const signedTransactionBytes = ecUtils.concatBytes(\n    v0FieldsWithoutSignature,\n    signatureLength,\n    signatureBytes,\n    v1FieldsBuffer\n  );\n\n  return ecUtils.bytesToHex(signedTransactionBytes);\n};\n\nexport const getSignedJWT = async (\n  seedHex: string,\n  alg: jwtAlgorithm,\n  {\n    derivedPublicKeyBase58Check,\n    // TODO: actually support this... or remove it.\n    expiration,\n  }: {\n    derivedPublicKeyBase58Check?: string;\n    expiration?: number;\n  }\n): Promise<string> => {\n  const header = JSON.stringify({ alg, typ: 'JWT' });\n  const issuedAt = Math.floor(Date.now() / 1000);\n  const thirtyMinFromNow = issuedAt + 30 * 60;\n  const payload = JSON.stringify({\n    ...(derivedPublicKeyBase58Check ? { derivedPublicKeyBase58Check } : {}),\n    iat: issuedAt,\n    exp: thirtyMinFromNow,\n  });\n\n  const jwt = `${urlSafeBase64(header)}.${urlSafeBase64(payload)}`;\n  const [signature] = await sign(\n    ecUtils.bytesToHex(sha256(new Uint8Array(new TextEncoder().encode(jwt)))),\n    ecUtils.hexToBytes(seedHex)\n  );\n  const encodedSignature = derToJoseEncoding(signature);\n\n  return `${jwt}.${encodedSignature}`;\n};\n\nfunction urlSafeBase64(str: string) {\n  return window\n    .btoa(str)\n    .replace(/\\+/g, '-')\n    .replace(/\\//g, '_')\n    .replace(/=/g, '');\n}\n\nexport const encryptChatMessage = (\n  senderSeedHex: string,\n  recipientPublicKeyBase58Check: string,\n  message: string\n) => {\n  const privateKey = ecUtils.hexToBytes(senderSeedHex);\n  const recipientPublicKey = bs58PublicKeyToBytes(\n    recipientPublicKeyBase58Check\n  );\n  const sharedPrivateKey = getSharedPrivateKey(privateKey, recipientPublicKey);\n  const sharedPublicKey = getPublicKey(sharedPrivateKey);\n\n  return encrypt(sharedPublicKey, message);\n};\n\n/**\n * @param publicEncryptionKey could be in raw bytes or base58check format\n * @param plaintext\n * @returns cipher text as a hex string\n */\nexport const encrypt = async (\n  publicKey: Uint8Array | string,\n  plaintext: string\n): Promise<string> => {\n  const ephemPrivateKey = ecUtils.randomBytes(32);\n  const ephemPublicKey = getPublicKey(ephemPrivateKey);\n  const publicKeyBytes =\n    typeof publicKey === 'string' ? bs58PublicKeyToBytes(publicKey) : publicKey;\n  const privKey = getSharedPrivateKey(ephemPrivateKey, publicKeyBytes);\n  const encryptionKey = privKey.slice(0, 16);\n  const iv = ecUtils.randomBytes(16);\n  const macKey = sha256(privKey.slice(16));\n  const bytes = new TextEncoder().encode(plaintext);\n  const cryptoKey = await globalThis.crypto.subtle.importKey(\n    'raw',\n    encryptionKey,\n    'AES-CTR',\n    true,\n    ['encrypt']\n  );\n  const cipherBytes = await globalThis.crypto.subtle.encrypt(\n    {\n      name: 'AES-CTR',\n      counter: iv,\n      length: 128,\n    },\n    cryptoKey,\n    bytes\n  );\n  const hmac = await ecUtils.hmacSha256(\n    macKey,\n    new Uint8Array([...iv, ...new Uint8Array(cipherBytes)])\n  );\n\n  return ecUtils.bytesToHex(\n    new Uint8Array([\n      ...ephemPublicKey,\n      ...iv,\n      ...new Uint8Array(cipherBytes),\n      ...hmac,\n    ])\n  );\n};\n\nexport const bs58PublicKeyToCompressedBytes = (str: string) => {\n  if (!str) {\n    return new Uint8Array(33);\n  }\n  const pubKeyUncompressed = bs58PublicKeyToBytes(str);\n  return Point.fromHex(ecUtils.bytesToHex(pubKeyUncompressed)).toRawBytes(true);\n};\n\nexport const bs58PublicKeyToBytes = (str: string) => {\n  const bytes = bs58.decode(str);\n  const payload = bytes.slice(0, -4);\n  const checksumA = bytes.slice(-4);\n  const checksumB = sha256X2(payload);\n\n  if (\n    (checksumA[0] ^ checksumB[0]) |\n    (checksumA[1] ^ checksumB[1]) |\n    (checksumA[2] ^ checksumB[2]) |\n    (checksumA[3] ^ checksumB[3])\n  ) {\n    throw new Error('Invalid checksum');\n  }\n\n  return Point.fromHex(ecUtils.bytesToHex(payload.slice(3))).toRawBytes(false);\n};\n\nconst regexMainnet = /^BC[1-9A-HJ-NP-Za-km-z]{53}$/;\nconst regexTestnet = /^tBC[1-9A-HJ-NP-Za-km-z]{51}$/;\n\nexport const isValidBS58PublicKey = (publicKey: string, isTestnet = false) => {\n  const regexPattern = isTestnet ? regexTestnet : regexMainnet;\n  if (!regexPattern.test(publicKey)) {\n    return false;\n  }\n  try {\n    bs58PublicKeyToBytes(publicKey);\n    return true;\n  } catch (e) {\n    return false;\n  }\n};\n\nconst isValidHmac = (candidate: Uint8Array, knownGood: Uint8Array) => {\n  if (candidate.length !== knownGood.length) {\n    return false;\n  }\n\n  for (let i = 0; i < knownGood.length; i++) {\n    if (candidate[i] !== knownGood[i]) {\n      return false;\n    }\n  }\n\n  return true;\n};\n\nexport const decryptChatMessage = async (\n  recipientSeedHex: string,\n  publicDecryptionKey: string,\n  cipherTextHex: string\n) => {\n  const privateKey = ecUtils.hexToBytes(recipientSeedHex);\n  const publicKey = await bs58PublicKeyToBytes(publicDecryptionKey);\n  const sharedPrivateKey = await getSharedPrivateKey(privateKey, publicKey);\n  return decrypt(sharedPrivateKey, cipherTextHex);\n};\n\nexport const decrypt = async (\n  privateDecryptionKey: Uint8Array | string,\n  hexString: string,\n  { retrying = false } = {}\n): Promise<string> => {\n  const bytes = ecUtils.hexToBytes(hexString);\n  const metaLength = 113;\n\n  if (bytes.length < metaLength) {\n    throw new Error('invalid cipher text. data too small.');\n  }\n\n  if (!(bytes[0] >= 2 && bytes[0] <= 4)) {\n    // this could be a case where the hex string has been double encoded...\n    // so we try decoding and calling again. If it fails again, we just throw.\n    if (!retrying) {\n      return decrypt(privateDecryptionKey, new TextDecoder().decode(bytes), {\n        retrying: true,\n      });\n    } else {\n      throw new Error('invalid cipher text.');\n    }\n  }\n\n  const privateKey = normalizeSeed(privateDecryptionKey);\n  const ephemPublicKey = bytes.slice(0, 65);\n  const cipherTextLength = bytes.length - metaLength;\n  const counter = bytes.slice(65, 65 + 16);\n  const cipherAndIv = bytes.slice(65, 65 + 16 + cipherTextLength);\n  const cipherText = cipherAndIv.slice(16);\n  const msgMac = bytes.slice(65 + 16 + cipherTextLength);\n  const sharedSecretKey = await getSharedPrivateKey(privateKey, ephemPublicKey);\n  const encryptionKey = sharedSecretKey.slice(0, 16);\n  const macKey = sha256(sharedSecretKey.slice(16));\n  const hmacKnownGood = await ecUtils.hmacSha256(macKey, cipherAndIv);\n\n  if (!isValidHmac(msgMac, hmacKnownGood)) {\n    throw new Error('incorrect MAC');\n  }\n\n  const cryptoKey = await globalThis.crypto.subtle.importKey(\n    'raw',\n    encryptionKey,\n    'AES-CTR',\n    true,\n    ['decrypt']\n  );\n\n  const decryptedBuffer = await globalThis.crypto.subtle.decrypt(\n    { name: 'AES-CTR', counter, length: 128 },\n    cryptoKey,\n    cipherText\n  );\n\n  return new TextDecoder().decode(decryptedBuffer);\n};\n\nexport const getSharedPrivateKey = (\n  privKey: Uint8Array,\n  pubKey: Uint8Array\n) => {\n  const sharedSecret = getSharedSecret(privKey, pubKey);\n\n  return kdf(sharedSecret, 32);\n};\n\nexport const decodePublicKey = async (publicKeyBase58Check: string) => {\n  const decoded = await bs58PublicKeyToBytes(publicKeyBase58Check);\n  const withPrefixRemoved = decoded.slice(3);\n  const senderPubKeyHex = ecUtils.bytesToHex(withPrefixRemoved);\n\n  return Point.fromHex(senderPubKeyHex).toRawBytes(false);\n};\n\nexport const getSharedSecret = (privKey: Uint8Array, pubKey: Uint8Array) => {\n  // passing true to compress the public key, and then slicing off the first byte\n  // matches the implementation of derive in the elliptic package.\n  // https://github.com/paulmillr/noble-secp256k1/issues/28#issuecomment-946538037\n  return nobleGetSharedSecret(privKey, pubKey, true).slice(1);\n};\n\n// taken from reference implementation in the deso chat app:\n// https://github.com/deso-protocol/access-group-messaging-app/blob/cd5c237f5e5729196aac0da161d0851bde78092c/src/services/crypto-utils.service.tsx#L91\nexport const kdf = (secret: Uint8Array, outputLength: number) => {\n  let ctr = 1;\n  let written = 0;\n  let result = new Uint8Array();\n\n  while (written < outputLength) {\n    const hash = sha256(\n      new Uint8Array([\n        ...new Uint8Array([ctr >> 24, ctr >> 16, ctr >> 8, ctr]),\n        ...secret,\n      ])\n    );\n    result = new Uint8Array([...result, ...hash]);\n    written += 32;\n    ctr += 1;\n  }\n\n  return result;\n};\n\n// This is a modified version of the derToJose function from\n// https://github.com/Brightspace/node-ecdsa-sig-formatter/blob/ca25a2fd5ae9dd85036081632936e802a47a1289/src/ecdsa-sig-formatter.js#L32\n// The original package is not browser friendly and requires node polyfills. We\n// also don't need to be quite as defensive as the original package since we\n// have full control of the input.\nfunction derToJoseEncoding(signature: Uint8Array) {\n  const paramBytes = 32;\n\n  let offset = 3;\n  const rLength = signature[offset];\n  offset += 1;\n  const rOffset = offset;\n  offset += rLength + 1;\n  const sLength = signature[offset];\n  offset += 1;\n  const sOffset = offset;\n  offset += sLength;\n\n  const rPadding = paramBytes - rLength;\n  const sPadding = paramBytes - sLength;\n\n  const outPut = new Uint8Array(rPadding + rLength + sPadding + sLength);\n\n  for (offset = 0; offset < rPadding; ++offset) {\n    outPut[offset] = 0;\n  }\n\n  outPut.set(\n    signature.slice(rOffset + Math.max(-rPadding, 0), rOffset + rLength),\n    offset\n  );\n\n  offset = paramBytes;\n\n  for (const o = offset; offset < o + sPadding; ++offset) {\n    outPut[offset] = 0;\n  }\n\n  outPut.set(\n    signature.slice(sOffset + Math.max(-sPadding, 0), sOffset + sLength),\n    offset\n  );\n\n  const outputChars = outPut.reduce(\n    (data, byte) => data + String.fromCharCode(byte),\n    ''\n  );\n\n  return urlSafeBase64(outputChars);\n}\n\nexport function deriveAccessGroupKeyPair(\n  privateKeyHex: string,\n  groupKeyName: string\n): KeyPair {\n  const secretHash = sha256X2(privateKeyHex);\n  const keyNameHash = sha256X2(new TextEncoder().encode(groupKeyName));\n  const privateKey = sha256X2(new Uint8Array([...secretHash, ...keyNameHash]));\n\n  return keygen(privateKey);\n}\n"]}

@@ -1,4 +0,4 @@

import { ConstructedTransactionResponse, DAOCoinLimitOrderRequest, DAOCoinOrderResponse, DAOCoinLimitOrderWithCancelOrderIDRequest, DAOCoinRequest, DAOCoinResponse, RequestOptions, TransferDAOCoinRequest, TransferDAOCoinResponse, TxRequestWithOptionalFeesAndExtraData, DAOCoinMarketOrderRequest } from '../backend-types/index.js';
import { ConstructedTransactionResponse, DAOCoinLimitOrderRequest, DAOCoinLimitOrderWithCancelOrderIDRequest, DAOCoinMarketOrderRequest, DAOCoinOrderResponse, DAOCoinRequest, DAOCoinResponse, RequestOptions, TransferDAOCoinRequest, TransferDAOCoinResponse, TxRequestWithOptionalFeesAndExtraData } from '../backend-types/index.js';
import { PartialWithRequiredFields } from '../data/index.js';
import { ConstructedAndSubmittedTx } from '../types.js';
import { ConstructedAndSubmittedTx, TxRequestOptions } from '../types.js';
/**

@@ -28,3 +28,3 @@ * https://docs.deso.org/deso-backend/construct-transactions/dao-transactions-api#create-deso-token-dao-coin

*/
export declare const transferDeSoToken: (params: TxRequestWithOptionalFeesAndExtraData<TransferDAOCoinRequest>, options?: RequestOptions) => Promise<ConstructedAndSubmittedTx<TransferDAOCoinResponse>>;
export declare const transferDeSoToken: (params: TxRequestWithOptionalFeesAndExtraData<TransferDAOCoinRequest>, options?: TxRequestOptions) => Promise<ConstructedAndSubmittedTx<TransferDAOCoinResponse>>;
export declare const constructTransferDeSoToken: (params: TxRequestWithOptionalFeesAndExtraData<TransferDAOCoinRequest>) => Promise<ConstructedTransactionResponse>;

@@ -31,0 +31,0 @@ /**

import { hexToBytes } from '@noble/hashes/utils';
import { TransactionMetadataDAOCoin, TransactionMetadataTransferDAOCoin, bs58PublicKeyToCompressedBytes, } from '../identity/index.js';
import { constructBalanceModelTx, handleSignAndSubmit, isMaybeDeSoPublicKey, } from '../internal.js';
import { TransactionMetadataDAOCoin, TransactionMetadataTransferDAOCoin, bs58PublicKeyToCompressedBytes, identity, } from '../identity/index.js';
import { constructBalanceModelTx, getTxWithFeeNanos, handleSignAndSubmit, isMaybeDeSoPublicKey, sumTransactionFees, } from '../internal.js';
import { guardTxPermission } from './utils.js';
export const burnDeSoToken = (params, options) => {

@@ -98,4 +99,2 @@ return handleSignAndSubmit('api/v0/dao-coin', {

const metadata = new TransactionMetadataDAOCoin();
// TODO: I know we're passing hex strings representing uint256, but need
// to figure out how they go to bytes.
if (!isMaybeDeSoPublicKey(params.ProfilePublicKeyBase58CheckOrUsername)) {

@@ -115,3 +114,34 @@ return Promise.reject('must provide profile public key, not username for local transaction construction');

*/
export const transferDeSoToken = (params, options) => {
export const transferDeSoToken = async (params, options) => {
if (options?.checkPermissions !== false) {
const txWithFee = getTxWithFeeNanos(params.SenderPublicKeyBase58Check, new TransactionMetadataTransferDAOCoin(), {
// TODO: I'm not sure exactly what outputs are needed here... for the time
// being I'm just adding a static 1500 nanos to make sure the derived key
// transaction can be submitted.
// Outputs: ...,
ExtraData: params.ExtraData,
MinFeeRateNanosPerKB: params.MinFeeRateNanosPerKB,
TransactionFees: params.TransactionFees,
});
if (!isMaybeDeSoPublicKey(params.ProfilePublicKeyBase58CheckOrUsername)) {
return Promise.reject('must provide profile public key, not username for ProfilePublicKeyBase58CheckOrUsername when checking dao coin transfer permissions');
}
await guardTxPermission({
GlobalDESOLimit:
// TODO: when I figure out how to properly calculate the fee for this transaction
// we can remove this static 1500 buffer.
txWithFee.feeNanos + sumTransactionFees(params.TransactionFees) + 1500,
TransactionCountLimitMap: {
DAO_COIN_TRANSFER: options?.txLimitCount ??
identity.transactionSpendingLimitOptions.TransactionCountLimitMap
?.DAO_COIN_TRANSFER ??
1,
},
DAOCoinOperationLimitMap: {
[params.ProfilePublicKeyBase58CheckOrUsername]: {
transfer: 1,
},
},
});
}
return handleSignAndSubmit('api/v0/transfer-dao-coin', params, {

@@ -170,2 +200,2 @@ ...options,

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"deso-tokens.js","sourceRoot":"","sources":["../../../src/transactions/deso-tokens.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAgBjD,OAAO,EACL,0BAA0B,EAC1B,kCAAkC,EAClC,8BAA8B,GAC/B,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EACL,uBAAuB,EACvB,mBAAmB,EACnB,oBAAoB,GACrB,MAAM,gBAAgB,CAAC;AAcxB,MAAM,CAAC,MAAM,aAAa,GAAG,CAC3B,MAA2C,EAC3C,OAAwB,EAC6B,EAAE;IACvD,OAAO,mBAAmB,CACxB,iBAAiB,EACjB;QACE,GAAG,MAAM;QACT,aAAa,EAAE,MAAM;KACtB,EACD,EAAE,GAAG,OAAO,EAAE,oBAAoB,EAAE,iCAAiC,EAAE,CACxE,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,iCAAiC,GAAG,CAC/C,MAA2C,EACF,EAAE;IAC3C,MAAM,QAAQ,GAAG,IAAI,0BAA0B,EAAE,CAAC;IAClD,wEAAwE;IACxE,sCAAsC;IACtC,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,qCAAqC,CAAC,EAAE;QACvE,OAAO,OAAO,CAAC,MAAM,CACnB,kFAAkF,CACnF,CAAC;KACH;IACD,QAAQ,CAAC,gBAAgB,GAAG,UAAU,CACpC,MAAM,CAAC,gBAAgB,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,CAC3C,CAAC;IACF,QAAQ,CAAC,gBAAgB,GAAG,8BAA8B,CACxD,MAAM,CAAC,qCAAqC,CAC7C,CAAC;IACF,QAAQ,CAAC,aAAa,GAAG,CAAC,CAAC;IAC3B,OAAO,uBAAuB,CAAC,MAAM,CAAC,2BAA2B,EAAE,QAAQ,EAAE;QAC3E,SAAS,EAAE,MAAM,CAAC,SAAS;QAC3B,oBAAoB,EAAE,MAAM,CAAC,oBAAoB;QACjD,eAAe,EAAE,MAAM,CAAC,eAAe;KACxC,CAAC,CAAC;AACL,CAAC,CAAC;AAaF,MAAM,CAAC,MAAM,aAAa,GAAG,CAC3B,MAAkC,EAClC,OAAwB,EAC6B,EAAE;IACvD,OAAO,mBAAmB,CACxB,iBAAiB,EACjB;QACE,GAAG,MAAM;QACT,aAAa,EAAE,MAAM;KACtB,EACD,EAAE,GAAG,OAAO,EAAE,oBAAoB,EAAE,iCAAiC,EAAE,CACxE,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,iCAAiC,GAAG,CAC/C,MAAkC,EACO,EAAE;IAC3C,MAAM,QAAQ,GAAG,IAAI,0BAA0B,EAAE,CAAC;IAClD,wEAAwE;IACxE,sCAAsC;IACtC,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,qCAAqC,CAAC,EAAE;QACvE,OAAO,OAAO,CAAC,MAAM,CACnB,kFAAkF,CACnF,CAAC;KACH;IACD,QAAQ,CAAC,gBAAgB,GAAG,UAAU,CACpC,MAAM,CAAC,gBAAgB,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,CAC3C,CAAC;IACF,QAAQ,CAAC,gBAAgB,GAAG,8BAA8B,CACxD,MAAM,CAAC,qCAAqC,CAC7C,CAAC;IACF,QAAQ,CAAC,aAAa,GAAG,CAAC,CAAC;IAC3B,OAAO,uBAAuB,CAAC,MAAM,CAAC,2BAA2B,EAAE,QAAQ,EAAE;QAC3E,SAAS,EAAE,MAAM,CAAC,SAAS;QAC3B,oBAAoB,EAAE,MAAM,CAAC,oBAAoB;QACjD,eAAe,EAAE,MAAM,CAAC,eAAe;KACxC,CAAC,CAAC;AACL,CAAC,CAAC;AAYF,MAAM,CAAC,MAAM,wCAAwC,GAAG,CACtD,MAA6D,EAC7D,OAAwB,EAC6B,EAAE;IACvD,OAAO,mBAAmB,CACxB,iBAAiB,EACjB;QACE,GAAG,MAAM;QACT,aAAa,EAAE,oCAAoC;KACpD,EACD;QACE,GAAG,OAAO;QACV,oBAAoB,EAClB,4DAA4D;KAC/D,CACF,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,4DAA4D,GAAG,CAC1E,MAA6D,EACpB,EAAE;IAC3C,MAAM,QAAQ,GAAG,IAAI,0BAA0B,EAAE,CAAC;IAClD,wEAAwE;IACxE,sCAAsC;IACtC,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,qCAAqC,CAAC,EAAE;QACvE,OAAO,OAAO,CAAC,MAAM,CACnB,kFAAkF,CACnF,CAAC;KACH;IACD,QAAQ,CAAC,gBAAgB,GAAG,8BAA8B,CACxD,MAAM,CAAC,qCAAqC,CAC7C,CAAC;IACF,QAAQ,CAAC,aAAa,GAAG,CAAC,CAAC;IAC3B,IAAI,yBAAiC,CAAC;IACtC,QAAQ,MAAM,CAAC,yBAAyB,EAAE;QACxC,KAAK,kBAAkB;YACrB,yBAAyB,GAAG,CAAC,CAAC;YAC9B,MAAM;QACR,KAAK,0BAA0B;YAC7B,yBAAyB,GAAG,CAAC,CAAC;YAC9B,MAAM;QACR,KAAK,oBAAoB;YACvB,yBAAyB,GAAG,CAAC,CAAC;YAC9B,MAAM;QACR,KAAK,cAAc;YACjB,yBAAyB,GAAG,CAAC,CAAC;YAC9B,MAAM;QACR;YACE,OAAO,OAAO,CAAC,MAAM,CAAC,2CAA2C,CAAC,CAAC;KACtE;IACD,QAAQ,CAAC,yBAAyB,GAAG,yBAAyB,CAAC;IAC/D,OAAO,uBAAuB,CAAC,MAAM,CAAC,2BAA2B,EAAE,QAAQ,EAAE;QAC3E,SAAS,EAAE,MAAM,CAAC,SAAS;QAC3B,oBAAoB,EAAE,MAAM,CAAC,oBAAoB;QACjD,eAAe,EAAE,MAAM,CAAC,eAAe;KACxC,CAAC,CAAC;AACL,CAAC,CAAC;AASF,MAAM,CAAC,MAAM,uBAAuB,GAAG,CACrC,MAA4C,EAC5C,OAAwB,EAC6B,EAAE;IACvD,OAAO,mBAAmB,CACxB,iBAAiB,EACjB;QACE,GAAG,MAAM;QACT,aAAa,EAAE,iBAAiB;KACjC,EACD,EAAE,GAAG,OAAO,EAAE,oBAAoB,EAAE,gCAAgC,EAAE,CACvE,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,gCAAgC,GAAG,CAC9C,MAA4C,EACH,EAAE;IAC3C,MAAM,QAAQ,GAAG,IAAI,0BAA0B,EAAE,CAAC;IAClD,wEAAwE;IACxE,sCAAsC;IACtC,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,qCAAqC,CAAC,EAAE;QACvE,OAAO,OAAO,CAAC,MAAM,CACnB,kFAAkF,CACnF,CAAC;KACH;IACD,QAAQ,CAAC,gBAAgB,GAAG,8BAA8B,CACxD,MAAM,CAAC,qCAAqC,CAC7C,CAAC;IACF,QAAQ,CAAC,aAAa,GAAG,CAAC,CAAC;IAC3B,OAAO,uBAAuB,CAAC,MAAM,CAAC,2BAA2B,EAAE,QAAQ,EAAE;QAC3E,SAAS,EAAE,MAAM,CAAC,SAAS;QAC3B,oBAAoB,EAAE,MAAM,CAAC,oBAAoB;QACjD,eAAe,EAAE,MAAM,CAAC,eAAe;KACxC,CAAC,CAAC;AACL,CAAC,CAAC;AAEF;;GAEG;AACH,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAC/B,MAAqE,EACrE,OAAwB,EACqC,EAAE;IAC/D,OAAO,mBAAmB,CAAC,0BAA0B,EAAE,MAAM,EAAE;QAC7D,GAAG,OAAO;QACV,oBAAoB,EAAE,0BAA0B;KACjD,CAAC,CAAC;AACL,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,0BAA0B,GAAG,CACxC,MAAqE,EAC5B,EAAE;IAC3C,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,qCAAqC,CAAC,EAAE;QACvE,OAAO,OAAO,CAAC,MAAM,CACnB,kFAAkF,CACnF,CAAC;KACH;IACD,MAAM,QAAQ,GAAG,IAAI,kCAAkC,EAAE,CAAC;IAC1D,QAAQ,CAAC,sBAAsB,GAAG,UAAU,CAC1C,MAAM,CAAC,sBAAsB,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,CACjD,CAAC;IACF,QAAQ,CAAC,gBAAgB,GAAG,8BAA8B,CACxD,MAAM,CAAC,qCAAqC,CAC7C,CAAC;IACF,QAAQ,CAAC,iBAAiB,GAAG,8BAA8B,CACzD,MAAM,CAAC,sCAAsC,CAC9C,CAAC;IACF,OAAO,uBAAuB,CAAC,MAAM,CAAC,0BAA0B,EAAE,QAAQ,EAAE;QAC1E,SAAS,EAAE,MAAM,CAAC,SAAS;QAC3B,oBAAoB,EAAE,MAAM,CAAC,oBAAoB;QACjD,eAAe,EAAE,MAAM,CAAC,eAAe;KACxC,CAAC,CAAC;AACL,CAAC,CAAC;AAEF,iEAAiE;AACjE;;GAEG;AACH,MAAM,CAAC,MAAM,yBAAyB,GAAG,CACvC,MAAgC,EAChC,OAAwB,EACkC,EAAE;IAC5D,OAAO,mBAAmB,CACxB,oCAAoC,EACpC;QACE,GAAG,MAAM;KACV,EACD,OAAO,CACR,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,0BAA0B,GAAG,CACxC,MAAiC,EACjC,OAAwB,EACkC,EAAE;IAC5D,OAAO,mBAAmB,CACxB,qCAAqC,EACrC;QACE,GAAG,MAAM;KACV,EACD,OAAO,CACR,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,uBAAuB,GAAG,CACrC,MAQC,EACD,OAAwB,EACkC,EAAE;IAC5D,OAAO,mBAAmB,CACxB,qCAAqC,EACrC;QACE,GAAG,MAAM;QACT,yCAAyC,EAAE,EAAE;QAC7C,aAAa,EAAE,KAAK;KACrB,EACD,OAAO,CACR,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,wBAAwB,GAAG,CACtC,MAQC,EACD,OAAwB,EACkC,EAAE;IAC5D,OAAO,mBAAmB,CACxB,qCAAqC,EACrC;QACE,GAAG,MAAM;QACT,yCAAyC,EAAE,EAAE;QAC7C,aAAa,EAAE,KAAK;KACrB,EACD,OAAO,CACR,CAAC;AACJ,CAAC,CAAC;AAEF;;GAEG;AACH,MAAM,CAAC,MAAM,yBAAyB,GAAG,CACvC,MAAwF,EACxF,OAAwB,EACkC,EAAE;IAC5D,OAAO,mBAAmB,CACxB,oCAAoC,EACpC,MAAM,EACN,OAAO,CACR,CAAC;AACJ,CAAC,CAAC","sourcesContent":["import { hexToBytes } from '@noble/hashes/utils';\nimport {\n  ConstructedTransactionResponse,\n  DAOCoinLimitOrderRequest,\n  DAOCoinOrderResponse,\n  DAOCoinLimitOrderWithCancelOrderIDRequest,\n  DAOCoinLimitOrderWithExchangeRateAndQuantityRequest,\n  DAOCoinRequest,\n  DAOCoinResponse,\n  RequestOptions,\n  TransferDAOCoinRequest,\n  TransferDAOCoinResponse,\n  TxRequestWithOptionalFeesAndExtraData,\n  DAOCoinMarketOrderRequest,\n} from '../backend-types/index.js';\nimport { PartialWithRequiredFields } from '../data/index.js';\nimport {\n  TransactionMetadataDAOCoin,\n  TransactionMetadataTransferDAOCoin,\n  bs58PublicKeyToCompressedBytes,\n} from '../identity/index.js';\nimport {\n  constructBalanceModelTx,\n  handleSignAndSubmit,\n  isMaybeDeSoPublicKey,\n} from '../internal.js';\nimport { ConstructedAndSubmittedTx } from '../types.js';\n/**\n * https://docs.deso.org/deso-backend/construct-transactions/dao-transactions-api#create-deso-token-dao-coin\n */\nexport type ConstructBurnDeSoTokenRequestParams =\n  TxRequestWithOptionalFeesAndExtraData<\n    PartialWithRequiredFields<\n      Omit<DAOCoinRequest, 'OperationType'>,\n      | 'UpdaterPublicKeyBase58Check'\n      | 'ProfilePublicKeyBase58CheckOrUsername'\n      | 'CoinsToBurnNanos'\n    >\n  >;\nexport const burnDeSoToken = (\n  params: ConstructBurnDeSoTokenRequestParams,\n  options?: RequestOptions\n): Promise<ConstructedAndSubmittedTx<DAOCoinResponse>> => {\n  return handleSignAndSubmit(\n    'api/v0/dao-coin',\n    {\n      ...params,\n      OperationType: 'burn',\n    },\n    { ...options, constructionFunction: constructBurnDeSoTokenTransaction }\n  );\n};\n\nexport const constructBurnDeSoTokenTransaction = (\n  params: ConstructBurnDeSoTokenRequestParams\n): Promise<ConstructedTransactionResponse> => {\n  const metadata = new TransactionMetadataDAOCoin();\n  // TODO: I know we're passing hex strings representing uint256, but need\n  // to figure out how they go to bytes.\n  if (!isMaybeDeSoPublicKey(params.ProfilePublicKeyBase58CheckOrUsername)) {\n    return Promise.reject(\n      'must provide profile public key, not username for local transaction construction'\n    );\n  }\n  metadata.coinsToBurnNanos = hexToBytes(\n    params.CoinsToBurnNanos.replace('0x', 'x')\n  );\n  metadata.profilePublicKey = bs58PublicKeyToCompressedBytes(\n    params.ProfilePublicKeyBase58CheckOrUsername\n  );\n  metadata.operationType = 1;\n  return constructBalanceModelTx(params.UpdaterPublicKeyBase58Check, metadata, {\n    ExtraData: params.ExtraData,\n    MinFeeRateNanosPerKB: params.MinFeeRateNanosPerKB,\n    TransactionFees: params.TransactionFees,\n  });\n};\n\n/**\n * https://docs.deso.org/deso-backend/construct-transactions/dao-transactions-api#create-deso-token-dao-coin\n */\nexport type MintDeSoTokenRequestParams = TxRequestWithOptionalFeesAndExtraData<\n  PartialWithRequiredFields<\n    Omit<DAOCoinRequest, 'OperationType'>,\n    | 'UpdaterPublicKeyBase58Check'\n    | 'ProfilePublicKeyBase58CheckOrUsername'\n    | 'CoinsToMintNanos'\n  >\n>;\nexport const mintDeSoToken = (\n  params: MintDeSoTokenRequestParams,\n  options?: RequestOptions\n): Promise<ConstructedAndSubmittedTx<DAOCoinResponse>> => {\n  return handleSignAndSubmit(\n    'api/v0/dao-coin',\n    {\n      ...params,\n      OperationType: 'mint',\n    },\n    { ...options, constructionFunction: constructMintDeSoTokenTransaction }\n  );\n};\n\nexport const constructMintDeSoTokenTransaction = (\n  params: MintDeSoTokenRequestParams\n): Promise<ConstructedTransactionResponse> => {\n  const metadata = new TransactionMetadataDAOCoin();\n  // TODO: I know we're passing hex strings representing uint256, but need\n  // to figure out how they go to bytes.\n  if (!isMaybeDeSoPublicKey(params.ProfilePublicKeyBase58CheckOrUsername)) {\n    return Promise.reject(\n      'must provide profile public key, not username for local transaction construction'\n    );\n  }\n  metadata.coinsToMintNanos = hexToBytes(\n    params.CoinsToMintNanos.replace('0x', 'x')\n  );\n  metadata.profilePublicKey = bs58PublicKeyToCompressedBytes(\n    params.ProfilePublicKeyBase58CheckOrUsername\n  );\n  metadata.operationType = 0;\n  return constructBalanceModelTx(params.UpdaterPublicKeyBase58Check, metadata, {\n    ExtraData: params.ExtraData,\n    MinFeeRateNanosPerKB: params.MinFeeRateNanosPerKB,\n    TransactionFees: params.TransactionFees,\n  });\n};\n\n/**\n * https://docs.deso.org/deso-backend/construct-transactions/dao-transactions-api#create-deso-token-dao-coin\n */\nexport type UpdateDeSoTokenTransferRestrictionStatusRequestParams =\n  TxRequestWithOptionalFeesAndExtraData<\n    PartialWithRequiredFields<\n      Omit<DAOCoinRequest, 'OperationType'>,\n      'UpdaterPublicKeyBase58Check' | 'ProfilePublicKeyBase58CheckOrUsername'\n    >\n  >;\nexport const updateDeSoTokenTransferRestrictionStatus = (\n  params: UpdateDeSoTokenTransferRestrictionStatusRequestParams,\n  options?: RequestOptions\n): Promise<ConstructedAndSubmittedTx<DAOCoinResponse>> => {\n  return handleSignAndSubmit(\n    'api/v0/dao-coin',\n    {\n      ...params,\n      OperationType: 'update_transfer_restriction_status',\n    },\n    {\n      ...options,\n      constructionFunction:\n        constructUpdateDeSoTokenTransferRestrictionStatusTransaction,\n    }\n  );\n};\n\nexport const constructUpdateDeSoTokenTransferRestrictionStatusTransaction = (\n  params: UpdateDeSoTokenTransferRestrictionStatusRequestParams\n): Promise<ConstructedTransactionResponse> => {\n  const metadata = new TransactionMetadataDAOCoin();\n  // TODO: I know we're passing hex strings representing uint256, but need\n  // to figure out how they go to bytes.\n  if (!isMaybeDeSoPublicKey(params.ProfilePublicKeyBase58CheckOrUsername)) {\n    return Promise.reject(\n      'must provide profile public key, not username for local transaction construction'\n    );\n  }\n  metadata.profilePublicKey = bs58PublicKeyToCompressedBytes(\n    params.ProfilePublicKeyBase58CheckOrUsername\n  );\n  metadata.operationType = 3;\n  let transferRestrictionStatus: number;\n  switch (params.TransferRestrictionStatus) {\n    case 'dao_members_only':\n      transferRestrictionStatus = 2;\n      break;\n    case 'permanently_unrestricted':\n      transferRestrictionStatus = 3;\n      break;\n    case 'profile_owner_only':\n      transferRestrictionStatus = 1;\n      break;\n    case 'unrestricted':\n      transferRestrictionStatus = 0;\n      break;\n    default:\n      return Promise.reject('invalid transfer restriction status value');\n  }\n  metadata.transferRestrictionStatus = transferRestrictionStatus;\n  return constructBalanceModelTx(params.UpdaterPublicKeyBase58Check, metadata, {\n    ExtraData: params.ExtraData,\n    MinFeeRateNanosPerKB: params.MinFeeRateNanosPerKB,\n    TransactionFees: params.TransactionFees,\n  });\n};\n\nexport type DisableMintingDeSoTokenRequestParams =\n  TxRequestWithOptionalFeesAndExtraData<\n    PartialWithRequiredFields<\n      Omit<DAOCoinRequest, 'OperationType'>,\n      'UpdaterPublicKeyBase58Check' | 'ProfilePublicKeyBase58CheckOrUsername'\n    >\n  >;\nexport const disableMintingDeSoToken = (\n  params: DisableMintingDeSoTokenRequestParams,\n  options?: RequestOptions\n): Promise<ConstructedAndSubmittedTx<DAOCoinResponse>> => {\n  return handleSignAndSubmit(\n    'api/v0/dao-coin',\n    {\n      ...params,\n      OperationType: 'disable_minting',\n    },\n    { ...options, constructionFunction: constructDisableMintingDeSoToken }\n  );\n};\n\nexport const constructDisableMintingDeSoToken = (\n  params: DisableMintingDeSoTokenRequestParams\n): Promise<ConstructedTransactionResponse> => {\n  const metadata = new TransactionMetadataDAOCoin();\n  // TODO: I know we're passing hex strings representing uint256, but need\n  // to figure out how they go to bytes.\n  if (!isMaybeDeSoPublicKey(params.ProfilePublicKeyBase58CheckOrUsername)) {\n    return Promise.reject(\n      'must provide profile public key, not username for local transaction construction'\n    );\n  }\n  metadata.profilePublicKey = bs58PublicKeyToCompressedBytes(\n    params.ProfilePublicKeyBase58CheckOrUsername\n  );\n  metadata.operationType = 2;\n  return constructBalanceModelTx(params.UpdaterPublicKeyBase58Check, metadata, {\n    ExtraData: params.ExtraData,\n    MinFeeRateNanosPerKB: params.MinFeeRateNanosPerKB,\n    TransactionFees: params.TransactionFees,\n  });\n};\n\n/**\n * https://docs.deso.org/deso-backend/construct-transactions/dao-transactions-api#transfer-deso-token-dao-coin\n */\nexport const transferDeSoToken = (\n  params: TxRequestWithOptionalFeesAndExtraData<TransferDAOCoinRequest>,\n  options?: RequestOptions\n): Promise<ConstructedAndSubmittedTx<TransferDAOCoinResponse>> => {\n  return handleSignAndSubmit('api/v0/transfer-dao-coin', params, {\n    ...options,\n    constructionFunction: constructTransferDeSoToken,\n  });\n};\n\nexport const constructTransferDeSoToken = (\n  params: TxRequestWithOptionalFeesAndExtraData<TransferDAOCoinRequest>\n): Promise<ConstructedTransactionResponse> => {\n  if (!isMaybeDeSoPublicKey(params.ProfilePublicKeyBase58CheckOrUsername)) {\n    return Promise.reject(\n      'must provide profile public key, not username for local transaction construction'\n    );\n  }\n  const metadata = new TransactionMetadataTransferDAOCoin();\n  metadata.daoCoinToTransferNanos = hexToBytes(\n    params.DAOCoinToTransferNanos.replace('0x', 'x')\n  );\n  metadata.profilePublicKey = bs58PublicKeyToCompressedBytes(\n    params.ProfilePublicKeyBase58CheckOrUsername\n  );\n  metadata.receiverPublicKey = bs58PublicKeyToCompressedBytes(\n    params.ReceiverPublicKeyBase58CheckOrUsername\n  );\n  return constructBalanceModelTx(params.SenderPublicKeyBase58Check, metadata, {\n    ExtraData: params.ExtraData,\n    MinFeeRateNanosPerKB: params.MinFeeRateNanosPerKB,\n    TransactionFees: params.TransactionFees,\n  });\n};\n\n// TODO: Balance model transaction construction for limit orders.\n/**\n * https://docs.deso.org/deso-backend/construct-transactions/dao-transactions-api#create-deso-token-dao-coin-limit-order\n */\nexport const createDeSoTokenLimitOrder = (\n  params: DAOCoinLimitOrderRequest,\n  options?: RequestOptions\n): Promise<ConstructedAndSubmittedTx<DAOCoinOrderResponse>> => {\n  return handleSignAndSubmit(\n    'api/v0/create-dao-coin-limit-order',\n    {\n      ...params,\n    },\n    options\n  );\n};\n\nexport const createDeSoTokenMarketOrder = (\n  params: DAOCoinMarketOrderRequest,\n  options?: RequestOptions\n): Promise<ConstructedAndSubmittedTx<DAOCoinOrderResponse>> => {\n  return handleSignAndSubmit(\n    'api/v0/create-dao-coin-market-order',\n    {\n      ...params,\n    },\n    options\n  );\n};\n\nexport const buyDeSoTokenMarketOrder = (\n  params: PartialWithRequiredFields<\n    Omit<\n      DAOCoinMarketOrderRequest,\n      'SellingDAOCoinCreatorPublicKeyBase58Check' | 'OperationType'\n    >,\n    | 'TransactorPublicKeyBase58Check'\n    | 'BuyingDAOCoinCreatorPublicKeyBase58Check'\n    | 'Quantity'\n  >,\n  options?: RequestOptions\n): Promise<ConstructedAndSubmittedTx<DAOCoinOrderResponse>> => {\n  return handleSignAndSubmit(\n    'api/v0/create-dao-coin-market-order',\n    {\n      ...params,\n      SellingDAOCoinCreatorPublicKeyBase58Check: '',\n      OperationType: 'BID',\n    },\n    options\n  );\n};\n\nexport const sellDeSoTokenMarketOrder = (\n  params: PartialWithRequiredFields<\n    Omit<\n      DAOCoinMarketOrderRequest,\n      'BuyingDAOCoinCreatorPublicKeyBase58Check' | 'OperationType'\n    >,\n    | 'TransactorPublicKeyBase58Check'\n    | 'SellingDAOCoinCreatorPublicKeyBase58Check'\n    | 'Quantity'\n  >,\n  options?: RequestOptions\n): Promise<ConstructedAndSubmittedTx<DAOCoinOrderResponse>> => {\n  return handleSignAndSubmit(\n    'api/v0/create-dao-coin-market-order',\n    {\n      ...params,\n      SellingDAOCoinCreatorPublicKeyBase58Check: '',\n      OperationType: 'ASK',\n    },\n    options\n  );\n};\n\n/**\n * https://docs.deso.org/deso-backend/construct-transactions/dao-transactions-api#cancel-deso-token-dao-coin-limit-order\n */\nexport const cancelDeSoTokenLimitOrder = (\n  params: TxRequestWithOptionalFeesAndExtraData<DAOCoinLimitOrderWithCancelOrderIDRequest>,\n  options?: RequestOptions\n): Promise<ConstructedAndSubmittedTx<DAOCoinOrderResponse>> => {\n  return handleSignAndSubmit(\n    'api/v0/cancel-dao-coin-limit-order',\n    params,\n    options\n  );\n};\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"deso-tokens.js","sourceRoot":"","sources":["../../../src/transactions/deso-tokens.ts"],"names":[],"mappings":"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","sourcesContent":["import { hexToBytes } from '@noble/hashes/utils';\nimport {\n  ConstructedTransactionResponse,\n  DAOCoinLimitOrderRequest,\n  DAOCoinLimitOrderWithCancelOrderIDRequest,\n  DAOCoinMarketOrderRequest,\n  DAOCoinOrderResponse,\n  DAOCoinRequest,\n  DAOCoinResponse,\n  RequestOptions,\n  TransferDAOCoinRequest,\n  TransferDAOCoinResponse,\n  TxRequestWithOptionalFeesAndExtraData,\n} from '../backend-types/index.js';\nimport { PartialWithRequiredFields } from '../data/index.js';\nimport {\n  TransactionMetadataDAOCoin,\n  TransactionMetadataTransferDAOCoin,\n  bs58PublicKeyToCompressedBytes,\n  identity,\n} from '../identity/index.js';\nimport {\n  constructBalanceModelTx,\n  getTxWithFeeNanos,\n  handleSignAndSubmit,\n  isMaybeDeSoPublicKey,\n  sumTransactionFees,\n} from '../internal.js';\nimport { ConstructedAndSubmittedTx, TxRequestOptions } from '../types.js';\nimport { guardTxPermission } from './utils.js';\n\n/**\n * https://docs.deso.org/deso-backend/construct-transactions/dao-transactions-api#create-deso-token-dao-coin\n */\nexport type ConstructBurnDeSoTokenRequestParams =\n  TxRequestWithOptionalFeesAndExtraData<\n    PartialWithRequiredFields<\n      Omit<DAOCoinRequest, 'OperationType'>,\n      | 'UpdaterPublicKeyBase58Check'\n      | 'ProfilePublicKeyBase58CheckOrUsername'\n      | 'CoinsToBurnNanos'\n    >\n  >;\nexport const burnDeSoToken = (\n  params: ConstructBurnDeSoTokenRequestParams,\n  options?: RequestOptions\n): Promise<ConstructedAndSubmittedTx<DAOCoinResponse>> => {\n  return handleSignAndSubmit(\n    'api/v0/dao-coin',\n    {\n      ...params,\n      OperationType: 'burn',\n    },\n    { ...options, constructionFunction: constructBurnDeSoTokenTransaction }\n  );\n};\n\nexport const constructBurnDeSoTokenTransaction = (\n  params: ConstructBurnDeSoTokenRequestParams\n): Promise<ConstructedTransactionResponse> => {\n  const metadata = new TransactionMetadataDAOCoin();\n  // TODO: I know we're passing hex strings representing uint256, but need\n  // to figure out how they go to bytes.\n  if (!isMaybeDeSoPublicKey(params.ProfilePublicKeyBase58CheckOrUsername)) {\n    return Promise.reject(\n      'must provide profile public key, not username for local transaction construction'\n    );\n  }\n  metadata.coinsToBurnNanos = hexToBytes(\n    params.CoinsToBurnNanos.replace('0x', 'x')\n  );\n  metadata.profilePublicKey = bs58PublicKeyToCompressedBytes(\n    params.ProfilePublicKeyBase58CheckOrUsername\n  );\n  metadata.operationType = 1;\n  return constructBalanceModelTx(params.UpdaterPublicKeyBase58Check, metadata, {\n    ExtraData: params.ExtraData,\n    MinFeeRateNanosPerKB: params.MinFeeRateNanosPerKB,\n    TransactionFees: params.TransactionFees,\n  });\n};\n\n/**\n * https://docs.deso.org/deso-backend/construct-transactions/dao-transactions-api#create-deso-token-dao-coin\n */\nexport type MintDeSoTokenRequestParams = TxRequestWithOptionalFeesAndExtraData<\n  PartialWithRequiredFields<\n    Omit<DAOCoinRequest, 'OperationType'>,\n    | 'UpdaterPublicKeyBase58Check'\n    | 'ProfilePublicKeyBase58CheckOrUsername'\n    | 'CoinsToMintNanos'\n  >\n>;\nexport const mintDeSoToken = (\n  params: MintDeSoTokenRequestParams,\n  options?: RequestOptions\n): Promise<ConstructedAndSubmittedTx<DAOCoinResponse>> => {\n  return handleSignAndSubmit(\n    'api/v0/dao-coin',\n    {\n      ...params,\n      OperationType: 'mint',\n    },\n    { ...options, constructionFunction: constructMintDeSoTokenTransaction }\n  );\n};\n\nexport const constructMintDeSoTokenTransaction = (\n  params: MintDeSoTokenRequestParams\n): Promise<ConstructedTransactionResponse> => {\n  const metadata = new TransactionMetadataDAOCoin();\n  // TODO: I know we're passing hex strings representing uint256, but need\n  // to figure out how they go to bytes.\n  if (!isMaybeDeSoPublicKey(params.ProfilePublicKeyBase58CheckOrUsername)) {\n    return Promise.reject(\n      'must provide profile public key, not username for local transaction construction'\n    );\n  }\n  metadata.coinsToMintNanos = hexToBytes(\n    params.CoinsToMintNanos.replace('0x', 'x')\n  );\n  metadata.profilePublicKey = bs58PublicKeyToCompressedBytes(\n    params.ProfilePublicKeyBase58CheckOrUsername\n  );\n  metadata.operationType = 0;\n  return constructBalanceModelTx(params.UpdaterPublicKeyBase58Check, metadata, {\n    ExtraData: params.ExtraData,\n    MinFeeRateNanosPerKB: params.MinFeeRateNanosPerKB,\n    TransactionFees: params.TransactionFees,\n  });\n};\n\n/**\n * https://docs.deso.org/deso-backend/construct-transactions/dao-transactions-api#create-deso-token-dao-coin\n */\nexport type UpdateDeSoTokenTransferRestrictionStatusRequestParams =\n  TxRequestWithOptionalFeesAndExtraData<\n    PartialWithRequiredFields<\n      Omit<DAOCoinRequest, 'OperationType'>,\n      'UpdaterPublicKeyBase58Check' | 'ProfilePublicKeyBase58CheckOrUsername'\n    >\n  >;\nexport const updateDeSoTokenTransferRestrictionStatus = (\n  params: UpdateDeSoTokenTransferRestrictionStatusRequestParams,\n  options?: RequestOptions\n): Promise<ConstructedAndSubmittedTx<DAOCoinResponse>> => {\n  return handleSignAndSubmit(\n    'api/v0/dao-coin',\n    {\n      ...params,\n      OperationType: 'update_transfer_restriction_status',\n    },\n    {\n      ...options,\n      constructionFunction:\n        constructUpdateDeSoTokenTransferRestrictionStatusTransaction,\n    }\n  );\n};\n\nexport const constructUpdateDeSoTokenTransferRestrictionStatusTransaction = (\n  params: UpdateDeSoTokenTransferRestrictionStatusRequestParams\n): Promise<ConstructedTransactionResponse> => {\n  const metadata = new TransactionMetadataDAOCoin();\n  // TODO: I know we're passing hex strings representing uint256, but need\n  // to figure out how they go to bytes.\n  if (!isMaybeDeSoPublicKey(params.ProfilePublicKeyBase58CheckOrUsername)) {\n    return Promise.reject(\n      'must provide profile public key, not username for local transaction construction'\n    );\n  }\n  metadata.profilePublicKey = bs58PublicKeyToCompressedBytes(\n    params.ProfilePublicKeyBase58CheckOrUsername\n  );\n  metadata.operationType = 3;\n  let transferRestrictionStatus: number;\n  switch (params.TransferRestrictionStatus) {\n    case 'dao_members_only':\n      transferRestrictionStatus = 2;\n      break;\n    case 'permanently_unrestricted':\n      transferRestrictionStatus = 3;\n      break;\n    case 'profile_owner_only':\n      transferRestrictionStatus = 1;\n      break;\n    case 'unrestricted':\n      transferRestrictionStatus = 0;\n      break;\n    default:\n      return Promise.reject('invalid transfer restriction status value');\n  }\n  metadata.transferRestrictionStatus = transferRestrictionStatus;\n  return constructBalanceModelTx(params.UpdaterPublicKeyBase58Check, metadata, {\n    ExtraData: params.ExtraData,\n    MinFeeRateNanosPerKB: params.MinFeeRateNanosPerKB,\n    TransactionFees: params.TransactionFees,\n  });\n};\n\nexport type DisableMintingDeSoTokenRequestParams =\n  TxRequestWithOptionalFeesAndExtraData<\n    PartialWithRequiredFields<\n      Omit<DAOCoinRequest, 'OperationType'>,\n      'UpdaterPublicKeyBase58Check' | 'ProfilePublicKeyBase58CheckOrUsername'\n    >\n  >;\nexport const disableMintingDeSoToken = (\n  params: DisableMintingDeSoTokenRequestParams,\n  options?: RequestOptions\n): Promise<ConstructedAndSubmittedTx<DAOCoinResponse>> => {\n  return handleSignAndSubmit(\n    'api/v0/dao-coin',\n    {\n      ...params,\n      OperationType: 'disable_minting',\n    },\n    { ...options, constructionFunction: constructDisableMintingDeSoToken }\n  );\n};\n\nexport const constructDisableMintingDeSoToken = (\n  params: DisableMintingDeSoTokenRequestParams\n): Promise<ConstructedTransactionResponse> => {\n  const metadata = new TransactionMetadataDAOCoin();\n  if (!isMaybeDeSoPublicKey(params.ProfilePublicKeyBase58CheckOrUsername)) {\n    return Promise.reject(\n      'must provide profile public key, not username for local transaction construction'\n    );\n  }\n  metadata.profilePublicKey = bs58PublicKeyToCompressedBytes(\n    params.ProfilePublicKeyBase58CheckOrUsername\n  );\n  metadata.operationType = 2;\n  return constructBalanceModelTx(params.UpdaterPublicKeyBase58Check, metadata, {\n    ExtraData: params.ExtraData,\n    MinFeeRateNanosPerKB: params.MinFeeRateNanosPerKB,\n    TransactionFees: params.TransactionFees,\n  });\n};\n\n/**\n * https://docs.deso.org/deso-backend/construct-transactions/dao-transactions-api#transfer-deso-token-dao-coin\n */\nexport const transferDeSoToken = async (\n  params: TxRequestWithOptionalFeesAndExtraData<TransferDAOCoinRequest>,\n  options?: TxRequestOptions\n): Promise<ConstructedAndSubmittedTx<TransferDAOCoinResponse>> => {\n  if (options?.checkPermissions !== false) {\n    const txWithFee = getTxWithFeeNanos(\n      params.SenderPublicKeyBase58Check,\n      new TransactionMetadataTransferDAOCoin(),\n      {\n        // TODO: I'm not sure exactly what outputs are needed here... for the time\n        // being I'm just adding a static 1500 nanos to make sure the derived key\n        // transaction can be submitted.\n        // Outputs: ...,\n        ExtraData: params.ExtraData,\n        MinFeeRateNanosPerKB: params.MinFeeRateNanosPerKB,\n        TransactionFees: params.TransactionFees,\n      }\n    );\n\n    if (!isMaybeDeSoPublicKey(params.ProfilePublicKeyBase58CheckOrUsername)) {\n      return Promise.reject(\n        'must provide profile public key, not username for ProfilePublicKeyBase58CheckOrUsername when checking dao coin transfer permissions'\n      );\n    }\n    await guardTxPermission({\n      GlobalDESOLimit:\n        // TODO: when I figure out how to properly calculate the fee for this transaction\n        // we can remove this static 1500 buffer.\n        txWithFee.feeNanos + sumTransactionFees(params.TransactionFees) + 1500,\n      TransactionCountLimitMap: {\n        DAO_COIN_TRANSFER:\n          options?.txLimitCount ??\n          identity.transactionSpendingLimitOptions.TransactionCountLimitMap\n            ?.DAO_COIN_TRANSFER ??\n          1,\n      },\n      DAOCoinOperationLimitMap: {\n        [params.ProfilePublicKeyBase58CheckOrUsername]: {\n          transfer: 1,\n        },\n      },\n    });\n  }\n\n  return handleSignAndSubmit('api/v0/transfer-dao-coin', params, {\n    ...options,\n    constructionFunction: constructTransferDeSoToken,\n  });\n};\n\nexport const constructTransferDeSoToken = (\n  params: TxRequestWithOptionalFeesAndExtraData<TransferDAOCoinRequest>\n): Promise<ConstructedTransactionResponse> => {\n  if (!isMaybeDeSoPublicKey(params.ProfilePublicKeyBase58CheckOrUsername)) {\n    return Promise.reject(\n      'must provide profile public key, not username for local transaction construction'\n    );\n  }\n  const metadata = new TransactionMetadataTransferDAOCoin();\n  metadata.daoCoinToTransferNanos = hexToBytes(\n    params.DAOCoinToTransferNanos.replace('0x', 'x')\n  );\n  metadata.profilePublicKey = bs58PublicKeyToCompressedBytes(\n    params.ProfilePublicKeyBase58CheckOrUsername\n  );\n  metadata.receiverPublicKey = bs58PublicKeyToCompressedBytes(\n    params.ReceiverPublicKeyBase58CheckOrUsername\n  );\n  return constructBalanceModelTx(params.SenderPublicKeyBase58Check, metadata, {\n    ExtraData: params.ExtraData,\n    MinFeeRateNanosPerKB: params.MinFeeRateNanosPerKB,\n    TransactionFees: params.TransactionFees,\n  });\n};\n\n// TODO: Balance model transaction construction for limit orders.\n/**\n * https://docs.deso.org/deso-backend/construct-transactions/dao-transactions-api#create-deso-token-dao-coin-limit-order\n */\nexport const createDeSoTokenLimitOrder = (\n  params: DAOCoinLimitOrderRequest,\n  options?: RequestOptions\n): Promise<ConstructedAndSubmittedTx<DAOCoinOrderResponse>> => {\n  return handleSignAndSubmit(\n    'api/v0/create-dao-coin-limit-order',\n    {\n      ...params,\n    },\n    options\n  );\n};\n\nexport const createDeSoTokenMarketOrder = (\n  params: DAOCoinMarketOrderRequest,\n  options?: RequestOptions\n): Promise<ConstructedAndSubmittedTx<DAOCoinOrderResponse>> => {\n  return handleSignAndSubmit(\n    'api/v0/create-dao-coin-market-order',\n    {\n      ...params,\n    },\n    options\n  );\n};\n\nexport const buyDeSoTokenMarketOrder = (\n  params: PartialWithRequiredFields<\n    Omit<\n      DAOCoinMarketOrderRequest,\n      'SellingDAOCoinCreatorPublicKeyBase58Check' | 'OperationType'\n    >,\n    | 'TransactorPublicKeyBase58Check'\n    | 'BuyingDAOCoinCreatorPublicKeyBase58Check'\n    | 'Quantity'\n  >,\n  options?: RequestOptions\n): Promise<ConstructedAndSubmittedTx<DAOCoinOrderResponse>> => {\n  return handleSignAndSubmit(\n    'api/v0/create-dao-coin-market-order',\n    {\n      ...params,\n      SellingDAOCoinCreatorPublicKeyBase58Check: '',\n      OperationType: 'BID',\n    },\n    options\n  );\n};\n\nexport const sellDeSoTokenMarketOrder = (\n  params: PartialWithRequiredFields<\n    Omit<\n      DAOCoinMarketOrderRequest,\n      'BuyingDAOCoinCreatorPublicKeyBase58Check' | 'OperationType'\n    >,\n    | 'TransactorPublicKeyBase58Check'\n    | 'SellingDAOCoinCreatorPublicKeyBase58Check'\n    | 'Quantity'\n  >,\n  options?: RequestOptions\n): Promise<ConstructedAndSubmittedTx<DAOCoinOrderResponse>> => {\n  return handleSignAndSubmit(\n    'api/v0/create-dao-coin-market-order',\n    {\n      ...params,\n      SellingDAOCoinCreatorPublicKeyBase58Check: '',\n      OperationType: 'ASK',\n    },\n    options\n  );\n};\n\n/**\n * https://docs.deso.org/deso-backend/construct-transactions/dao-transactions-api#cancel-deso-token-dao-coin-limit-order\n */\nexport const cancelDeSoTokenLimitOrder = (\n  params: TxRequestWithOptionalFeesAndExtraData<DAOCoinLimitOrderWithCancelOrderIDRequest>,\n  options?: RequestOptions\n): Promise<ConstructedAndSubmittedTx<DAOCoinOrderResponse>> => {\n  return handleSignAndSubmit(\n    'api/v0/cancel-dao-coin-limit-order',\n    params,\n    options\n  );\n};\n"]}

@@ -6,4 +6,10 @@ import { BuyOrSellCreatorCoinRequest, BuyOrSellCreatorCoinResponse, ConstructedTransactionResponse, SendDeSoRequest, SendDeSoResponse, TransferCreatorCoinRequest, TransferCreatorCoinResponse, TxRequestWithOptionalFeesAndExtraData } from '../backend-types/index.js';

* https://docs.deso.org/deso-backend/construct-transactions/financial-transactions-api#send-deso
*
* NOTE: In the case of a max send, the AmountNanos param will be a -1, which
* is not useful for calculating the GlobalDESOLimit. In this case, the caller
* should provide the optional spendingLimitAmountNanos to be used instead.
*/
export declare const sendDeso: (params: TxRequestWithOptionalFeesAndExtraData<SendDeSoRequest>, options?: TxRequestOptions) => Promise<ConstructedAndSubmittedTx<SendDeSoResponse | ConstructedTransactionResponse>>;
export declare const sendDeso: (params: TxRequestWithOptionalFeesAndExtraData<SendDeSoRequest>, options?: TxRequestOptions & {
spendingLimitAmountNanos?: number;
}) => Promise<ConstructedAndSubmittedTx<SendDeSoResponse | ConstructedTransactionResponse>>;
export declare const constructSendDeSoTransaction: (params: TxRequestWithOptionalFeesAndExtraData<SendDeSoRequest>) => Promise<ConstructedTransactionResponse>;

@@ -10,0 +16,0 @@ /**

@@ -6,2 +6,6 @@ import { TransactionMetadataBasicTransfer, TransactionMetadataCreatorCoin, TransactionMetadataCreatorCoinTransfer, TransactionOutput, bs58PublicKeyToCompressedBytes, identity, } from '../identity/index.js';

* https://docs.deso.org/deso-backend/construct-transactions/financial-transactions-api#send-deso
*
* NOTE: In the case of a max send, the AmountNanos param will be a -1, which
* is not useful for calculating the GlobalDESOLimit. In this case, the caller
* should provide the optional spendingLimitAmountNanos to be used instead.
*/

@@ -25,4 +29,7 @@ export const sendDeso = async (params, options) => {

if (options?.checkPermissions !== false) {
const amountNanos = typeof options?.spendingLimitAmountNanos === 'number'
? options.spendingLimitAmountNanos
: params.AmountNanos;
await guardTxPermission({
GlobalDESOLimit: params.AmountNanos +
GlobalDESOLimit: amountNanos +
txWithFee.feeNanos +

@@ -172,2 +179,2 @@ sumTransactionFees(params.TransactionFees),

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"financial.js","sourceRoot":"","sources":["../../../src/transactions/financial.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  BuyOrSellCreatorCoinRequest,\n  BuyOrSellCreatorCoinResponse,\n  ConstructedTransactionResponse,\n  SendDeSoRequest,\n  SendDeSoResponse,\n  TransferCreatorCoinRequest,\n  TransferCreatorCoinResponse,\n  TxRequestWithOptionalFeesAndExtraData,\n} from '../backend-types/index.js';\nimport { PartialWithRequiredFields } from '../data/index.js';\nimport {\n  TransactionMetadataBasicTransfer,\n  TransactionMetadataCreatorCoin,\n  TransactionMetadataCreatorCoinTransfer,\n  TransactionOutput,\n  bs58PublicKeyToCompressedBytes,\n  identity,\n} from '../identity/index.js';\nimport {\n  constructBalanceModelTx,\n  getTxWithFeeNanos,\n  handleSignAndSubmit,\n  isMaybeDeSoPublicKey,\n  sumTransactionFees,\n} from '../internal.js';\nimport { ConstructedAndSubmittedTx, TxRequestOptions } from '../types.js';\nimport { guardTxPermission } from './utils.js';\n\n/**\n * https://docs.deso.org/deso-backend/construct-transactions/financial-transactions-api#send-deso\n */\nexport const sendDeso = async (\n  params: TxRequestWithOptionalFeesAndExtraData<SendDeSoRequest>,\n  options?: TxRequestOptions\n): Promise<\n  ConstructedAndSubmittedTx<SendDeSoResponse | ConstructedTransactionResponse>\n> => {\n  const txWithFee = getTxWithFeeNanos(\n    params.SenderPublicKeyBase58Check,\n    new TransactionMetadataBasicTransfer(),\n    {\n      Outputs: buildSendDeSoOutputs({\n        ...params,\n        // NOTE: this is a bit of an odd hack, but bc we are only using this to\n        // estimate the fee, we can overwrite the recipient to be the sender to\n        // ensure the value is a valid public key that can be converted to\n        // bytes. The reason we cannot make an api call to get the true public\n        // key is because it could cause the derived key re-approval popup to\n        // get blocked by browser popup blockers.\n        RecipientPublicKeyOrUsername: params.SenderPublicKeyBase58Check,\n      }),\n      ExtraData: params.ExtraData,\n      MinFeeRateNanosPerKB: params.MinFeeRateNanosPerKB,\n      TransactionFees: params.TransactionFees,\n    }\n  );\n\n  if (options?.checkPermissions !== false) {\n    await guardTxPermission({\n      GlobalDESOLimit:\n        params.AmountNanos +\n        txWithFee.feeNanos +\n        sumTransactionFees(params.TransactionFees),\n      TransactionCountLimitMap: {\n        BASIC_TRANSFER:\n          options?.txLimitCount ??\n          identity.transactionSpendingLimitOptions.TransactionCountLimitMap\n            ?.BASIC_TRANSFER ??\n          1,\n      },\n    });\n  }\n\n  return handleSignAndSubmit('api/v0/send-deso', params, {\n    ...options,\n    constructionFunction: constructSendDeSoTransaction,\n  });\n};\n\nconst buildSendDeSoOutputs = (\n  params: TxRequestWithOptionalFeesAndExtraData<SendDeSoRequest>\n) => {\n  const transactionOutput = new TransactionOutput();\n  transactionOutput.amountNanos = params.AmountNanos;\n  transactionOutput.publicKey = bs58PublicKeyToCompressedBytes(\n    // FIXME: this will throw an error if the recipient is a username. We need\n    // to either fetch the public key and overwrite the username with it or\n    // throw a more helpful error to consumers explaining that we require the\n    // public key instead of the username.\n    params.RecipientPublicKeyOrUsername\n  );\n  return [transactionOutput];\n};\n\nexport const constructSendDeSoTransaction = (\n  params: TxRequestWithOptionalFeesAndExtraData<SendDeSoRequest>\n): Promise<ConstructedTransactionResponse> => {\n  if (!isMaybeDeSoPublicKey(params.RecipientPublicKeyOrUsername)) {\n    throw new Error(\n      'must provide public key, not user name for local construction'\n    );\n  }\n\n  return constructBalanceModelTx(\n    params.SenderPublicKeyBase58Check,\n    new TransactionMetadataBasicTransfer(),\n    {\n      Outputs: buildSendDeSoOutputs(params),\n      ExtraData: params.ExtraData,\n      MinFeeRateNanosPerKB: params.MinFeeRateNanosPerKB,\n      TransactionFees: params.TransactionFees,\n      Nonce: params.Nonce,\n    }\n  );\n};\n\n// TODO: BUY creator coins is hard. Need to move some\n// big float math into js.\n/**\n * https://docs.deso.org/deso-backend/construct-transactions/financial-transactions-api#buy-or-sell-creator-coin\n */\nexport type BuyCreatorCoinRequestParams = TxRequestWithOptionalFeesAndExtraData<\n  PartialWithRequiredFields<\n    Omit<\n      BuyOrSellCreatorCoinRequest,\n      'CreatorCoinToSellNanos' | 'OperationType'\n    >,\n    | 'UpdaterPublicKeyBase58Check'\n    | 'CreatorPublicKeyBase58Check'\n    | 'DeSoToSellNanos'\n  >\n>;\nexport const buyCreatorCoin = async (\n  params: BuyCreatorCoinRequestParams,\n  options?: TxRequestOptions\n): Promise<\n  ConstructedAndSubmittedTx<\n    BuyOrSellCreatorCoinResponse | ConstructedTransactionResponse\n  >\n> => {\n  const txWithFee = getTxWithFeeNanos(\n    params.UpdaterPublicKeyBase58Check,\n    buildBuyCreatorCoinMetadata(params),\n    {\n      ExtraData: params.ExtraData,\n      MinFeeRateNanosPerKB: params.MinFeeRateNanosPerKB,\n      TransactionFees: params.TransactionFees,\n    }\n  );\n\n  if (options?.checkPermissions !== false) {\n    await guardTxPermission({\n      GlobalDESOLimit:\n        params.DeSoToSellNanos +\n        txWithFee.feeNanos +\n        sumTransactionFees(params.TransactionFees),\n      CreatorCoinOperationLimitMap: {\n        [params.CreatorPublicKeyBase58Check]: {\n          buy: options?.txLimitCount ?? 1,\n        },\n      },\n    });\n  }\n\n  return handleSignAndSubmit(\n    'api/v0/buy-or-sell-creator-coin',\n    {\n      ...params,\n      OperationType: 'buy',\n    },\n    options\n  );\n};\n\n// TODO: SELL creator coins is hard. Need to move some\n// big float math into js.\n/**\n * https://docs.deso.org/deso-backend/construct-transactions/financial-transactions-api#buy-or-sell-creator-coin\n */\n\nexport type SellCreatorCoinRequestParams =\n  TxRequestWithOptionalFeesAndExtraData<\n    PartialWithRequiredFields<\n      Omit<BuyOrSellCreatorCoinRequest, 'DesoToSellNanos' | 'OperationType'>,\n      | 'UpdaterPublicKeyBase58Check'\n      | 'CreatorPublicKeyBase58Check'\n      | 'CreatorCoinToSellNanos'\n    >\n  >;\n\nexport const sellCreatorCoin = async (\n  params: SellCreatorCoinRequestParams,\n  options?: TxRequestOptions\n): Promise<\n  ConstructedAndSubmittedTx<\n    BuyOrSellCreatorCoinResponse | ConstructedTransactionResponse\n  >\n> => {\n  const txWithFee = getTxWithFeeNanos(\n    params.UpdaterPublicKeyBase58Check,\n    buildSellCreatorCoinMetadata(params),\n    {\n      ExtraData: params.ExtraData,\n      MinFeeRateNanosPerKB: params.MinFeeRateNanosPerKB,\n      TransactionFees: params.TransactionFees,\n    }\n  );\n\n  if (options?.checkPermissions !== false) {\n    await guardTxPermission({\n      GlobalDESOLimit:\n        txWithFee.feeNanos + sumTransactionFees(params.TransactionFees),\n      CreatorCoinOperationLimitMap: {\n        [params.CreatorPublicKeyBase58Check]: {\n          sell: options?.txLimitCount ?? 1,\n        },\n      },\n    });\n  }\n\n  return handleSignAndSubmit(\n    'api/v0/buy-or-sell-creator-coin',\n    {\n      ...params,\n      OperationType: 'sell',\n    },\n    options\n  );\n};\n\n/**\n * https://docs.deso.org/deso-backend/construct-transactions/financial-transactions-api#transfer-creator-coin\n */\nexport type TransferCreatorCoinRequestParams =\n  TxRequestWithOptionalFeesAndExtraData<\n    PartialWithRequiredFields<\n      TransferCreatorCoinRequest,\n      | 'SenderPublicKeyBase58Check'\n      | 'CreatorPublicKeyBase58Check'\n      | 'ReceiverUsernameOrPublicKeyBase58Check'\n      | 'CreatorCoinToTransferNanos'\n    >\n  >;\nexport const transferCreatorCoin = async (\n  params: TransferCreatorCoinRequestParams,\n  options?: TxRequestOptions\n): Promise<ConstructedAndSubmittedTx<TransferCreatorCoinResponse>> => {\n  const txWithFee = getTxWithFeeNanos(\n    params.SenderPublicKeyBase58Check,\n    buildTransferCreatorCoinMetadata(params),\n    {\n      ExtraData: params.ExtraData,\n      MinFeeRateNanosPerKB: params.MinFeeRateNanosPerKB,\n      TransactionFees: params.TransactionFees,\n    }\n  );\n\n  if (options?.checkPermissions !== false) {\n    await guardTxPermission({\n      GlobalDESOLimit:\n        txWithFee.feeNanos + sumTransactionFees(params.TransactionFees),\n      CreatorCoinOperationLimitMap: {\n        [params.CreatorPublicKeyBase58Check]: {\n          transfer: options?.txLimitCount ?? 1,\n        },\n      },\n    });\n  }\n\n  return handleSignAndSubmit('api/v0/transfer-creator-coin', params, {\n    ...options,\n    constructionFunction: constructTransferCreatorCoinTransaction,\n  });\n};\n\nconst buildTransferCreatorCoinMetadata = (\n  params: TransferCreatorCoinRequestParams\n) => {\n  const metadata = new TransactionMetadataCreatorCoinTransfer();\n  metadata.creatorCoinToTransferNanos = params.CreatorCoinToTransferNanos;\n  metadata.profilePublicKey = bs58PublicKeyToCompressedBytes(\n    params.CreatorPublicKeyBase58Check\n  );\n  metadata.receiverPublicKey = bs58PublicKeyToCompressedBytes(\n    params.ReceiverUsernameOrPublicKeyBase58Check\n  );\n\n  return metadata;\n};\n\nconst constructTransferCreatorCoinTransaction = (\n  params: TransferCreatorCoinRequestParams\n): Promise<ConstructedTransactionResponse> => {\n  if (!isMaybeDeSoPublicKey(params.ReceiverUsernameOrPublicKeyBase58Check)) {\n    return Promise.reject(\n      'must provide public key, not user name for local construction'\n    );\n  }\n  return constructBalanceModelTx(\n    params.SenderPublicKeyBase58Check,\n    buildTransferCreatorCoinMetadata(params),\n    {\n      ExtraData: params.ExtraData,\n      MinFeeRateNanosPerKB: params.MinFeeRateNanosPerKB,\n      TransactionFees: params.TransactionFees,\n    }\n  );\n};\n\nconst buildBuyCreatorCoinMetadata = (params: BuyCreatorCoinRequestParams) => {\n  // NOTE: This is not exactly accurate and gives an upper bound estimate for\n  // minCreatorCoinExpectedNanos. It should not but used for actual tx\n  // construction, but it is useful for estimating tx fees.\n  const metadata = new TransactionMetadataCreatorCoin();\n  metadata.profilePublicKey = bs58PublicKeyToCompressedBytes(\n    params.CreatorPublicKeyBase58Check\n  );\n  metadata.operationType = 0;\n  metadata.desoToSellNanos = params.DeSoToSellNanos;\n  metadata.minCreatorCoinExpectedNanos =\n    params.MinCreatorCoinExpectedNanos ?? Number.MAX_SAFE_INTEGER;\n\n  return metadata;\n};\n\nconst buildSellCreatorCoinMetadata = (params: SellCreatorCoinRequestParams) => {\n  // NOTE: This is not exactly accurate and gives an upper bound estimate for\n  // minDeSoExpectedNanos. It should not but used for actual tx construction,\n  // but it is useful for estimating tx fees.\n  const metadata = new TransactionMetadataCreatorCoin();\n  metadata.profilePublicKey = bs58PublicKeyToCompressedBytes(\n    params.CreatorPublicKeyBase58Check\n  );\n  metadata.operationType = 1;\n  metadata.creatorCoinToSellNanos = params.CreatorCoinToSellNanos;\n  metadata.minDeSoExpectedNanos =\n    params.MinDeSoExpectedNanos ?? Number.MAX_SAFE_INTEGER;\n\n  return metadata;\n};\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"financial.js","sourceRoot":"","sources":["../../../src/transactions/financial.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  BuyOrSellCreatorCoinRequest,\n  BuyOrSellCreatorCoinResponse,\n  ConstructedTransactionResponse,\n  SendDeSoRequest,\n  SendDeSoResponse,\n  TransferCreatorCoinRequest,\n  TransferCreatorCoinResponse,\n  TxRequestWithOptionalFeesAndExtraData,\n} from '../backend-types/index.js';\nimport { PartialWithRequiredFields } from '../data/index.js';\nimport {\n  TransactionMetadataBasicTransfer,\n  TransactionMetadataCreatorCoin,\n  TransactionMetadataCreatorCoinTransfer,\n  TransactionOutput,\n  bs58PublicKeyToCompressedBytes,\n  identity,\n} from '../identity/index.js';\nimport {\n  constructBalanceModelTx,\n  getTxWithFeeNanos,\n  handleSignAndSubmit,\n  isMaybeDeSoPublicKey,\n  sumTransactionFees,\n} from '../internal.js';\nimport { ConstructedAndSubmittedTx, TxRequestOptions } from '../types.js';\nimport { guardTxPermission } from './utils.js';\n\n/**\n * https://docs.deso.org/deso-backend/construct-transactions/financial-transactions-api#send-deso\n *\n * NOTE: In the case of a max send, the AmountNanos param will be a -1, which\n * is not useful for calculating the GlobalDESOLimit. In this case, the caller\n * should provide the optional spendingLimitAmountNanos to be used instead.\n */\nexport const sendDeso = async (\n  params: TxRequestWithOptionalFeesAndExtraData<SendDeSoRequest>,\n  options?: TxRequestOptions & { spendingLimitAmountNanos?: number }\n): Promise<\n  ConstructedAndSubmittedTx<SendDeSoResponse | ConstructedTransactionResponse>\n> => {\n  const txWithFee = getTxWithFeeNanos(\n    params.SenderPublicKeyBase58Check,\n    new TransactionMetadataBasicTransfer(),\n    {\n      Outputs: buildSendDeSoOutputs({\n        ...params,\n        // NOTE: this is a bit of an odd hack, but bc we are only using this to\n        // estimate the fee, we can overwrite the recipient to be the sender to\n        // ensure the value is a valid public key that can be converted to\n        // bytes. The reason we cannot make an api call to get the true public\n        // key is because it could cause the derived key re-approval popup to\n        // get blocked by browser popup blockers.\n        RecipientPublicKeyOrUsername: params.SenderPublicKeyBase58Check,\n      }),\n      ExtraData: params.ExtraData,\n      MinFeeRateNanosPerKB: params.MinFeeRateNanosPerKB,\n      TransactionFees: params.TransactionFees,\n    }\n  );\n\n  if (options?.checkPermissions !== false) {\n    const amountNanos =\n      typeof options?.spendingLimitAmountNanos === 'number'\n        ? options.spendingLimitAmountNanos\n        : params.AmountNanos;\n\n    await guardTxPermission({\n      GlobalDESOLimit:\n        amountNanos +\n        txWithFee.feeNanos +\n        sumTransactionFees(params.TransactionFees),\n      TransactionCountLimitMap: {\n        BASIC_TRANSFER:\n          options?.txLimitCount ??\n          identity.transactionSpendingLimitOptions.TransactionCountLimitMap\n            ?.BASIC_TRANSFER ??\n          1,\n      },\n    });\n  }\n\n  return handleSignAndSubmit('api/v0/send-deso', params, {\n    ...options,\n    constructionFunction: constructSendDeSoTransaction,\n  });\n};\n\nconst buildSendDeSoOutputs = (\n  params: TxRequestWithOptionalFeesAndExtraData<SendDeSoRequest>\n) => {\n  const transactionOutput = new TransactionOutput();\n  transactionOutput.amountNanos = params.AmountNanos;\n  transactionOutput.publicKey = bs58PublicKeyToCompressedBytes(\n    // FIXME: this will throw an error if the recipient is a username. We need\n    // to either fetch the public key and overwrite the username with it or\n    // throw a more helpful error to consumers explaining that we require the\n    // public key instead of the username.\n    params.RecipientPublicKeyOrUsername\n  );\n  return [transactionOutput];\n};\n\nexport const constructSendDeSoTransaction = (\n  params: TxRequestWithOptionalFeesAndExtraData<SendDeSoRequest>\n): Promise<ConstructedTransactionResponse> => {\n  if (!isMaybeDeSoPublicKey(params.RecipientPublicKeyOrUsername)) {\n    throw new Error(\n      'must provide public key, not user name for local construction'\n    );\n  }\n\n  return constructBalanceModelTx(\n    params.SenderPublicKeyBase58Check,\n    new TransactionMetadataBasicTransfer(),\n    {\n      Outputs: buildSendDeSoOutputs(params),\n      ExtraData: params.ExtraData,\n      MinFeeRateNanosPerKB: params.MinFeeRateNanosPerKB,\n      TransactionFees: params.TransactionFees,\n      Nonce: params.Nonce,\n    }\n  );\n};\n\n// TODO: BUY creator coins is hard. Need to move some\n// big float math into js.\n/**\n * https://docs.deso.org/deso-backend/construct-transactions/financial-transactions-api#buy-or-sell-creator-coin\n */\nexport type BuyCreatorCoinRequestParams = TxRequestWithOptionalFeesAndExtraData<\n  PartialWithRequiredFields<\n    Omit<\n      BuyOrSellCreatorCoinRequest,\n      'CreatorCoinToSellNanos' | 'OperationType'\n    >,\n    | 'UpdaterPublicKeyBase58Check'\n    | 'CreatorPublicKeyBase58Check'\n    | 'DeSoToSellNanos'\n  >\n>;\nexport const buyCreatorCoin = async (\n  params: BuyCreatorCoinRequestParams,\n  options?: TxRequestOptions\n): Promise<\n  ConstructedAndSubmittedTx<\n    BuyOrSellCreatorCoinResponse | ConstructedTransactionResponse\n  >\n> => {\n  const txWithFee = getTxWithFeeNanos(\n    params.UpdaterPublicKeyBase58Check,\n    buildBuyCreatorCoinMetadata(params),\n    {\n      ExtraData: params.ExtraData,\n      MinFeeRateNanosPerKB: params.MinFeeRateNanosPerKB,\n      TransactionFees: params.TransactionFees,\n    }\n  );\n\n  if (options?.checkPermissions !== false) {\n    await guardTxPermission({\n      GlobalDESOLimit:\n        params.DeSoToSellNanos +\n        txWithFee.feeNanos +\n        sumTransactionFees(params.TransactionFees),\n      CreatorCoinOperationLimitMap: {\n        [params.CreatorPublicKeyBase58Check]: {\n          buy: options?.txLimitCount ?? 1,\n        },\n      },\n    });\n  }\n\n  return handleSignAndSubmit(\n    'api/v0/buy-or-sell-creator-coin',\n    {\n      ...params,\n      OperationType: 'buy',\n    },\n    options\n  );\n};\n\n// TODO: SELL creator coins is hard. Need to move some\n// big float math into js.\n/**\n * https://docs.deso.org/deso-backend/construct-transactions/financial-transactions-api#buy-or-sell-creator-coin\n */\n\nexport type SellCreatorCoinRequestParams =\n  TxRequestWithOptionalFeesAndExtraData<\n    PartialWithRequiredFields<\n      Omit<BuyOrSellCreatorCoinRequest, 'DesoToSellNanos' | 'OperationType'>,\n      | 'UpdaterPublicKeyBase58Check'\n      | 'CreatorPublicKeyBase58Check'\n      | 'CreatorCoinToSellNanos'\n    >\n  >;\n\nexport const sellCreatorCoin = async (\n  params: SellCreatorCoinRequestParams,\n  options?: TxRequestOptions\n): Promise<\n  ConstructedAndSubmittedTx<\n    BuyOrSellCreatorCoinResponse | ConstructedTransactionResponse\n  >\n> => {\n  const txWithFee = getTxWithFeeNanos(\n    params.UpdaterPublicKeyBase58Check,\n    buildSellCreatorCoinMetadata(params),\n    {\n      ExtraData: params.ExtraData,\n      MinFeeRateNanosPerKB: params.MinFeeRateNanosPerKB,\n      TransactionFees: params.TransactionFees,\n    }\n  );\n\n  if (options?.checkPermissions !== false) {\n    await guardTxPermission({\n      GlobalDESOLimit:\n        txWithFee.feeNanos + sumTransactionFees(params.TransactionFees),\n      CreatorCoinOperationLimitMap: {\n        [params.CreatorPublicKeyBase58Check]: {\n          sell: options?.txLimitCount ?? 1,\n        },\n      },\n    });\n  }\n\n  return handleSignAndSubmit(\n    'api/v0/buy-or-sell-creator-coin',\n    {\n      ...params,\n      OperationType: 'sell',\n    },\n    options\n  );\n};\n\n/**\n * https://docs.deso.org/deso-backend/construct-transactions/financial-transactions-api#transfer-creator-coin\n */\nexport type TransferCreatorCoinRequestParams =\n  TxRequestWithOptionalFeesAndExtraData<\n    PartialWithRequiredFields<\n      TransferCreatorCoinRequest,\n      | 'SenderPublicKeyBase58Check'\n      | 'CreatorPublicKeyBase58Check'\n      | 'ReceiverUsernameOrPublicKeyBase58Check'\n      | 'CreatorCoinToTransferNanos'\n    >\n  >;\nexport const transferCreatorCoin = async (\n  params: TransferCreatorCoinRequestParams,\n  options?: TxRequestOptions\n): Promise<ConstructedAndSubmittedTx<TransferCreatorCoinResponse>> => {\n  const txWithFee = getTxWithFeeNanos(\n    params.SenderPublicKeyBase58Check,\n    buildTransferCreatorCoinMetadata(params),\n    {\n      ExtraData: params.ExtraData,\n      MinFeeRateNanosPerKB: params.MinFeeRateNanosPerKB,\n      TransactionFees: params.TransactionFees,\n    }\n  );\n\n  if (options?.checkPermissions !== false) {\n    await guardTxPermission({\n      GlobalDESOLimit:\n        txWithFee.feeNanos + sumTransactionFees(params.TransactionFees),\n      CreatorCoinOperationLimitMap: {\n        [params.CreatorPublicKeyBase58Check]: {\n          transfer: options?.txLimitCount ?? 1,\n        },\n      },\n    });\n  }\n\n  return handleSignAndSubmit('api/v0/transfer-creator-coin', params, {\n    ...options,\n    constructionFunction: constructTransferCreatorCoinTransaction,\n  });\n};\n\nconst buildTransferCreatorCoinMetadata = (\n  params: TransferCreatorCoinRequestParams\n) => {\n  const metadata = new TransactionMetadataCreatorCoinTransfer();\n  metadata.creatorCoinToTransferNanos = params.CreatorCoinToTransferNanos;\n  metadata.profilePublicKey = bs58PublicKeyToCompressedBytes(\n    params.CreatorPublicKeyBase58Check\n  );\n  metadata.receiverPublicKey = bs58PublicKeyToCompressedBytes(\n    params.ReceiverUsernameOrPublicKeyBase58Check\n  );\n\n  return metadata;\n};\n\nconst constructTransferCreatorCoinTransaction = (\n  params: TransferCreatorCoinRequestParams\n): Promise<ConstructedTransactionResponse> => {\n  if (!isMaybeDeSoPublicKey(params.ReceiverUsernameOrPublicKeyBase58Check)) {\n    return Promise.reject(\n      'must provide public key, not user name for local construction'\n    );\n  }\n  return constructBalanceModelTx(\n    params.SenderPublicKeyBase58Check,\n    buildTransferCreatorCoinMetadata(params),\n    {\n      ExtraData: params.ExtraData,\n      MinFeeRateNanosPerKB: params.MinFeeRateNanosPerKB,\n      TransactionFees: params.TransactionFees,\n    }\n  );\n};\n\nconst buildBuyCreatorCoinMetadata = (params: BuyCreatorCoinRequestParams) => {\n  // NOTE: This is not exactly accurate and gives an upper bound estimate for\n  // minCreatorCoinExpectedNanos. It should not but used for actual tx\n  // construction, but it is useful for estimating tx fees.\n  const metadata = new TransactionMetadataCreatorCoin();\n  metadata.profilePublicKey = bs58PublicKeyToCompressedBytes(\n    params.CreatorPublicKeyBase58Check\n  );\n  metadata.operationType = 0;\n  metadata.desoToSellNanos = params.DeSoToSellNanos;\n  metadata.minCreatorCoinExpectedNanos =\n    params.MinCreatorCoinExpectedNanos ?? Number.MAX_SAFE_INTEGER;\n\n  return metadata;\n};\n\nconst buildSellCreatorCoinMetadata = (params: SellCreatorCoinRequestParams) => {\n  // NOTE: This is not exactly accurate and gives an upper bound estimate for\n  // minDeSoExpectedNanos. It should not but used for actual tx construction,\n  // but it is useful for estimating tx fees.\n  const metadata = new TransactionMetadataCreatorCoin();\n  metadata.profilePublicKey = bs58PublicKeyToCompressedBytes(\n    params.CreatorPublicKeyBase58Check\n  );\n  metadata.operationType = 1;\n  metadata.creatorCoinToSellNanos = params.CreatorCoinToSellNanos;\n  metadata.minDeSoExpectedNanos =\n    params.MinDeSoExpectedNanos ?? Number.MAX_SAFE_INTEGER;\n\n  return metadata;\n};\n"]}
SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc