mirror of
https://github.com/kmc7468/arkvault.git
synced 2025-12-16 06:58:46 +00:00
암호 키 생성 및 등록시 최초 MEK도 함께 생성 및 등록하도록 구현
This commit is contained in:
@@ -1,9 +1,13 @@
|
||||
import {
|
||||
encodeToBase64,
|
||||
generateRSAKeyPair,
|
||||
makeRSAKeyNonextractable,
|
||||
exportRSAKeyToBase64,
|
||||
exportRSAKey,
|
||||
generateAESKey,
|
||||
makeAESKeyNonextractable,
|
||||
exportAESKey,
|
||||
} from "$lib/modules/crypto";
|
||||
import { keyPairStore } from "$lib/stores";
|
||||
import { keyPairStore, mekStore } from "$lib/stores";
|
||||
|
||||
export const generateKeyPair = async () => {
|
||||
const keyPair = await generateRSAKeyPair();
|
||||
@@ -15,7 +19,21 @@ export const generateKeyPair = async () => {
|
||||
});
|
||||
|
||||
return {
|
||||
pubKeyBase64: await exportRSAKeyToBase64(keyPair.publicKey, "public"),
|
||||
privKeyBase64: await exportRSAKeyToBase64(keyPair.privateKey, "private"),
|
||||
pubKeyBase64: encodeToBase64((await exportRSAKey(keyPair.publicKey, "public")).key),
|
||||
privKeyBase64: encodeToBase64((await exportRSAKey(keyPair.privateKey, "private")).key),
|
||||
};
|
||||
};
|
||||
|
||||
export const generateMekDraft = async () => {
|
||||
const mek = await generateAESKey();
|
||||
const mekSecured = await makeAESKeyNonextractable(mek);
|
||||
|
||||
mekStore.update((meks) => {
|
||||
meks.set(meks.size, mekSecured);
|
||||
return meks;
|
||||
});
|
||||
|
||||
return {
|
||||
mekDraft: await exportAESKey(mek),
|
||||
};
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user