Skip to content

Commit

Permalink
Allow native USDC openWithPermit function
Browse files Browse the repository at this point in the history
  • Loading branch information
sisou committed Feb 27, 2024
1 parent 10d6a9b commit ba5a700
Show file tree
Hide file tree
Showing 11 changed files with 54 additions and 70 deletions.
10 changes: 5 additions & 5 deletions client/PublicRequestTypes.ts
Original file line number Diff line number Diff line change
Expand Up @@ -271,12 +271,12 @@ export interface BitcoinHtlcCreationInstructions {
}

export interface PolygonHtlcCreationInstructions extends RelayRequest {
type: 'USDC';
type: 'USDC_MATIC';
/**
* The sender's nonce in the token contract, required when calling the
* contract function `openWithApproval`.
* contract function `openWithPermit`.
*/
approval?: {
permit?: {
tokenNonce: number,
};
}
Expand Down Expand Up @@ -312,7 +312,7 @@ export interface BitcoinHtlcSettlementInstructions {
}

export interface PolygonHtlcSettlementInstructions extends RelayRequest {
type: 'USDC';
type: 'USDC_MATIC';
amount: number;
}

Expand Down Expand Up @@ -360,7 +360,7 @@ export interface BitcoinHtlcRefundInstructions {
}

export interface PolygonHtlcRefundInstructions extends RelayRequest {
type: 'USDC';
type: 'USDC_MATIC';
amount: number;
}

Expand Down
2 changes: 1 addition & 1 deletion client/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@
"types": "types/index.d.ts",
"dependencies": {
"@nimiq/core-web": "^1.6.1",
"@nimiq/fastspot-api": "^1.7.0",
"@nimiq/fastspot-api": "^1.8.0",
"@nimiq/rpc": "^0.4.0",
"@nimiq/utils": "^0.5.0",
"@opengsn/common": "^2.2.5",
Expand Down
8 changes: 4 additions & 4 deletions client/yarn.lock
Original file line number Diff line number Diff line change
Expand Up @@ -232,10 +232,10 @@
resolved "https://registry.yarnpkg.com/@nimiq/core-web/-/core-web-1.6.1.tgz#97cb5b43b257c7f6f6808ef603e9bf686377241f"
integrity sha512-WYw2brIxUXa/SQ0JRp0RXWQKzBFhROXrEjF9Eh+tRlC+NrI2ObwRQkwJCbP2qmPtYldIimfyECmsDVHFoyLXjQ==

"@nimiq/fastspot-api@^1.7.0":
version "1.7.0"
resolved "https://registry.yarnpkg.com/@nimiq/fastspot-api/-/fastspot-api-1.7.0.tgz#eea496f4898139c51971f0b177583c6cc6b06611"
integrity sha512-k7vSjYdjAiAQar+21v681Zrp9kN9uHMUw7/dyG2D/IrXqNPHkD133JyrzxPBga+myW411SUR4mtdPQRPQm3d/A==
"@nimiq/fastspot-api@^1.8.0":
version "1.8.0"
resolved "https://registry.yarnpkg.com/@nimiq/fastspot-api/-/fastspot-api-1.8.0.tgz#705a9e79e425c3e6536d8994fd0b39d88af1b268"
integrity sha512-qNkibJnxS8ndOn4tuy1m3lSNKybBYApo+wy1ajTKcQ0lHo3VfLY0sAJ+WRE7diVWCa7iumu6wsFVudyc3k8/NQ==

"@nimiq/rpc@^0.4.0":
version "0.4.0"
Expand Down
4 changes: 2 additions & 2 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -21,9 +21,9 @@
"dependencies": {
"@nimiq/browser-warning": "^1.1.1",
"@nimiq/electrum-client": "https://github.com/nimiq/electrum-client#build",
"@nimiq/fastspot-api": "^1.7.0",
"@nimiq/fastspot-api": "^1.8.0",
"@nimiq/iqons": "^1.5.2",
"@nimiq/keyguard-client": "^1.5.4",
"@nimiq/keyguard-client": "https://gitpkg.vercel.app/nimiq/keyguard?scripts.postinstall=cd%20client%20%26%26%20.%2Fbuild-gitpkg.sh&aaff49f9ea0b575208de60d38e27e05197332eef",
"@nimiq/ledger-api": "^2.3.0",
"@nimiq/network-client": "^0.6.2",
"@nimiq/oasis-api": "^1.1.1",
Expand Down
24 changes: 12 additions & 12 deletions src/lib/RequestParser.ts
Original file line number Diff line number Diff line change
Expand Up @@ -527,11 +527,11 @@ export class RequestParser {

// Validate and parse only what we use in the Hub

if (!['NIM', 'BTC', 'USDC', 'EUR'].includes(setupSwapRequest.fund.type)) {
if (!['NIM', 'BTC', 'USDC_MATIC', 'EUR'].includes(setupSwapRequest.fund.type)) {
throw new Error('Funding type is not supported');
}

if (!['NIM', 'BTC', 'USDC', 'EUR'].includes(setupSwapRequest.redeem.type)) {
if (!['NIM', 'BTC', 'USDC_MATIC', 'EUR'].includes(setupSwapRequest.redeem.type)) {
throw new Error('Redeeming type is not supported');
}

Expand Down Expand Up @@ -562,19 +562,19 @@ export class RequestParser {
throw new Error('When using the "slider" layout, `bitcoinAccount` must be provided');
}

const nimiqAddress = setupSwapRequest.fund.type === 'NIM'
const nimiqAddress = setupSwapRequest.fund.type === SwapAsset.NIM
? Nimiq.Address.fromAny(setupSwapRequest.fund.sender)
: setupSwapRequest.redeem.type === 'NIM'
: setupSwapRequest.redeem.type === SwapAsset.NIM
? Nimiq.Address.fromAny(setupSwapRequest.redeem.recipient)
: undefined;
if (nimiqAddress && !setupSwapRequest.nimiqAddresses.some(
({ address }) => Nimiq.Address.fromAny(address).equals(nimiqAddress))) {
throw new Error('The address details of the NIM address doing the swap must be provided');
}

const polygonAddress = setupSwapRequest.fund.type === 'USDC'
const polygonAddress = setupSwapRequest.fund.type === SwapAsset.USDC_MATIC
? setupSwapRequest.fund.request.from
: setupSwapRequest.redeem.type === 'USDC'
: setupSwapRequest.redeem.type === SwapAsset.USDC_MATIC
? setupSwapRequest.redeem.request.from
: undefined;
if (polygonAddress && !setupSwapRequest.polygonAddresses.some(
Expand All @@ -583,7 +583,7 @@ export class RequestParser {
}
}

if (setupSwapRequest.redeem.type === 'NIM') {
if (setupSwapRequest.redeem.type === SwapAsset.NIM) {
if (!setupSwapRequest.redeem.validityStartHeight
|| setupSwapRequest.redeem.validityStartHeight < 1) {
throw new Error(
Expand All @@ -592,7 +592,7 @@ export class RequestParser {
}
}

if (setupSwapRequest.fund.type === 'NIM') {
if (setupSwapRequest.fund.type === SwapAsset.NIM) {
if (!setupSwapRequest.fund.validityStartHeight
|| setupSwapRequest.fund.validityStartHeight < 1) {
throw new Error(`Invalid validity start height: ${setupSwapRequest.fund.validityStartHeight}`);
Expand Down Expand Up @@ -628,7 +628,7 @@ export class RequestParser {
} : setupSwapRequest.fund.type === 'BTC' ? {
...setupSwapRequest.fund,
type: SwapAsset[setupSwapRequest.fund.type],
} : setupSwapRequest.fund.type === 'USDC' ? {
} : setupSwapRequest.fund.type === 'USDC_MATIC' ? {
...setupSwapRequest.fund,
type: SwapAsset[setupSwapRequest.fund.type],
} : { // EUR
Expand All @@ -646,7 +646,7 @@ export class RequestParser {
} : setupSwapRequest.redeem.type === 'BTC' ? {
...setupSwapRequest.redeem,
type: SwapAsset[setupSwapRequest.redeem.type],
} : setupSwapRequest.redeem.type === 'USDC' ? {
} : setupSwapRequest.redeem.type === 'USDC_MATIC' ? {
...setupSwapRequest.redeem,
type: SwapAsset[setupSwapRequest.redeem.type],
} : { // EUR
Expand All @@ -664,8 +664,8 @@ export class RequestParser {
// Only basic parsing and validation. Refund transaction specific data will be validated by the Keyguard
// or subsequent Ledger transaction signing requests.

if (!['NIM', 'BTC', 'USDC'].includes(refundSwapRequest.refund.type)) {
throw new Error('Refunding object type must be "NIM", "BTC", or "USDC"');
if (!['NIM', 'BTC', 'USDC_MATIC'].includes(refundSwapRequest.refund.type)) {
throw new Error('Refunding object type must be "NIM", "BTC", or "USDC_MATIC"');
}

const parsedRefundSwapRequest: ParsedRefundSwapRequest = {
Expand Down
8 changes: 4 additions & 4 deletions src/lib/RequestTypes.ts
Original file line number Diff line number Diff line change
Expand Up @@ -198,8 +198,8 @@ export interface ParsedSetupSwapRequest extends ParsedSimpleRequest {
// htlcScript: Uint8Array,
refundAddress: string,
} | ({
type: SwapAsset.USDC,
approval?: {
type: SwapAsset.USDC_MATIC,
permit?: {
tokenNonce: number,
},
} & RelayRequest) | {
Expand Down Expand Up @@ -232,7 +232,7 @@ export interface ParsedSetupSwapRequest extends ParsedSimpleRequest {
value: number, // Sats
};
} | ({
type: SwapAsset.USDC,
type: SwapAsset.USDC_MATIC,
amount: number,
} & RelayRequest) | {
type: SwapAsset.EUR,
Expand Down Expand Up @@ -311,7 +311,7 @@ export interface ParsedRefundSwapRequest extends ParsedSimpleRequest {
};
refundAddress: string; // My address, must be refund address of HTLC
} | ({
type: SwapAsset.USDC,
type: SwapAsset.USDC_MATIC,
amount: number,
} & RelayRequest);
}
Expand Down
2 changes: 1 addition & 1 deletion src/views/RefundSwap.vue
Original file line number Diff line number Diff line change
Expand Up @@ -122,7 +122,7 @@ export default class RefundSwap extends BitcoinSyncBaseView {
this._signTransaction(signRequest);
}
if (refundInfo.type === SwapAsset.USDC) {
if (refundInfo.type === SwapAsset.USDC_MATIC) {
const signer = account.polygonAddresses.find((ai) => ai.address === refundInfo.request.from);
if (!signer) {
Expand Down
2 changes: 1 addition & 1 deletion src/views/RefundSwapSuccess.vue
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,7 @@ export default class SignBtcTransactionSuccess extends Vue {
return;
}
if ('message' in this.keyguardResult && this.request.refund.type === SwapAsset.USDC) {
if ('message' in this.keyguardResult && this.request.refund.type === SwapAsset.USDC_MATIC) {
const result: SignedPolygonTransaction = {
message: this.keyguardResult.message,
signature: this.keyguardResult.signature,
Expand Down
11 changes: 5 additions & 6 deletions src/views/SetupSwap.vue
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,6 @@ import { WalletInfo } from '../lib/WalletInfo';
import { BtcAddressInfo } from '../lib/bitcoin/BtcAddressInfo';
import { SwapAsset } from '@nimiq/fastspot-api';
import { DEFAULT_KEY_PATH } from '../lib/Constants';
import { threadId } from 'worker_threads';
// Import only types to avoid bundling of KeyguardClient in Ledger request if not required.
// (But note that currently, the KeyguardClient is still always bundled in the RpcApi).
Expand Down Expand Up @@ -183,7 +182,7 @@ export default class SetupSwap extends BitcoinSyncBaseView {
};
}
if (this.request.fund.type === SwapAsset.USDC) {
if (this.request.fund.type === SwapAsset.USDC_MATIC) {
const senderAddress = this.request.fund.request.from;
const signer = this._account.polygonAddresses.find((ai) => ai.address === senderAddress);
Expand All @@ -192,11 +191,11 @@ export default class SetupSwap extends BitcoinSyncBaseView {
}
fundingInfo = {
type: SwapAsset.USDC,
type: SwapAsset.USDC_MATIC,
keyPath: signer.path,
request: this.request.fund.request,
relayData: this.request.fund.relayData,
approval: this.request.fund.approval,
permit: this.request.fund.permit,
};
}
Expand Down Expand Up @@ -255,7 +254,7 @@ export default class SetupSwap extends BitcoinSyncBaseView {
};
}
if (this.request.redeem.type === SwapAsset.USDC) {
if (this.request.redeem.type === SwapAsset.USDC_MATIC) {
const senderAddress = this.request.redeem.request.from;
const signer = this._account.polygonAddresses.find((ai) => ai.address === senderAddress);
Expand All @@ -264,7 +263,7 @@ export default class SetupSwap extends BitcoinSyncBaseView {
}
redeemingInfo = {
type: SwapAsset.USDC,
type: SwapAsset.USDC_MATIC,
keyPath: signer.path,
request: this.request.redeem.request,
relayData: this.request.redeem.relayData,
Expand Down
24 changes: 12 additions & 12 deletions src/views/SetupSwapSuccess.vue
Original file line number Diff line number Diff line change
Expand Up @@ -84,7 +84,7 @@ export default class SetupSwapSuccess extends BitcoinSyncBaseView {
case SwapAsset.BTC:
refundAddress = this.request.fund.refundAddress;
break;
case SwapAsset.USDC:
case SwapAsset.USDC_MATIC:
refundAddress = this.request.fund.request.from;
break;
default: break;
Expand All @@ -98,7 +98,7 @@ export default class SetupSwapSuccess extends BitcoinSyncBaseView {
case SwapAsset.BTC:
redeemAddress = this.request.redeem.output.address;
break;
case SwapAsset.USDC:
case SwapAsset.USDC_MATIC:
redeemAddress = this.request.redeem.request.from;
break;
case SwapAsset.EUR:
Expand Down Expand Up @@ -228,8 +228,8 @@ export default class SetupSwapSuccess extends BitcoinSyncBaseView {
}
}
if (confirmedSwap.from.asset === SwapAsset.USDC || confirmedSwap.to.asset === SwapAsset.USDC) {
const contract = confirmedSwap.contracts[SwapAsset.USDC] as Contract<SwapAsset.USDC>;
if (confirmedSwap.from.asset === SwapAsset.USDC_MATIC || confirmedSwap.to.asset === SwapAsset.USDC_MATIC) {
const contract = confirmedSwap.contracts[SwapAsset.USDC_MATIC] as Contract<SwapAsset.USDC_MATIC>;
const htlc = contract.htlc as UsdcHtlcDetails;
const contractData = {
Expand All @@ -254,11 +254,11 @@ export default class SetupSwapSuccess extends BitcoinSyncBaseView {
}
hashRoot = contractData.hash;
if (confirmedSwap.from.asset === SwapAsset.USDC && refundAddress !== contractData.refundAddress) {
if (confirmedSwap.from.asset === SwapAsset.USDC_MATIC && refundAddress !== contractData.refundAddress) {
this.$rpc.reject(new Error('Unknown HTLC refund address'));
return;
}
if (confirmedSwap.to.asset === SwapAsset.USDC && redeemAddress !== contractData.recipientAddress) {
if (confirmedSwap.to.asset === SwapAsset.USDC_MATIC && redeemAddress !== contractData.recipientAddress) {
this.$rpc.reject(new Error('Unknown HTLC redeem address'));
return;
}
Expand Down Expand Up @@ -304,16 +304,16 @@ export default class SetupSwapSuccess extends BitcoinSyncBaseView {
};
}
if (this.request.fund.type === SwapAsset.USDC) {
const usdcHtlcData = confirmedSwap.contracts[SwapAsset.USDC]!.htlc as UsdcHtlcDetails;
if (this.request.fund.type === SwapAsset.USDC_MATIC) {
const usdcHtlcData = confirmedSwap.contracts[SwapAsset.USDC_MATIC]!.htlc as UsdcHtlcDetails;
if (!usdcHtlcData.data) {
// TODO: Create data with ethersJS
throw new Error('Missing `data` field in confirmed USDC contract');
}
fundingHtlcInfo = {
type: SwapAsset.USDC,
type: SwapAsset.USDC_MATIC,
htlcData: usdcHtlcData.data,
};
}
Expand Down Expand Up @@ -409,12 +409,12 @@ export default class SetupSwapSuccess extends BitcoinSyncBaseView {
}
}
if (this.request.redeem.type === SwapAsset.USDC) {
const usdcContract = confirmedSwap.contracts[SwapAsset.USDC] as Contract<SwapAsset.USDC>;
if (this.request.redeem.type === SwapAsset.USDC_MATIC) {
const usdcContract = confirmedSwap.contracts[SwapAsset.USDC_MATIC] as Contract<SwapAsset.USDC_MATIC>;
const usdcHtlcData = usdcContract.htlc as UsdcHtlcDetails;
redeemingHtlcInfo = {
type: SwapAsset.USDC,
type: SwapAsset.USDC_MATIC,
hash: confirmedSwap.hash,
timeout: usdcContract.timeout,
htlcId: usdcHtlcData.address,
Expand Down
29 changes: 7 additions & 22 deletions yarn.lock
Original file line number Diff line number Diff line change
Expand Up @@ -1486,11 +1486,6 @@
resolved "https://registry.yarnpkg.com/@nimiq/core-web/-/core-web-1.5.3.tgz#f0a4de59394f210f2c2d9cda8ee35c716847d40e"
integrity sha512-W66SS9n3ygYgD52r1GJr1WtYYOkcZsqdtMmDCEwDvkrmeARnHs2sAvj77Wt4PQG8JA7GwK5svIJr6rGccCaekw==

"@nimiq/[email protected]":
version "1.5.8"
resolved "https://registry.yarnpkg.com/@nimiq/core-web/-/core-web-1.5.8.tgz#da8abef84c6d293cbb9ca495a77f08daa08886b9"
integrity sha512-MNpFbGZetz2eZcHtJVa5tpmLjPf65mTcJBRQkOHS8kWE+f+Z++hdnwWUBQCEAph4oC6bsE5JSuU7VpwcogN7+w==

"@nimiq/core-web@^1.6.0", "@nimiq/core-web@^1.6.1":
version "1.6.1"
resolved "https://registry.yarnpkg.com/@nimiq/core-web/-/core-web-1.6.1.tgz#97cb5b43b257c7f6f6808ef603e9bf686377241f"
Expand Down Expand Up @@ -1520,10 +1515,10 @@
dependencies:
bitcoinjs-lib "^5.1.10"

"@nimiq/fastspot-api@^1.7.0":
version "1.7.0"
resolved "https://registry.yarnpkg.com/@nimiq/fastspot-api/-/fastspot-api-1.7.0.tgz#eea496f4898139c51971f0b177583c6cc6b06611"
integrity sha512-k7vSjYdjAiAQar+21v681Zrp9kN9uHMUw7/dyG2D/IrXqNPHkD133JyrzxPBga+myW411SUR4mtdPQRPQm3d/A==
"@nimiq/fastspot-api@^1.8.0":
version "1.8.0"
resolved "https://registry.yarnpkg.com/@nimiq/fastspot-api/-/fastspot-api-1.8.0.tgz#705a9e79e425c3e6536d8994fd0b39d88af1b268"
integrity sha512-qNkibJnxS8ndOn4tuy1m3lSNKybBYApo+wy1ajTKcQ0lHo3VfLY0sAJ+WRE7diVWCa7iumu6wsFVudyc3k8/NQ==

"@nimiq/iqons@^1.5.2", "@nimiq/iqons@^1.6.0":
version "1.6.0"
Expand All @@ -1541,14 +1536,9 @@
btoa "^1.1.2"
node-lmdb "^0.9.6"

"@nimiq/keyguard-client@^1.5.4":
version "1.5.4"
resolved "https://registry.yarnpkg.com/@nimiq/keyguard-client/-/keyguard-client-1.5.4.tgz#0842386e1c36e2b203cae94ac62ffafd48ee79fa"
integrity sha512-E4sQys66nSPCiMRm2NN9ibm0RZCA9VbyP7UApSEBShBCHkCCSYp1zjfuPm9+v4VKwA7yw+pEDZ5RE7Mlf2OdIQ==
dependencies:
"@nimiq/core-web" "1.5.8"
"@nimiq/rpc" "^0.3.0"
"@opengsn/common" "^2.2.5"
"@nimiq/keyguard-client@https://gitpkg.vercel.app/nimiq/keyguard?scripts.postinstall=cd%20client%20%26%26%20.%2Fbuild-gitpkg.sh&aaff49f9ea0b575208de60d38e27e05197332eef":
version "1.0.0"
resolved "https://gitpkg.vercel.app/nimiq/keyguard?scripts.postinstall=cd%20client%20%26%26%20.%2Fbuild-gitpkg.sh&aaff49f9ea0b575208de60d38e27e05197332eef#1b6121b7d2d9695f759512bf7354361af1a0f6d7"

"@nimiq/ledger-api@^2.3.0":
version "2.3.0"
Expand Down Expand Up @@ -1594,11 +1584,6 @@
resolved "https://registry.yarnpkg.com/@nimiq/rpc/-/rpc-0.1.5.tgz#53919b0a3a9abcdfebee0e865f4c663f72a8b8c2"
integrity sha512-oTRThXzpbQOY8jz8h+2KXucWzW40nVfYBWROKXKBrSozhTG0nR+rzCbEm4ZyTC26b4RnmB6y4nYabUXi7gNWcA==

"@nimiq/rpc@^0.3.0":
version "0.3.0"
resolved "https://registry.yarnpkg.com/@nimiq/rpc/-/rpc-0.3.0.tgz#654c05acccc193b7d79fb09b2faf2114945ff872"
integrity sha512-je7fv+wP4nLEgTcZwu3FaGre22qkZ9AYGbStglVaJAxOH+3CvDnnOIa9IjGFaCEhtRQKRaQEvFqa5vN4IVnH+Q==

"@nimiq/rpc@^0.4.1":
version "0.4.1"
resolved "https://registry.yarnpkg.com/@nimiq/rpc/-/rpc-0.4.1.tgz#d5df1e426793afcdd8c407a2968442bbee874dbd"
Expand Down

0 comments on commit ba5a700

Please sign in to comment.