Skip to content

Commit 16457af

Browse files
committed
helper for address
1 parent 9a2467d commit 16457af

File tree

8 files changed

+31
-44
lines changed

8 files changed

+31
-44
lines changed

README.md

-29
Original file line numberDiff line numberDiff line change
@@ -29,9 +29,6 @@ You can generate random keys with the following command:
2929
yarn gen:keys
3030
```
3131

32-
> [!WARNING]
33-
> Running the `gen:keys` script will overwrite the existing `.env` file.
34-
3532
### Fetching messages
3633

3734
There are to ways to fetch messages from a conversation, one is by starting a stream
@@ -72,32 +69,6 @@ for (const conversation of conversations) {
7269
}
7370
```
7471

75-
### Working with addresses
76-
77-
Conversations in XMTP can be `DMs` or `Groups`. The underlying technicalities are the same, but DMs are essentially groups locked between two users that can be reused - basically a fixed group of 2. This is how MLS works.
78-
79-
Each member of a conversation has the following properties:
80-
81-
```tsx
82-
inboxId: string; // unique identifier from the XMTP network
83-
accountAddresses: Array<string>; // ethereum network addresses
84-
installationIds: Array<string>; // How many active devices the user has
85-
permissionLevel: PermissionLevel; // In the context of a group, if it's admin or not
86-
consentState: ConsentState; // If it's blocked or allowed via consent
87-
```
88-
89-
To fetch an ethereum address in a DM, you can use a script like the following:
90-
91-
```tsx
92-
const address =
93-
(await group.members?.find(
94-
(member: any) => member.inboxId === dm.dmPeerInboxId,
95-
)?.accountAddresses[0]) || "";
96-
```
97-
98-
> [!WARNING]
99-
> XMTP is working on integrating passkeys as a pillar of identity. Expect a breaking change soon as XMTP prepares for the first v3 stable release.
100-
10172
## Web inbox
10273

10374
Interact with the XMTP network using [xmtp.chat](https://xmtp.chat), the official web inbox for developers.

examples/gated-group/README.md

-3
Original file line numberDiff line numberDiff line change
@@ -20,9 +20,6 @@ You can generate random keys with the following command:
2020
yarn gen:keys
2121
```
2222

23-
> [!WARNING]
24-
> Running the `gen:keys` script will overwrite the existing `.env` file.
25-
2623
## Start the XMTP agent
2724

2825
Start your XMTP client and begin listening to messages. The bot responds to the following commands:

examples/gm/index.ts

+8-2
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,9 @@
11
import { Client, type XmtpEnv } from "@xmtp/node-sdk";
2-
import { createSigner, getEncryptionKeyFromHex } from "@/helpers";
2+
import {
3+
createSigner,
4+
getAddressOfMember,
5+
getEncryptionKeyFromHex,
6+
} from "@/helpers";
37

48
/* Get the wallet key associated to the public key of
59
* the agent and the encryption key for the local db
@@ -62,8 +66,10 @@ async function main() {
6266
console.log("Unable to find conversation, skipping");
6367
continue;
6468
}
69+
const members = await conversation.members();
6570

66-
console.log(`Sending "gm" response...`);
71+
const address = getAddressOfMember(members, message.senderInboxId);
72+
console.log(`Sending "gm" response to ${address}...`);
6773
/* Send a message to the conversation */
6874
await conversation.send("gm");
6975

examples/gpt/README.md

-3
Original file line numberDiff line numberDiff line change
@@ -18,9 +18,6 @@ You can generate random keys with the following command:
1818
yarn gen:keys
1919
```
2020

21-
> [!WARNING]
22-
> Running the `gen:keys` script will overwrite the existing `.env` file.
23-
2421
## Usage
2522

2623
```tsx

helpers/index.ts

+20-1
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
import { getRandomValues } from "node:crypto";
2-
import { IdentifierKind } from "@xmtp/node-bindings";
2+
import { IdentifierKind, type GroupMember } from "@xmtp/node-bindings";
33
import { type Signer } from "@xmtp/node-sdk";
44
import { fromString, toString } from "uint8arrays";
55
import { createWalletClient, http, toBytes } from "viem";
@@ -44,6 +44,25 @@ export const createSigner = (key: `0x${string}`): Signer => {
4444
};
4545
};
4646

47+
/**
48+
* Get the address of a member
49+
* @param members - The members of the group
50+
* @param inboxId - The inboxId of the member
51+
* @returns The address of the member
52+
*/
53+
export function getAddressOfMember(members: GroupMember[], inboxId: string) {
54+
for (const member of members) {
55+
for (const identifier of member.accountIdentifiers) {
56+
if (
57+
identifier.identifierKind === IdentifierKind.Ethereum &&
58+
member.inboxId === inboxId
59+
) {
60+
return identifier.identifier;
61+
}
62+
}
63+
}
64+
}
65+
4766
/**
4867
* Generate a random encryption key
4968
* @returns The encryption key

integrations/gaia/README.md

-3
Original file line numberDiff line numberDiff line change
@@ -22,9 +22,6 @@ You can generate random keys with the following command:
2222
yarn gen:keys
2323
```
2424

25-
> [!WARNING]
26-
> Running the `gen:keys` script will overwrite the existing `.env` file.
27-
2825
## Usage
2926

3027
```tsx

integrations/grok/README.md

-3
Original file line numberDiff line numberDiff line change
@@ -18,9 +18,6 @@ You can generate random keys with the following command:
1818
yarn gen:keys
1919
```
2020

21-
> [!WARNING]
22-
> Running the `gen:keys` script will overwrite the existing `.env` file.
23-
2421
## Usage
2522

2623
```tsx

scripts/generateKeys.ts

+3
Original file line numberDiff line numberDiff line change
@@ -15,6 +15,9 @@ await writeFile(
1515
`WALLET_KEY=${walletKey}
1616
ENCRYPTION_KEY=${encryptionKeyHex}
1717
`,
18+
{
19+
flag: "a",
20+
},
1821
);
1922

2023
console.log(`Keys written to ${filePath}`);

0 commit comments

Comments
 (0)