GO tooling and library for embedding zip files inside existing binaries.

spsobole 01a8940c89 Sort info 1 rok pred
cmd 01a8940c89 Sort info 1 rok pred
example 781eadc3f6 Cleanup the FS implementationfor vessel 3 rokov pred
.gitignore 781eadc3f6 Cleanup the FS implementationfor vessel 3 rokov pred
README.md c45a91e6ac Fix some formatting 3 rokov pred
build.yaml 781eadc3f6 Cleanup the FS implementationfor vessel 3 rokov pred
bundle.go 5a1b0ff2b3 Add ability to see timestamp and size of bundled files 1 rok pred
go.mod 781eadc3f6 Cleanup the FS implementationfor vessel 3 rokov pred
go.sum 781eadc3f6 Cleanup the FS implementationfor vessel 3 rokov pred
http_dir.go 781eadc3f6 Cleanup the FS implementationfor vessel 3 rokov pred
http_file.go 7528df9b03 Fix lack of modtime in vessel zip files 1 rok pred
http_fs.go 7528df9b03 Fix lack of modtime in vessel zip files 1 rok pred
log.go 7842c7d5b8 A bit of cleanup 3 rokov pred
overlay.go 7528df9b03 Fix lack of modtime in vessel zip files 1 rok pred
vessel.go 86da497ddd Add a fully flushed out server 3 rokov pred
vessel_test.go 7528df9b03 Fix lack of modtime in vessel zip files 1 rok pred

README.md

vessel

Implements a golang library and command line tool for embedding contents of a zip file into a golang binary for the purpose of packing the binary and content into a single file for distribution.

The zip file is appended to the back of the binary, and the provided API allows us to access the zipped files directly.

bundling

In the example below, vesselcmd will zip up the content of site/ and attach it to the golang binary server

./vesselcmd build --overwrite --bundle=./server.exe --src=site/

Accessing the bundled resources

Once bundled the golang program can acess the content via:

    b, err := vessel.Self()
    if err != nil {
        panic(err)
    }
    fs := b.FileSystem() // this returns an http.FileSystem 

We can then directly use the returned filesystem to serve http pages/content

    http.Handle("/", http.FileServer(fs))

Or we can access the files ourselves by using the http.FileSystem interfaces

    f, err := fs.Open("/templates/list.html")
    if err != nil {
        return err
    }
    defer f.Close()
    data, err := ioutil.ReadAll(f)