2025-03-03 09:46:03 +13:00
|
|
|
import { ed25519 } from "@noble/curves/ed25519";
|
|
|
|
|
import BufferReader from "./buffer_reader.js";
|
|
|
|
|
import Packet from "./packet.js";
|
|
|
|
|
|
|
|
|
|
class Advert {
|
|
|
|
|
|
|
|
|
|
constructor(publicKey, timestamp, signature, appData) {
|
|
|
|
|
this.publicKey = publicKey;
|
|
|
|
|
this.timestamp = timestamp;
|
|
|
|
|
this.signature = signature;
|
|
|
|
|
this.appData = appData;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
getTimestamp() {
|
|
|
|
|
return (new BufferReader(this.timestamp)).readUInt32LE();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
isVerified() {
|
|
|
|
|
return ed25519.verify(this.signature, Buffer.concat([
|
|
|
|
|
this.publicKey,
|
|
|
|
|
this.timestamp,
|
|
|
|
|
this.appData,
|
|
|
|
|
]), this.publicKey);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static fromPacketBytes(bytes) {
|
|
|
|
|
|
|
|
|
|
// parse packet from bytes
|
|
|
|
|
const packet = Packet.fromBytes(bytes);
|
|
|
|
|
|
|
|
|
|
// read packet payload
|
2025-03-03 09:48:10 +13:00
|
|
|
const bufferReader = new BufferReader(packet.payload);
|
|
|
|
|
const publicKey = bufferReader.readBytes(32);
|
|
|
|
|
const timestamp = bufferReader.readBytes(4); // read as bytes for signature
|
|
|
|
|
const signature = bufferReader.readBytes(64);
|
|
|
|
|
const appData = bufferReader.readRemainingBytes();
|
2025-03-03 09:46:03 +13:00
|
|
|
|
|
|
|
|
return new Advert(publicKey, timestamp, signature, appData);
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export default Advert;
|