From 5fc99dad2c56a8a5fb51ffb74e41508d4c992ab6 Mon Sep 17 00:00:00 2001 From: Michael Taylor Date: Sun, 22 Sep 2024 10:06:48 -0400 Subject: [PATCH 1/2] fix: wallet sig verification --- src/DigNetwork/PropagationServer.ts | 29 +++++++++++++++-------------- src/blockchain/Wallet.ts | 2 +- 2 files changed, 16 insertions(+), 15 deletions(-) diff --git a/src/DigNetwork/PropagationServer.ts b/src/DigNetwork/PropagationServer.ts index 0360c50..a0edabc 100644 --- a/src/DigNetwork/PropagationServer.ts +++ b/src/DigNetwork/PropagationServer.ts @@ -57,7 +57,7 @@ export class PropagationServer { */ async initializeWallet() { this.wallet = await Wallet.load("default"); - this.publicKey = await this.wallet.getPrivateSyntheticKey(); + this.publicKey = await this.wallet.getPublicSyntheticKey().toString('hex'); } /** @@ -86,7 +86,7 @@ export class PropagationServer { httpsAgent: this.createHttpsAgent(), }; - let url = `https://${this.ipAddress}:${PropagationServer.port}/stores/${this.storeId}`; + let url = `https://${this.ipAddress}:${PropagationServer.port}/${this.storeId}`; if (rootHash) { url += `?hasRootHash=${rootHash}`; } @@ -98,9 +98,9 @@ export class PropagationServer { const rootHashExists = response.headers["x-has-root-hash"] === "true"; if (storeExists) { - spinner.success({ text: green(`Store ${this.storeId} exists!`) }); + spinner.success({ text: green(`Store ${this.storeId} exists on peer!`) }); } else { - spinner.error({ text: red(`Store ${this.storeId} does not exist.`) }); + spinner.error({ text: red(`Store ${this.storeId} does not exist. Credentials will be required to push.`) }); } if (rootHash) { @@ -118,7 +118,7 @@ export class PropagationServer { return { storeExists, rootHashExists }; } catch (error: any) { spinner.error({ text: red("Error checking if store exists:") }); - console.error(red(error)); + console.error(red(error.message)); throw error; } } @@ -158,7 +158,7 @@ export class PropagationServer { }); } catch (error: any) { spinner.error({ text: red("Error starting upload session:") }); - console.error(red(error)); + console.error(red(error.message)); throw error; } } @@ -177,10 +177,10 @@ export class PropagationServer { const nonce = response.headers["x-nonce"]; console.log(blue(`Nonce received for file ${filename}: ${nonce}`)); return nonce; - } catch (error) { + } catch (error: any) { console.error( red(`Error generating nonce for file ${filename}:`), - error + error.message ); throw error; } @@ -193,9 +193,10 @@ export class PropagationServer { async uploadFile(filePath: string) { const filename = path.basename(filePath); const nonce = await this.getFileNonce(filename); - const keyOwnershipSig = await this.wallet.createKeyOwnershipSignature( - nonce - ); + const wallet = await Wallet.load("default"); + const keyOwnershipSig = await wallet.createKeyOwnershipSignature(nonce); + const publicKey = await wallet.getPublicSyntheticKey(); + const formData = new FormData(); formData.append("file", fs.createReadStream(filePath)); @@ -214,7 +215,7 @@ export class PropagationServer { headers: { "Content-Type": "multipart/form-data", "x-nonce": nonce, - "x-public-key": this.publicKey, + "x-public-key": publicKey.toString("hex"), "x-key-ownership-sig": keyOwnershipSig, ...formData.getHeaders(), }, @@ -238,8 +239,8 @@ export class PropagationServer { progressBar.stop(); return response.data; - } catch (error) { - console.error(red(`✖ Error uploading file ${filename}:`), error); + } catch (error: any) { + console.error(red(`✖ Error uploading file ${filename}:`), error.message); progressBar.stop(); // Stop the progress bar in case of error throw error; } diff --git a/src/blockchain/Wallet.ts b/src/blockchain/Wallet.ts index c9a9705..169e8cc 100644 --- a/src/blockchain/Wallet.ts +++ b/src/blockchain/Wallet.ts @@ -191,7 +191,7 @@ export class Wallet { return signature.toString("hex"); } - public async verifyKeyOwnershipSignature( + public static async verifyKeyOwnershipSignature( nonce: string, signature: string, publicKey: string From 9cd512103927e9c105ed9a84e7e87d9699155039 Mon Sep 17 00:00:00 2001 From: Michael Taylor Date: Sun, 22 Sep 2024 10:07:24 -0400 Subject: [PATCH 2/2] chore(release): 0.0.1-alpha.57 --- CHANGELOG.md | 7 +++++++ package-lock.json | 4 ++-- package.json | 2 +- 3 files changed, 10 insertions(+), 3 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index a4fe6c5..2e5992a 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,6 +2,13 @@ All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines. +### [0.0.1-alpha.57](https://github.com/DIG-Network/dig-chia-sdk/compare/v0.0.1-alpha.56...v0.0.1-alpha.57) (2024-09-22) + + +### Bug Fixes + +* wallet sig verification ([5fc99da](https://github.com/DIG-Network/dig-chia-sdk/commit/5fc99dad2c56a8a5fb51ffb74e41508d4c992ab6)) + ### [0.0.1-alpha.56](https://github.com/DIG-Network/dig-chia-sdk/compare/v0.0.1-alpha.55...v0.0.1-alpha.56) (2024-09-22) diff --git a/package-lock.json b/package-lock.json index daea37a..76f8e45 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,12 +1,12 @@ { "name": "@dignetwork/dig-sdk", - "version": "0.0.1-alpha.56", + "version": "0.0.1-alpha.57", "lockfileVersion": 3, "requires": true, "packages": { "": { "name": "@dignetwork/dig-sdk", - "version": "0.0.1-alpha.56", + "version": "0.0.1-alpha.57", "license": "ISC", "dependencies": { "@dignetwork/datalayer-driver": "^0.1.24", diff --git a/package.json b/package.json index be3b87d..1de690d 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@dignetwork/dig-sdk", - "version": "0.0.1-alpha.56", + "version": "0.0.1-alpha.57", "description": "", "type": "commonjs", "main": "./dist/index.js",