mirror of
https://github.com/kmc7468/arkvault.git
synced 2025-12-15 22:38:47 +00:00
pubKeyStore와 privKeyStore를 keyPairStore로 통합
This commit is contained in:
@@ -1,21 +1,21 @@
|
||||
import { Dexie, type EntityTable } from "dexie";
|
||||
|
||||
interface ClientKeyPair {
|
||||
interface KeyPair {
|
||||
type: "publicKey" | "privateKey";
|
||||
key: CryptoKey;
|
||||
}
|
||||
|
||||
const keyStore = new Dexie("keyStore") as Dexie & {
|
||||
clientKeyPairs: EntityTable<ClientKeyPair, "type">;
|
||||
keyPair: EntityTable<KeyPair, "type">;
|
||||
};
|
||||
|
||||
keyStore.version(1).stores({
|
||||
clientKeyPairs: "type",
|
||||
keyPair: "type",
|
||||
});
|
||||
|
||||
export const getKeyPairFromIndexedDB = async () => {
|
||||
const pubKey = await keyStore.clientKeyPairs.get("publicKey");
|
||||
const privKey = await keyStore.clientKeyPairs.get("privateKey");
|
||||
const pubKey = await keyStore.keyPair.get("publicKey");
|
||||
const privKey = await keyStore.keyPair.get("privateKey");
|
||||
return {
|
||||
pubKey: pubKey?.key ?? null,
|
||||
privKey: privKey?.key ?? null,
|
||||
@@ -23,7 +23,10 @@ export const getKeyPairFromIndexedDB = async () => {
|
||||
};
|
||||
|
||||
export const storeKeyPairIntoIndexedDB = async (pubKey: CryptoKey, privKey: CryptoKey) => {
|
||||
await keyStore.clientKeyPairs.bulkPut([
|
||||
if (!pubKey.extractable) throw new Error("Public key must be extractable");
|
||||
if (privKey.extractable) throw new Error("Private key must be non-extractable");
|
||||
|
||||
await keyStore.keyPair.bulkPut([
|
||||
{ type: "publicKey", key: pubKey },
|
||||
{ type: "privateKey", key: privKey },
|
||||
]);
|
||||
|
||||
@@ -1,4 +1,3 @@
|
||||
import { writable } from "svelte/store";
|
||||
|
||||
export const pubKeyStore = writable<CryptoKey | null>(null);
|
||||
export const privKeyStore = writable<CryptoKey | null>(null);
|
||||
export const keyPairStore = writable<CryptoKeyPair | null>(null);
|
||||
|
||||
Reference in New Issue
Block a user