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/set-PNP-default-as-optional-env-var #10436

Merged
merged 11 commits into from
Jul 26, 2023
16 changes: 16 additions & 0 deletions packages/phone-number-privacy/combiner/src/config.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
import {
BlockchainConfig,
FULL_NODE_TIMEOUT_IN_MS,
RETRY_COUNT,
RETRY_DELAY_IN_MS,
rootLogger,
TestUtils,
toBool,
Expand Down Expand Up @@ -36,6 +38,8 @@ export interface OdisConfig {
versions: string // parse as KeyVersionInfo[]
}
fullNodeTimeoutMs: number
fullNodeRetryCount: number
fullNodeRetryDelayMs: number
}

export interface CombinerConfig {
Expand Down Expand Up @@ -102,6 +106,8 @@ if (DEV_MODE) {
]),
},
fullNodeTimeoutMs: FULL_NODE_TIMEOUT_IN_MS,
fullNodeRetryCount: RETRY_COUNT,
fullNodeRetryDelayMs: RETRY_DELAY_IN_MS,
},
domains: {
serviceName: defaultServiceName,
Expand Down Expand Up @@ -135,6 +141,8 @@ if (DEV_MODE) {
]),
},
fullNodeTimeoutMs: FULL_NODE_TIMEOUT_IN_MS,
fullNodeRetryCount: RETRY_COUNT,
fullNodeRetryDelayMs: RETRY_DELAY_IN_MS,
},
}
} else {
Expand All @@ -160,6 +168,10 @@ if (DEV_MODE) {
versions: functionConfig.pnp_keys.versions,
},
fullNodeTimeoutMs: Number(functionConfig.pnp.full_node_timeout_ms ?? FULL_NODE_TIMEOUT_IN_MS),
fullNodeRetryCount: Number(functionConfig.pnp.full_node_retry_count ?? RETRY_COUNT),
fullNodeRetryDelayMs: Number(
functionConfig.pnp.full_node_retry_delay_ms ?? RETRY_DELAY_IN_MS
),
},
domains: {
serviceName: functionConfig.domains.service_name ?? defaultServiceName,
Expand All @@ -176,6 +188,10 @@ if (DEV_MODE) {
versions: functionConfig.domains_keys.versions,
},
fullNodeTimeoutMs: Number(functionConfig.pnp.full_node_timeout_ms ?? FULL_NODE_TIMEOUT_IN_MS),
fullNodeRetryCount: Number(functionConfig.pnp.full_node_retry_count ?? RETRY_COUNT),
fullNodeRetryDelayMs: Number(
functionConfig.pnp.full_node_retry_delay_ms ?? RETRY_DELAY_IN_MS
),
},
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -72,7 +72,9 @@ export class PnpQuotaIO extends IO<PnpQuotaRequest> {
logger,
this.config.shouldFailOpen,
[],
this.config.fullNodeTimeoutMs
this.config.fullNodeTimeoutMs,
this.config.fullNodeRetryCount,
this.config.fullNodeRetryDelayMs
)
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -91,7 +91,9 @@ export class LegacyPnpSignIO extends IO<LegacySignMessageRequest> {
logger,
this.config.shouldFailOpen,
[],
this.config.fullNodeTimeoutMs
this.config.fullNodeTimeoutMs,
this.config.fullNodeRetryCount,
this.config.fullNodeRetryDelayMs
)
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -90,7 +90,9 @@ export class PnpSignIO extends IO<SignMessageRequest> {
logger,
this.config.shouldFailOpen,
[],
this.config.fullNodeTimeoutMs
this.config.fullNodeTimeoutMs,
this.config.fullNodeRetryCount,
this.config.fullNodeRetryDelayMs
)
}

Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import {
CombinerEndpoint,
DB_TIMEOUT,
DisableDomainRequest,
disableDomainRequestEIP712,
DisableDomainResponse,
Expand All @@ -18,6 +19,8 @@ import {
getContractKit,
KEY_VERSION_HEADER,
PoprfClient,
RETRY_COUNT,
RETRY_DELAY_IN_MS,
SequentialDelayDomain,
SequentialDelayStage,
TestUtils,
Expand Down Expand Up @@ -110,6 +113,7 @@ const signerConfig: SignerConfig = {
port: undefined,
ssl: true,
poolMaxSize: 50,
timeout: DB_TIMEOUT,
},
keystore: {
type: SupportedKeystore.MOCK_SECRET_MANAGER,
Expand Down Expand Up @@ -140,6 +144,8 @@ const signerConfig: SignerConfig = {
timeout: 5000,
test_quota_bypass_percentage: 0,
fullNodeTimeoutMs: FULL_NODE_TIMEOUT_IN_MS,
fullNodeRetryCount: RETRY_COUNT,
fullNodeRetryDelayMs: RETRY_DELAY_IN_MS,
}

describe('domainService', () => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,11 +2,14 @@ import { newKit } from '@celo/contractkit'
import {
AuthenticationMethod,
CombinerEndpoint,
DB_TIMEOUT,
ErrorMessage,
FULL_NODE_TIMEOUT_IN_MS,
genSessionID,
KEY_VERSION_HEADER,
LegacySignMessageRequest,
RETRY_COUNT,
RETRY_DELAY_IN_MS,
SignMessageResponseFailure,
SignMessageResponseSuccess,
TestUtils,
Expand Down Expand Up @@ -114,6 +117,7 @@ const signerConfig: SignerConfig = {
port: undefined,
ssl: true,
poolMaxSize: 50,
timeout: DB_TIMEOUT,
},
keystore: {
type: SupportedKeystore.MOCK_SECRET_MANAGER,
Expand Down Expand Up @@ -144,6 +148,8 @@ const signerConfig: SignerConfig = {
timeout: 5000,
test_quota_bypass_percentage: 0,
fullNodeTimeoutMs: FULL_NODE_TIMEOUT_IN_MS,
fullNodeRetryCount: RETRY_COUNT,
fullNodeRetryDelayMs: RETRY_DELAY_IN_MS,
}

const testBlockNumber = 1000000
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,13 +2,16 @@ import { newKit } from '@celo/contractkit'
import {
AuthenticationMethod,
CombinerEndpoint,
DB_TIMEOUT,
ErrorMessage,
FULL_NODE_TIMEOUT_IN_MS,
genSessionID,
KEY_VERSION_HEADER,
PnpQuotaRequest,
PnpQuotaResponseFailure,
PnpQuotaResponseSuccess,
RETRY_COUNT,
RETRY_DELAY_IN_MS,
SignerEndpoint,
SignMessageRequest,
SignMessageResponseFailure,
Expand Down Expand Up @@ -65,6 +68,8 @@ const {
BLINDING_FACTOR,
} = TestUtils.Values

jest.setTimeout(20000)

// create deep copy of config
const combinerConfig: typeof config = JSON.parse(JSON.stringify(config))
combinerConfig.phoneNumberPrivacy.enabled = true
Expand Down Expand Up @@ -118,6 +123,7 @@ const signerConfig: SignerConfig = {
port: undefined,
ssl: true,
poolMaxSize: 50,
timeout: DB_TIMEOUT,
},
keystore: {
type: SupportedKeystore.MOCK_SECRET_MANAGER,
Expand Down Expand Up @@ -148,6 +154,8 @@ const signerConfig: SignerConfig = {
timeout: 5000,
test_quota_bypass_percentage: 0,
fullNodeTimeoutMs: FULL_NODE_TIMEOUT_IN_MS,
fullNodeRetryCount: RETRY_COUNT,
fullNodeRetryDelayMs: RETRY_DELAY_IN_MS,
}

const testBlockNumber = 1000000
Expand Down
21 changes: 16 additions & 5 deletions packages/phone-number-privacy/common/src/utils/authentication.ts
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,9 @@ export async function authenticateUser<R extends PhoneNumberPrivacyRequest>(
logger: Logger,
shouldFailOpen: boolean = false,
warnings: ErrorType[] = [],
timeoutMs: number = FULL_NODE_TIMEOUT_IN_MS
timeoutMs: number = FULL_NODE_TIMEOUT_IN_MS,
retryCount: number = RETRY_COUNT,
retryDelay: number = RETRY_DELAY_IN_MS
): Promise<boolean> {
logger.debug('Authenticating user')

Expand All @@ -43,7 +45,14 @@ export async function authenticateUser<R extends PhoneNumberPrivacyRequest>(
if (authMethod && authMethod === AuthenticationMethod.ENCRYPTION_KEY) {
let registeredEncryptionKey
try {
registeredEncryptionKey = await getDataEncryptionKey(signer, contractKit, logger, timeoutMs)
registeredEncryptionKey = await getDataEncryptionKey(
signer,
contractKit,
logger,
timeoutMs,
retryCount,
retryDelay
)
} catch (err) {
// getDataEncryptionKey should only throw if there is a full-node connection issue.
// That is, it does not throw if the DEK is undefined or invalid
Expand Down Expand Up @@ -129,17 +138,19 @@ export async function getDataEncryptionKey(
address: string,
contractKit: ContractKit,
logger: Logger,
timeoutMs: number
timeoutMs: number,
fullNodeRetryCount: number,
fullNodeRetryDelayMs: number
): Promise<string> {
try {
const res = await retryAsyncWithBackOffAndTimeout(
async () => {
const accountWrapper: AccountsWrapper = await contractKit.contracts.getAccounts()
return accountWrapper.getDataEncryptionKey(address)
},
RETRY_COUNT,
fullNodeRetryCount,
[],
RETRY_DELAY_IN_MS,
fullNodeRetryDelayMs,
1.5,
timeoutMs
)
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
export const REASONABLE_BODY_CHAR_LIMIT: number = 16_000
export const DB_TIMEOUT = 1000
export const DB_POOL_MAX_SIZE = 50
export const FULL_NODE_TIMEOUT_IN_MS = 1000
export const RETRY_COUNT = 5
export const RETRY_DELAY_IN_MS = 100
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import { DB_TIMEOUT, ErrorMessage } from '@celo/phone-number-privacy-common'
import { ErrorMessage } from '@celo/phone-number-privacy-common'
import Logger from 'bunyan'
import { Knex } from 'knex'
import { config } from '../../../config'
import { Histograms, meter } from '../../metrics'
import { AccountRecord, ACCOUNTS_COLUMNS, ACCOUNTS_TABLE, toAccountRecord } from '../models/account'
import { countAndThrowDBError, tableWithLockForTrx } from '../utils'
Expand All @@ -26,7 +27,7 @@ export async function getPerformedQueryCount(
.select(ACCOUNTS_COLUMNS.numLookups)
.where(ACCOUNTS_COLUMNS.address, account)
.first()
.timeout(DB_TIMEOUT)
.timeout(config.db.timeout)
return queryCounts === undefined ? 0 : queryCounts[ACCOUNTS_COLUMNS.numLookups]
},
[],
Expand All @@ -48,7 +49,7 @@ async function getAccountExists(
const accountRecord = await tableWithLockForTrx(accounts(db, accountsTable), trx)
.where(ACCOUNTS_COLUMNS.address, account)
.first()
.timeout(DB_TIMEOUT)
.timeout(config.db.timeout)

return !!accountRecord
},
Expand Down Expand Up @@ -77,7 +78,7 @@ export async function incrementQueryCount(
.transacting(trx)
.where(ACCOUNTS_COLUMNS.address, account)
.increment(ACCOUNTS_COLUMNS.numLookups, 1)
.timeout(DB_TIMEOUT)
.timeout(config.db.timeout)
} else {
const newAccountRecord = toAccountRecord(account, 1)
await insertRecord(db, accountsTable, newAccountRecord, logger, trx)
Expand All @@ -98,7 +99,7 @@ async function insertRecord(
trx: Knex.Transaction
): Promise<void> {
try {
await accounts(db, accountsTable).transacting(trx).insert(data).timeout(DB_TIMEOUT)
await accounts(db, accountsTable).transacting(trx).insert(data).timeout(config.db.timeout)
} catch (error) {
countAndThrowDBError(error, logger, ErrorMessage.DATABASE_INSERT_FAILURE)
}
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import { DB_TIMEOUT, Domain, domainHash, ErrorMessage } from '@celo/phone-number-privacy-common'
import { Domain, domainHash, ErrorMessage } from '@celo/phone-number-privacy-common'
import Logger from 'bunyan'
import { Knex } from 'knex'
import { config } from '../../../config'
import { Histograms, meter } from '../../metrics'
import {
DOMAIN_REQUESTS_COLUMNS,
Expand Down Expand Up @@ -35,7 +36,7 @@ export async function getDomainRequestRecordExists<D extends Domain>(
[DOMAIN_REQUESTS_COLUMNS.blindedMessage]: blindedMessage,
})
.first()
.timeout(DB_TIMEOUT)
.timeout(config.db.timeout)
return !!existingRequest
},
[],
Expand All @@ -58,7 +59,7 @@ export async function storeDomainRequestRecord<D extends Domain>(
await domainRequests(db)
.transacting(trx)
.insert(toDomainRequestRecord(domain, blindedMessage))
.timeout(DB_TIMEOUT)
.timeout(config.db.timeout)
},
[],
(err: any) => countAndThrowDBError(err, logger, ErrorMessage.DATABASE_INSERT_FAILURE),
Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
import { DB_TIMEOUT, ErrorMessage } from '@celo/phone-number-privacy-common'
import { ErrorMessage } from '@celo/phone-number-privacy-common'
import { Domain, domainHash } from '@celo/phone-number-privacy-common/lib/domains'
import Logger from 'bunyan'
import { Knex } from 'knex'
import { config } from '../../../config'
import { Histograms, meter } from '../../metrics'
import {
DOMAIN_STATE_COLUMNS,
Expand Down Expand Up @@ -29,7 +30,7 @@ export async function setDomainDisabled<D extends Domain>(
.transacting(trx)
.where(DOMAIN_STATE_COLUMNS.domainHash, hash)
.update(DOMAIN_STATE_COLUMNS.disabled, true)
.timeout(DB_TIMEOUT)
.timeout(config.db.timeout)
},
[],
(err: any) => countAndThrowDBError(err, logger, ErrorMessage.DATABASE_UPDATE_FAILURE),
Expand Down Expand Up @@ -71,7 +72,7 @@ export async function getDomainStateRecord<D extends Domain>(
const result = await tableWithLockForTrx(domainStates(db), trx)
.where(DOMAIN_STATE_COLUMNS.domainHash, hash)
.first()
.timeout(DB_TIMEOUT)
.timeout(config.db.timeout)

// bools are stored in db as ints (1 or 0), so we must cast them back
if (result) {
Expand Down Expand Up @@ -111,7 +112,7 @@ export async function updateDomainStateRecord<D extends Domain>(
.transacting(trx)
.where(DOMAIN_STATE_COLUMNS.domainHash, hash)
.update(domainState)
.timeout(DB_TIMEOUT)
.timeout(config.db.timeout)
}
},
[],
Expand All @@ -130,7 +131,7 @@ export async function insertDomainStateRecord(
return meter(
async () => {
logger.debug({ domainState }, 'Insert domain state')
await domainStates(db).transacting(trx).insert(domainState).timeout(DB_TIMEOUT)
await domainStates(db).transacting(trx).insert(domainState).timeout(config.db.timeout)
return domainState
},
[],
Expand Down
Loading