Skip to content

Commit

Permalink
update guide
Browse files Browse the repository at this point in the history
  • Loading branch information
jinglescode committed Nov 15, 2024
1 parent b3cf10f commit e30008b
Show file tree
Hide file tree
Showing 4 changed files with 22 additions and 18 deletions.
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
import { useState } from "react";

import { checkSignature } from "@meshsdk/core";
import { useWallet } from "@meshsdk/react";

import Input from "~/components/form/input";
Expand Down
4 changes: 0 additions & 4 deletions apps/playground/src/pages/governance/index.mdx
Original file line number Diff line number Diff line change
@@ -1,8 +1,4 @@
import { useState } from "react";

import { checkSignature, generateNonce } from "@meshsdk/core";
import { CardanoWallet, useWallet } from "@meshsdk/react";

import Button from "~/components/button/button";
import LayoutImageHeaderAndBody from "~/components/layouts/image-header-and-body";

Expand Down
17 changes: 15 additions & 2 deletions apps/playground/src/pages/guides/prove-wallet-ownership/demo.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ import { CardanoWallet, useWallet } from "@meshsdk/react";

import Button from "~/components/button/button";
import DemoResult from "~/components/sections/demo-result";
import Codeblock from "~/components/text/codeblock";

export default function Demo() {
const { wallet, connected } = useWallet();
Expand All @@ -16,15 +17,27 @@ export default function Demo() {

setLoading(true);
const nonce = generateNonce("Sign to login in to Mesh: ");
const signature = await wallet.signData(nonce);
const address = (await wallet.getUsedAddresses())[0];
const signature = await wallet.signData(nonce, address);

const result = checkSignature(nonce, signature);
const result = checkSignature(nonce, signature, address);
setResponse(result.toString());
setLoading(false);
}

let code = ``;
code += `import { checkSignature, generateNonce } from "@meshsdk/core";\n`;
code += `\n`;
code += `const nonce = generateNonce("Sign to login in to Mesh: ");\n`;
code += `\n`;
code += `const address = (await wallet.getUsedAddresses())[0];\n`;
code += `const signature = await wallet.signData(nonce, address);\n`;
code += `\n`;
code += `const result = checkSignature(nonce, signature, address);\n`;

return (
<>
<Codeblock data={code} />
<p>Connect your wallet and click on the button to sign a message.</p>
<CardanoWallet />
<Button
Expand Down
18 changes: 7 additions & 11 deletions apps/playground/src/pages/guides/prove-wallet-ownership/index.mdx
Original file line number Diff line number Diff line change
@@ -1,8 +1,4 @@
import { useState } from "react";

import { checkSignature, generateNonce } from "@meshsdk/core";
import { CardanoWallet, useWallet } from "@meshsdk/react";

import Button from "~/components/button/button";
import LayoutImageHeaderAndBody from "~/components/layouts/image-header-and-body";
import { guideownership } from "~/data/links-guides";
Expand Down Expand Up @@ -66,7 +62,7 @@ To ensure the signature is valid, the same cryptographic algorithm is applied to

The User model stored in the database of the backend server must have two compulsory fields: public address and nonce. Furthermore, this address has to be unique. Other details about the user, such as username, Twitter ID, and name fields can be added, but are not essential for this process.

On Cardano, to obtain a user's public address as an identifier, we can use their wallet's staking address. This will be stored in the server side database, so that authorized wallets can be linked. The user never has to worry about manually entering their address, since it can be retrieved using **wallet.getRewardAddresses()**.
On Cardano, to obtain a user's public address as an identifier, we can use their wallet's staking address. This will be stored in the server side database, so that authorized wallets can be linked. The user never has to worry about manually entering their address, since it can be retrieved using **wallet.getUsedAddresses()**.

With the user's wallet connected, the first step is to get the user's staking address and send it to our backend server.

Expand All @@ -75,7 +71,7 @@ const { wallet, connected } = useWallet();
async function frontendStartLoginProcess() {
if (connected) {
const userAddress = (await wallet.getRewardAddresses())[0];
const userAddress = (await wallet.getUsedAddresses())[0];
// do: send request with 'userAddress' to the backend
}
Expand Down Expand Up @@ -117,7 +113,7 @@ We request the user's authorization and show them the message that is to be sign
```
async function frontendSignMessage(nonce) {
try {
const userAddress = (await wallet.getRewardAddresses())[0];
const userAddress = (await wallet.getUsedAddresses())[0];
const signature = await wallet.signData(nonce, userAddress);
// do: send request with 'signature' and 'userAddress' to the backend
Expand All @@ -143,7 +139,7 @@ import { checkSignature } from '@meshsdk/core';
async function backendVerifySignature(userAddress, signature) {
// do: get 'nonce' from user (database) using 'userAddress'
const result = checkSignature(nonce, signature);
const result = checkSignature(nonce, signature, userAddress);
// do: update 'nonce' in the database with another random string
Expand Down Expand Up @@ -177,15 +173,15 @@ export default function Page() {
async function frontendStartLoginProcess() {
if (connected) {
const userAddress = (await wallet.getRewardAddresses())[0];
const userAddress = (await wallet.getUsedAddresses())[0];
const nonce = await backendGetNonce(userAddress);
await frontendSignMessage(nonce);
}
}
async function frontendSignMessage(nonce) {
try {
const userAddress = (await wallet.getRewardAddresses())[0];
const userAddress = (await wallet.getUsedAddresses())[0];
const signature = await wallet.signData(nonce, userAddress);
await backendVerifySignature(userAddress, signature);
} catch (error) {
Expand Down Expand Up @@ -217,7 +213,7 @@ async function backendGetNonce(userAddress) {
async function backendVerifySignature(userAddress, signature) {
// do: get 'nonce' from database
const result = checkSignature(nonce, signature);
const result = checkSignature(nonce, signature, userAddress);
if(result){
// create JWT or approve certain process
}
Expand Down

0 comments on commit e30008b

Please sign in to comment.