mirror of
https://github.com/status-im/wakuconnect-chat-sdk.git
synced 2025-01-16 15:16:07 +00:00
add Account
This commit is contained in:
parent
fd0dde5cd5
commit
2832e0f8f6
29
packages/status-js/src/account.test.ts
Normal file
29
packages/status-js/src/account.test.ts
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
import { keccak256 } from 'ethereum-cryptography/keccak'
|
||||||
|
import * as secp from 'ethereum-cryptography/secp256k1'
|
||||||
|
import { utf8ToBytes } from 'ethereum-cryptography/utils'
|
||||||
|
|
||||||
|
import { Account } from './account'
|
||||||
|
|
||||||
|
describe('Account', () => {
|
||||||
|
it('should verify the signature', async () => {
|
||||||
|
const account = new Account()
|
||||||
|
|
||||||
|
const message = '123'
|
||||||
|
const messageHash = keccak256(utf8ToBytes(message))
|
||||||
|
|
||||||
|
const signature = await account.sign(message)
|
||||||
|
|
||||||
|
expect(secp.verify(signature, messageHash, account.publicKey)).toBeTruthy()
|
||||||
|
})
|
||||||
|
|
||||||
|
it('should not verify signature with different message', async () => {
|
||||||
|
const account = new Account()
|
||||||
|
|
||||||
|
const message = '123'
|
||||||
|
const messageHash = keccak256(utf8ToBytes(message))
|
||||||
|
|
||||||
|
const signature = await account.sign('abc')
|
||||||
|
|
||||||
|
expect(secp.verify(signature, messageHash, account.publicKey)).toBeFalsy()
|
||||||
|
})
|
||||||
|
})
|
25
packages/status-js/src/account.ts
Normal file
25
packages/status-js/src/account.ts
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
import { keccak256 } from 'ethereum-cryptography/keccak'
|
||||||
|
import { getPublicKey, sign, utils } from 'ethereum-cryptography/secp256k1'
|
||||||
|
import { bytesToHex, utf8ToBytes } from 'ethereum-cryptography/utils'
|
||||||
|
|
||||||
|
import { privateKeyToAddress } from './utils/private-key-to-address'
|
||||||
|
|
||||||
|
export class Account {
|
||||||
|
public privateKey: string
|
||||||
|
public publicKey: string
|
||||||
|
public address: string
|
||||||
|
|
||||||
|
constructor() {
|
||||||
|
const privateKey = utils.randomPrivateKey()
|
||||||
|
const publicKey = getPublicKey(privateKey)
|
||||||
|
|
||||||
|
this.privateKey = bytesToHex(privateKey)
|
||||||
|
this.publicKey = bytesToHex(publicKey)
|
||||||
|
this.address = privateKeyToAddress(this.privateKey)
|
||||||
|
}
|
||||||
|
|
||||||
|
sign = (payload: string) => {
|
||||||
|
const hash = keccak256(utf8ToBytes(payload))
|
||||||
|
return sign(hash, this.privateKey)
|
||||||
|
}
|
||||||
|
}
|
@ -3,11 +3,9 @@ import { getPredefinedBootstrapNodes, Waku } from 'js-waku'
|
|||||||
import { ApplicationMetadataMessage } from '../protos/application-metadata-message'
|
import { ApplicationMetadataMessage } from '../protos/application-metadata-message'
|
||||||
import { ChatMessage } from '../protos/chat-message'
|
import { ChatMessage } from '../protos/chat-message'
|
||||||
import { CommunityChat, CommunityDescription } from '../protos/communities'
|
import { CommunityChat, CommunityDescription } from '../protos/communities'
|
||||||
|
import { Account } from './account'
|
||||||
import { idToContentTopic } from './contentTopic'
|
import { idToContentTopic } from './contentTopic'
|
||||||
import { createSymKeyFromPassword } from './encryption'
|
import { createSymKeyFromPassword } from './encryption'
|
||||||
import { hexToBuf } from './utils'
|
|
||||||
|
|
||||||
import type { WakuMessage } from 'js-waku'
|
|
||||||
|
|
||||||
export interface ClientOptions {
|
export interface ClientOptions {
|
||||||
publicKey: string
|
publicKey: string
|
||||||
@ -20,6 +18,7 @@ export class Client {
|
|||||||
publicKey: string
|
publicKey: string
|
||||||
callback: (message: ChatMessage) => void
|
callback: (message: ChatMessage) => void
|
||||||
waku?: Waku
|
waku?: Waku
|
||||||
|
account?: Account
|
||||||
communityDescription?: CommunityDescription
|
communityDescription?: CommunityDescription
|
||||||
clocks: Record<string, Date>
|
clocks: Record<string, Date>
|
||||||
|
|
||||||
@ -135,7 +134,10 @@ export class Client {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
async sendMessage(message: any) {}
|
createAccount = async (): Promise<Account> => {
|
||||||
|
this.account = new Account()
|
||||||
|
return this.account
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export const createClient = async (options: ClientOptions) => {
|
export const createClient = async (options: ClientOptions) => {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user