SHiNE-server/shine-UI/js/services/device-key-utils.js

52 lines
1.5 KiB
JavaScript

import { base64ToBytes } from './crypto-utils.js';
function isByteArrayLike(value) {
return Array.isArray(value) || ArrayBuffer.isView(value);
}
function parseKeypairJson64(raw) {
const text = String(raw || '').trim();
if (!text.startsWith('[')) return null;
let parsed;
try {
parsed = JSON.parse(text);
} catch {
return null;
}
if (!isByteArrayLike(parsed)) return null;
const asArray = Array.from(parsed);
if (asArray.length < 32) {
throw new Error('Некорректный JSON ключ device.key: ожидалось минимум 32 байта');
}
const out = new Uint8Array(asArray.length);
for (let i = 0; i < asArray.length; i += 1) {
const n = Number(asArray[i]);
if (!Number.isInteger(n) || n < 0 || n > 255) {
throw new Error('Некорректный JSON ключ device.key: найдены не-байтовые значения');
}
out[i] = n;
}
return out;
}
export function extractSeed32FromPkcs8B64(pkcs8B64) {
const bytes = base64ToBytes(String(pkcs8B64 || '').trim());
if (bytes.length < 32) throw new Error('Некорректный PKCS8 ключ device.key');
return bytes.slice(bytes.length - 32);
}
export function extractDeviceKey32FromStoredValue(storedDeviceKey) {
const raw = String(storedDeviceKey || '').trim();
if (!raw) throw new Error('Пустой device.key');
const jsonBytes = parseKeypairJson64(raw);
if (jsonBytes) {
return jsonBytes.slice(0, 32);
}
return extractSeed32FromPkcs8B64(raw);
}