Files
start-os/sdk/base/lib/s9pk/merkleArchive/directoryContents.ts
Aiden McClelland db0695126f Refactor/actions (#2733)
* store, properties, manifest

* interfaces

* init and backups

* fix init and backups

* file models

* more versions

* dependencies

* config except dynamic types

* clean up config

* remove disabled from non-dynamic vaues

* actions

* standardize example code block formats

* wip: actions refactor

Co-authored-by: Jade <Blu-J@users.noreply.github.com>

* commit types

* fix types

* update types

* update action request type

* update apis

* add description to actionrequest

* clean up imports

* revert package json

* chore: Remove the recursive to the index

* chore: Remove the other thing I was testing

* flatten action requests

* update container runtime with new config paradigm

* new actions strategy

* seems to be working

* misc backend fixes

* fix fe bugs

* only show breakages if breakages

* only show success modal if result

* don't panic on failed removal

* hide config from actions page

* polyfill autoconfig

* use metadata strategy for actions instead of prev

* misc fixes

* chore: split the sdk into 2 libs (#2736)

* follow sideload progress (#2718)

* follow sideload progress

* small bugfix

* shareReplay with no refcount false

* don't wrap sideload progress in RPCResult

* dont present toast

---------

Co-authored-by: Aiden McClelland <me@drbonez.dev>

* chore: Add the initial of the creation of the two sdk

* chore: Add in the baseDist

* chore: Add in the baseDist

* chore: Get the web and the runtime-container running

* chore: Remove the empty file

* chore: Fix it so the container-runtime works

---------

Co-authored-by: Matt Hill <MattDHill@users.noreply.github.com>
Co-authored-by: Aiden McClelland <me@drbonez.dev>

* misc fixes

* update todos

* minor clean up

* fix link script

* update node version in CI test

* fix node version syntax in ci build

* wip: fixing callbacks

* fix sdk makefile dependencies

* add support for const outside of main

* update apis

* don't panic!

* Chore: Capture weird case on rpc, and log that

* fix procedure id issue

* pass input value for dep auto config

* handle disabled and warning for actions

* chore: Fix for link not having node_modules

* sdk fixes

* fix build

* fix build

* fix build

---------

Co-authored-by: Matt Hill <mattnine@protonmail.com>
Co-authored-by: Jade <Blu-J@users.noreply.github.com>
Co-authored-by: J H <dragondef@gmail.com>
Co-authored-by: Jade <2364004+Blu-J@users.noreply.github.com>
Co-authored-by: Matt Hill <MattDHill@users.noreply.github.com>
2024-09-25 16:12:52 -06:00

81 lines
2.3 KiB
TypeScript

import { ArrayBufferReader, Entry } from "."
import { blake3 } from "@noble/hashes/blake3"
import { serializeVarint } from "./varint"
import { FileContents } from "./fileContents"
import { compare } from ".."
export class DirectoryContents {
static readonly headerSize =
8 + // position: u64 BE
8 // size: u64 BE
private constructor(readonly contents: { [name: string]: Entry }) {}
static async deserialize(
source: Blob,
header: ArrayBufferReader,
sighash: Uint8Array,
maxSize: bigint,
): Promise<DirectoryContents> {
const position = header.nextU64()
const size = header.nextU64()
if (size > maxSize) {
throw new Error("size is greater than signed")
}
const tocReader = new ArrayBufferReader(
await source
.slice(Number(position), Number(position + size))
.arrayBuffer(),
)
const len = tocReader.nextVarint()
const entries: { [name: string]: Entry } = {}
for (let i = 0; i < len; i++) {
const name = tocReader.nextVarstring()
const entry = await Entry.deserialize(source, tocReader)
entries[name] = entry
}
const res = new DirectoryContents(entries)
if (!compare(res.sighash(), sighash)) {
throw new Error("hash sum does not match")
}
return res
}
sighash(): Uint8Array {
const hasher = blake3.create({})
const names = Object.keys(this.contents).sort()
hasher.update(new Uint8Array(serializeVarint(names.length)))
for (const name of names) {
const entry = this.contents[name]
const nameBuf = new TextEncoder().encode(name)
hasher.update(new Uint8Array(serializeVarint(nameBuf.length)))
hasher.update(nameBuf)
hasher.update(new Uint8Array(entry.hash))
const sizeBuf = new Uint8Array(8)
new DataView(sizeBuf.buffer).setBigUint64(0, entry.size)
hasher.update(sizeBuf)
hasher.update(new Uint8Array([0]))
}
return hasher.digest()
}
getPath(path: string[]): Entry | null {
if (path.length === 0) {
return null
}
const next = this.contents[path[0]]
const rest = path.slice(1)
if (next === undefined) {
return null
}
if (rest.length === 0) {
return next
}
if (next.contents instanceof DirectoryContents) {
return next.contents.getPath(rest)
}
return null
}
}