Skip to content

Commit

Permalink
test: check that existing P-256 publicKeyHex keys can be recomputed
Browse files Browse the repository at this point in the history
  • Loading branch information
mirceanis committed Feb 24, 2023
1 parent 22648aa commit 5808f81
Show file tree
Hide file tree
Showing 4 changed files with 115 additions and 6 deletions.
106 changes: 106 additions & 0 deletions __tests__/data.migration.test.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,106 @@
// noinspection ES6PreferShortImport

import { KeyManagementSystem, SecretBox } from '../packages/kms-local/src'
import { Entities, KeyStore, migrations, PrivateKeyStore, } from '../packages/data-store/src'
import { PrivateKeyStoreJson } from '../packages/data-store-json/src'

import { DataSource } from 'typeorm'
import * as fs from 'fs'

import { jest } from '@jest/globals'
import { fileURLToPath } from 'url'
import { dirname } from 'path'

// @ts-ignore TS1343
const __filename = fileURLToPath(import.meta.url)
const __dirname = dirname(__filename)

jest.setTimeout(60000)

const dbEncryptionKey = '29739248cad1bd1a0fc4d9b75cd4d2990de535baf5caadfdf8d8f86664aa830c'

describe('data handling tests', () => {
describe('can recompute p256 keys from old database', () => {
const fixture = __dirname + '/fixtures/local-database-before-p256key-migration.sqlite'
const databaseFile = fixture + '.tmp'
// intentionally using DataSource instead of Promise<DataSource> to test compatibility
let dbConnection: DataSource

beforeAll(async () => {
await fs.promises.copyFile(fixture, databaseFile)
dbConnection = new DataSource({
name: 'test',
type: 'sqlite',
database: databaseFile,
synchronize: false,
migrations: migrations,
migrationsRun: true,
logging: false,
entities: Entities,
})
})

afterAll(async () => {
await dbConnection.destroy()
await fs.promises.unlink(databaseFile)
})

it('should recompute p256 keys', async () => {
const kmsLocal = new KeyManagementSystem(
new PrivateKeyStore(dbConnection, new SecretBox(dbEncryptionKey)),
)
const managedKeyStore = new KeyStore(dbConnection)
// list known private keys. kms-local will compute the correct public keys
const allPrivKeys = await kmsLocal.listKeys()
const keyIds: string[] = []
for (const privKey of allPrivKeys) {
if (privKey.type === 'Secp256r1') {
const managedKey = await managedKeyStore.getKey({ kid: privKey.kid })
if (managedKey.publicKeyHex.length === 64) {
keyIds.push(privKey.kid)
managedKey.publicKeyHex = privKey.publicKeyHex
}
await managedKeyStore.importKey(managedKey)
}
}
for (const kid of keyIds) {
const managedKey = await managedKeyStore.getKey({ kid })
expect(managedKey.publicKeyHex.length).toEqual(66)
expect(managedKey.publicKeyHex).toMatch(/^(02|03).*/)
}
})
})
describe('kms-local maintains public key values for listKeys', () => {
it('when using data-store-json', async () => {
const memoryJsonStore = {
notifyUpdate: () => Promise.resolve(),
}
const kmsLocal = new KeyManagementSystem(
new PrivateKeyStoreJson(memoryJsonStore, new SecretBox(dbEncryptionKey)),
)
const key = await kmsLocal.createKey({ type: 'Secp256r1' })
const allPrivKeys = await kmsLocal.listKeys()
const foundKey = allPrivKeys.find((k) => k.kid === key.kid)
expect(foundKey?.publicKeyHex).toEqual(key.publicKeyHex)
})

it('when using data-store', async () => {
const dbConnection = new DataSource({
type: 'sqlite',
database: ':memory:',
entities: Entities,
synchronize: false,
migrations: migrations,
migrationsRun: true,
logging: false,
})
const kmsLocal = new KeyManagementSystem(
new PrivateKeyStore(dbConnection, new SecretBox(dbEncryptionKey)),
)
const key = await kmsLocal.createKey({ type: 'Secp256r1' })
const allPrivKeys = await kmsLocal.listKeys()
const foundKey = allPrivKeys.find((k) => k.kid === key.kid)
expect(foundKey?.publicKeyHex).toEqual(key.publicKeyHex)
})
})
})
11 changes: 6 additions & 5 deletions __tests__/initial.migration.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -34,18 +34,19 @@ import { KeyManager } from '../packages/key-manager/src'
import { DIDManager } from '../packages/did-manager/src'
import { FakeDidProvider, FakeDidResolver } from '../packages/test-utils/src'

import { DataSourceOptions, DataSource } from 'typeorm'
import { DataSource, DataSourceOptions } from 'typeorm'
import { Resolver } from 'did-resolver'
import { getResolver as ethrDidResolver } from 'ethr-did-resolver'
import { getResolver as webDidResolver } from 'web-did-resolver'
import * as fs from 'fs'

import { jest } from '@jest/globals'
import { fileURLToPath } from 'url';
import { dirname } from 'path';
import { fileURLToPath } from 'url'
import { dirname } from 'path'

const __filename = fileURLToPath(import.meta.url);
const __dirname = dirname(__filename);
// @ts-ignore TS1343
const __filename = fileURLToPath(import.meta.url)
const __dirname = dirname(__filename)

jest.setTimeout(60000)

Expand Down
2 changes: 1 addition & 1 deletion packages/test-react-app/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -14,9 +14,9 @@
"@veramo/did-jwt": "^5.0.0",
"@veramo/did-manager": "^5.0.0",
"@veramo/did-provider-ethr": "^5.0.0",
"@veramo/did-provider-jwk": "^5.0.0",
"@veramo/did-provider-key": "^5.0.0",
"@veramo/did-provider-pkh": "^5.0.0",
"@veramo/did-provider-jwk": "^5.0.0",
"@veramo/did-provider-web": "^5.0.0",
"@veramo/did-resolver": "^5.0.0",
"@veramo/key-manager": "^5.0.0",
Expand Down
2 changes: 2 additions & 0 deletions packages/test-react-app/tsconfig.json
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,9 @@
{ "path": "../did-jwt" },
{ "path": "../did-manager" },
{ "path": "../did-provider-ethr" },
{ "path": "../did-provider-jwk" },
{ "path": "../did-provider-key" },
{ "path": "../did-provider-pkh" },
{ "path": "../did-provider-web" },
{ "path": "../did-resolver" },
{ "path": "../key-manager" },
Expand Down

0 comments on commit 5808f81

Please sign in to comment.