Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Soloseng/loadtest-with-DEK #10482

Merged
Merged
Show file tree
Hide file tree
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
32 changes: 23 additions & 9 deletions packages/phone-number-privacy/monitor/src/query.ts
Original file line number Diff line number Diff line change
Expand Up @@ -18,8 +18,9 @@ import { genSessionID } from '@celo/phone-number-privacy-common/lib/utils/logger
import { normalizeAddressWith0x, privateKeyToAddress } from '@celo/utils/lib/address'
import { defined } from '@celo/utils/lib/sign-typed-data-utils'
import { LocalWallet } from '@celo/wallet-local'
import { ACCOUNT_ADDRESS, dekAuthSigner, generateRandomPhoneNumber, PRIVATE_KEY } from './resources'

const phoneNumber = fetchEnv('PHONE_NUMBER')
let phoneNumber = fetchEnv('PHONE_NUMBER')

const newPrivateKey = async () => {
const mnemonic = await generateMnemonic(MnemonicStrength.s256_24words)
Expand All @@ -30,21 +31,34 @@ export const queryOdisForSalt = async (
blockchainProvider: string,
contextName: OdisContextName,
timeoutMs: number = 10000,
bypassQuota: boolean = false
bypassQuota: boolean = false,
useDEK: boolean = false
) => {
let authSigner: AuthSigner
let accountAddress: string
console.log(`contextName: ${contextName}`) // tslint:disable-line:no-console
console.log(`blockchain provider: ${blockchainProvider}`) // tslint:disable-line:no-console
console.log(`using DEK: ${useDEK}`) // tslint:disable-line:no-console

const serviceContext = getServiceContext(contextName, OdisAPI.PNP)

const contractKit = newKit(blockchainProvider, new LocalWallet())
const privateKey = await newPrivateKey()
const accountAddress = normalizeAddressWith0x(privateKeyToAddress(privateKey))
contractKit.connection.addAccount(privateKey)
contractKit.defaultAccount = accountAddress
const authSigner: AuthSigner = {
authenticationMethod: OdisUtils.Query.AuthenticationMethod.WALLET_KEY,
contractKit,

if (useDEK) {
accountAddress = ACCOUNT_ADDRESS
contractKit.connection.addAccount(PRIVATE_KEY)
contractKit.defaultAccount = accountAddress
authSigner = dekAuthSigner(0)
phoneNumber = generateRandomPhoneNumber()
} else {
const privateKey = await newPrivateKey()
accountAddress = normalizeAddressWith0x(privateKeyToAddress(privateKey))
contractKit.connection.addAccount(privateKey)
contractKit.defaultAccount = accountAddress
authSigner = {
authenticationMethod: OdisUtils.Query.AuthenticationMethod.WALLET_KEY,
contractKit,
}
}

const abortController = new AbortController()
Expand Down
49 changes: 49 additions & 0 deletions packages/phone-number-privacy/monitor/src/resources.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
import { EncryptionKeySigner } from '@celo/identity/lib/odis/query'
import { AuthenticationMethod } from '@celo/phone-number-privacy-common'
import {
ensureLeading0x,
normalizeAddressWith0x,
privateKeyToAddress,
} from '@celo/utils/lib/address'
import 'isomorphic-fetch'
soloseng marked this conversation as resolved.
Show resolved Hide resolved

export const PRIVATE_KEY = '0x1234567890abcdef1234567890abcdef1234567890abcdef1234567890abcdef'
export const ACCOUNT_ADDRESS = normalizeAddressWith0x(privateKeyToAddress(PRIVATE_KEY)) // 0x1be31a94361a391bbafb2a4ccd704f57dc04d4bb

interface DEK {
privateKey: string
publicKey: string
address: string
}

export const deks: DEK[] = [
{
privateKey: 'bf8a2b73baf8402f8fe906ad3f42b560bf14b39f7df7797ece9e293d6f162188',
publicKey: '034846bc781cacdafc66f3a77aa9fc3c56a9dadcd683c72be3c446fee8da041070',
address: '0x7b33dF2607b85e3211738a49A6Ad6E8Ed4d13F6E',
},
{
privateKey: '0975b0c565abc75b6638a749ea3008cb52676af3eabe4b80e19c516d82330364',
publicKey: '03b1ac8c445f0796978018c087b97e8213b32c39e6a8642ae63dce71da33a19f65',
address: '0x34332049B07Fab9a2e843A7C8991469d93cF6Ae6',
},
]

// The following code can be used to generate more test DEKs
// const generateDEKs = (n: number): Promise<DEK[]> => Promise.all([...Array(n).keys()].map(
// async () => await deriveDek(await generateMnemonic())
// ))

export const dekAuthSigner = (index: number): EncryptionKeySigner => {
return {
authenticationMethod: AuthenticationMethod.ENCRYPTION_KEY,
rawKey: ensureLeading0x(deks[index].privateKey),
}
}

export function generateRandomPhoneNumber() {
const min = 1000000000 // Smallest 10-digit number
const max = 9999999999 // Largest 10-digit number
const randomNumber = Math.floor(Math.random() * (max - min + 1)) + min
return '+1' + randomNumber.toString()
}
17 changes: 13 additions & 4 deletions packages/phone-number-privacy/monitor/src/scripts/run-load-test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,8 @@ const runLoadTest = (
isSerial: boolean,
pnpQuotaEndpoint: boolean,
timeoutMs: number,
bypassQuota: boolean
bypassQuota: boolean,
useDEK: boolean
) => {
let blockchainProvider: string
switch (contextName) {
Expand Down Expand Up @@ -39,7 +40,8 @@ const runLoadTest = (
contextName as OdisContextName,
pnpQuotaEndpoint ? CombinerEndpointPNP.PNP_QUOTA : CombinerEndpointPNP.PNP_SIGN,
timeoutMs,
bypassQuota
bypassQuota,
useDEK
)
} else {
concurrentLoadTest(
Expand All @@ -48,7 +50,8 @@ const runLoadTest = (
contextName as OdisContextName,
pnpQuotaEndpoint ? CombinerEndpointPNP.PNP_QUOTA : CombinerEndpointPNP.PNP_SIGN,
timeoutMs,
bypassQuota
bypassQuota,
useDEK
)
}
}
Expand Down Expand Up @@ -87,6 +90,11 @@ yargs
description: 'Bypass Signer quota check.',
default: false,
})
.option('useDEK', {
type: 'boolean',
description: 'Use Data Encryption Key (DEK) to authenticate.',
default: false,
})
.option('pnpQuotaEndpoint', {
type: 'boolean',
description:
Expand All @@ -100,6 +108,7 @@ yargs
args.isSerial,
args.pnpQuotaEndpoint,
args.timeoutMs,
args.bypassQuota
args.bypassQuota,
args.useDEK
)
).argv
24 changes: 18 additions & 6 deletions packages/phone-number-privacy/monitor/src/test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,15 +14,17 @@ export async function testPNPSignQuery(
contextName: OdisContextName,
endpoint: CombinerEndpointPNP.PNP_SIGN,
timeoutMs?: number,
bypassQuota?: boolean
bypassQuota?: boolean,
useDEK?: boolean
) {
logger.info(`Performing test PNP query for ${endpoint}`)
try {
const odisResponse: IdentifierHashDetails = await queryOdisForSalt(
blockchainProvider,
contextName,
timeoutMs,
bypassQuota
bypassQuota,
useDEK
)
logger.info({ odisResponse }, 'ODIS salt request successful. System is healthy.')
} catch (err) {
Expand Down Expand Up @@ -85,13 +87,21 @@ export async function serialLoadTest(
| CombinerEndpointPNP.PNP_QUOTA
| CombinerEndpointPNP.PNP_SIGN = CombinerEndpointPNP.PNP_SIGN,
timeoutMs?: number,
bypassQuota?: boolean
bypassQuota?: boolean,
useDEK?: boolean
) {
for (let i = 0; i < n; i++) {
try {
switch (endpoint) {
case CombinerEndpointPNP.PNP_SIGN:
await testPNPSignQuery(blockchainProvider, contextName, endpoint, timeoutMs, bypassQuota)
await testPNPSignQuery(
blockchainProvider,
contextName,
endpoint,
timeoutMs,
bypassQuota,
useDEK
)
break
case CombinerEndpointPNP.PNP_QUOTA:
await testPNPQuotaQuery(blockchainProvider, contextName, timeoutMs)
Expand All @@ -108,7 +118,8 @@ export async function concurrentLoadTest(
| CombinerEndpointPNP.PNP_QUOTA
| CombinerEndpointPNP.PNP_SIGN = CombinerEndpointPNP.PNP_SIGN,
timeoutMs?: number,
bypassQuota?: boolean
bypassQuota?: boolean,
useDEK?: boolean
) {
while (true) {
const reqs = []
Expand All @@ -126,7 +137,8 @@ export async function concurrentLoadTest(
contextName,
endpoint,
timeoutMs,
bypassQuota
bypassQuota,
useDEK
)
break
case CombinerEndpointPNP.PNP_QUOTA:
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import { ContractKit } from '@celo/contractkit'
import {
authenticateUser,
AuthenticationMethod,
ErrorType,
hasValidAccountParam,
hasValidBlindedPhoneNumberParam,
Expand Down Expand Up @@ -75,6 +76,12 @@ export class PnpSignIO extends IO<SignMessageRequest> {
warnings: ErrorType[],
logger: Logger
): Promise<boolean> {
const authMethod = request.body.authenticationMethod

if (authMethod && authMethod === AuthenticationMethod.WALLET_KEY) {
Counters.requestsWithWalletAddress.inc()
}

return authenticateUser(
request,
this.kit,
Expand Down