feat: improved building
This commit is contained in:
parent
7a799868fb
commit
1c7cf7966f
@ -1,6 +1,6 @@
|
|||||||
.env
|
.env
|
||||||
/docker-compose.*
|
/docker-compose.*
|
||||||
/result
|
/result*
|
||||||
/.direnv/
|
/.direnv/
|
||||||
/build/
|
/build/
|
||||||
|
|
||||||
|
11
.github/workflows/release.yaml
vendored
11
.github/workflows/release.yaml
vendored
@ -28,13 +28,20 @@ jobs:
|
|||||||
authToken: '${{ secrets.CACHIX_AUTH_TOKEN }}'
|
authToken: '${{ secrets.CACHIX_AUTH_TOKEN }}'
|
||||||
|
|
||||||
- name: Build
|
- name: Build
|
||||||
run: nix develop --command trevstack-build
|
run: >-
|
||||||
|
nix build
|
||||||
|
.#trevstack-linux-amd64
|
||||||
|
.#trevstack-linux-arm64
|
||||||
|
.#trevstack-linux-arm
|
||||||
|
.#trevstack-windows-amd64
|
||||||
|
.#trevstack-darwin-amd64
|
||||||
|
.#trevstack-darwin-arm64
|
||||||
|
|
||||||
- name: Create Release
|
- name: Create Release
|
||||||
uses: softprops/action-gh-release@v2
|
uses: softprops/action-gh-release@v2
|
||||||
with:
|
with:
|
||||||
files: |-
|
files: |-
|
||||||
build/**
|
result*/bin/*
|
||||||
|
|
||||||
# https://docs.docker.com/build/ci/github-actions/manage-tags-labels/
|
# https://docs.docker.com/build/ci/github-actions/manage-tags-labels/
|
||||||
package:
|
package:
|
||||||
|
2
.gitignore
vendored
2
.gitignore
vendored
@ -1,5 +1,5 @@
|
|||||||
.env
|
.env
|
||||||
/docker-compose.*
|
/docker-compose.*
|
||||||
/result
|
/result*
|
||||||
/.direnv/
|
/.direnv/
|
||||||
/build/
|
/build/
|
@ -1,24 +0,0 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
|
|
||||||
git_root=$(git rev-parse --show-toplevel)
|
|
||||||
url=$(git config --get remote.origin.url)
|
|
||||||
name=$(basename -s .git "${url}")
|
|
||||||
git_version=$(git describe --tags --abbrev=0)
|
|
||||||
version=${git_version#v}
|
|
||||||
|
|
||||||
echo "building client"
|
|
||||||
cd "${git_root}"
|
|
||||||
nix build .#trevstack-client
|
|
||||||
cp -a result/. server/client
|
|
||||||
chmod -R u+w server/client
|
|
||||||
|
|
||||||
echo "building server"
|
|
||||||
cd "${git_root}/server"
|
|
||||||
echo "Building ${name}-windows-amd64-${version}.exe"
|
|
||||||
GOOS=windows GOARCH=amd64 go build -o "./build/${name}-windows-amd64-${version}.exe" .
|
|
||||||
echo "Building ${name}-linux-amd64-${version}"
|
|
||||||
GOOS=linux GOARCH=amd64 go build -o "./build/${name}-linux-amd64-${version}" .
|
|
||||||
echo "Building ${name}-linux-amd64-${version}"
|
|
||||||
GOOS=linux GOARCH=arm64 go build -o "./build/${name}-linux-arm64-${version}" .
|
|
||||||
echo "Building ${name}-linux-arm-${version}"
|
|
||||||
GOOS=linux GOARCH=arm go build -o "./build/${name}-linux-arm-${version}" .
|
|
100
flake.nix
100
flake.nix
@ -23,14 +23,40 @@
|
|||||||
pname = "trevstack";
|
pname = "trevstack";
|
||||||
version = "0.0.18";
|
version = "0.0.18";
|
||||||
|
|
||||||
supportedSystems = [
|
build-systems = [
|
||||||
"x86_64-linux"
|
"x86_64-linux"
|
||||||
"aarch64-linux"
|
"aarch64-linux"
|
||||||
"x86_64-darwin"
|
"x86_64-darwin"
|
||||||
"aarch64-darwin"
|
"aarch64-darwin"
|
||||||
];
|
];
|
||||||
|
host-systems = [
|
||||||
|
{
|
||||||
|
GOOS = "linux";
|
||||||
|
GOARCH = "amd64";
|
||||||
|
}
|
||||||
|
{
|
||||||
|
GOOS = "linux";
|
||||||
|
GOARCH = "arm64";
|
||||||
|
}
|
||||||
|
{
|
||||||
|
GOOS = "linux";
|
||||||
|
GOARCH = "arm";
|
||||||
|
}
|
||||||
|
{
|
||||||
|
GOOS = "windows";
|
||||||
|
GOARCH = "amd64";
|
||||||
|
}
|
||||||
|
{
|
||||||
|
GOOS = "darwin";
|
||||||
|
GOARCH = "amd64";
|
||||||
|
}
|
||||||
|
{
|
||||||
|
GOOS = "darwin";
|
||||||
|
GOARCH = "arm64";
|
||||||
|
}
|
||||||
|
];
|
||||||
forSystem = f:
|
forSystem = f:
|
||||||
nixpkgs.lib.genAttrs supportedSystems (
|
nixpkgs.lib.genAttrs build-systems (
|
||||||
system:
|
system:
|
||||||
f {
|
f {
|
||||||
inherit system;
|
inherit system;
|
||||||
@ -74,7 +100,6 @@
|
|||||||
sha256 = "sha256-3XBQCc9H9N/AZm/8J5bJRgBhVtoZKFvbdTB+glHxYdA=";
|
sha256 = "sha256-3XBQCc9H9N/AZm/8J5bJRgBhVtoZKFvbdTB+glHxYdA=";
|
||||||
};
|
};
|
||||||
vendorHash = "sha256-CIiG/XhV8xxjYY0sZcSvIFcJ1Wh8LyDDwqem2cSSwBA=";
|
vendorHash = "sha256-CIiG/XhV8xxjYY0sZcSvIFcJ1Wh8LyDDwqem2cSSwBA=";
|
||||||
nativeCheckInputs = with pkgs; [less];
|
|
||||||
})
|
})
|
||||||
|
|
||||||
# Client
|
# Client
|
||||||
@ -148,29 +173,54 @@
|
|||||||
|
|
||||||
formatter = forSystem ({pkgs, ...}: pkgs.alejandra);
|
formatter = forSystem ({pkgs, ...}: pkgs.alejandra);
|
||||||
|
|
||||||
packages = forSystem ({pkgs, ...}: rec {
|
packages = forSystem (
|
||||||
trevstack-client = pkgs.buildNpmPackage {
|
{pkgs, ...}: let
|
||||||
pname = "${pname}-client";
|
server = pkgs.buildGoModule {
|
||||||
inherit version;
|
inherit client pname version;
|
||||||
src = ./client;
|
src = ./server;
|
||||||
npmDepsHash = "sha256-u7zkBgaxDEB2XFrNl0f7/HtW0Oy2B7FVPot9MLPzXGc=";
|
vendorHash = "sha256-uXyCYODrBWNm7nbibm66oO90SYXRvrNtjF0K4ZI7IkM=";
|
||||||
nodejs = pkgs.nodejs_22;
|
env.CGO_ENABLED = 0;
|
||||||
|
|
||||||
installPhase = ''
|
preBuild = ''
|
||||||
cp -r build "$out"
|
cp -r ${client} client
|
||||||
chmod -R u+w "$out"
|
'';
|
||||||
'';
|
};
|
||||||
};
|
client = pkgs.buildNpmPackage {
|
||||||
trevstack = pkgs.buildGoModule {
|
pname = "${pname}-client";
|
||||||
inherit trevstack-client pname version;
|
inherit version;
|
||||||
src = ./server;
|
src = ./client;
|
||||||
vendorHash = "sha256-uXyCYODrBWNm7nbibm66oO90SYXRvrNtjF0K4ZI7IkM=";
|
npmDepsHash = "sha256-u7zkBgaxDEB2XFrNl0f7/HtW0Oy2B7FVPot9MLPzXGc=";
|
||||||
|
|
||||||
preBuild = ''
|
installPhase = ''
|
||||||
cp -r ${trevstack-client} client
|
cp -r build "$out"
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
default = trevstack;
|
in
|
||||||
});
|
{
|
||||||
|
default = server;
|
||||||
|
}
|
||||||
|
// builtins.listToAttrs (builtins.map (x: {
|
||||||
|
name = "${pname}-${x.GOOS}-${x.GOARCH}";
|
||||||
|
value = server.overrideAttrs {
|
||||||
|
nativeBuildInputs = server.nativeBuildInputs ++ [
|
||||||
|
pkgs.rename
|
||||||
|
];
|
||||||
|
env.CGO_ENABLED = 0;
|
||||||
|
env.GOOS = x.GOOS;
|
||||||
|
env.GOARCH = x.GOARCH;
|
||||||
|
|
||||||
|
installPhase = ''
|
||||||
|
runHook preInstall
|
||||||
|
|
||||||
|
mkdir -p $out/bin
|
||||||
|
find $GOPATH/bin -type f -exec mv -t $out/bin {} +
|
||||||
|
rename 's/(.+\/)(.+?)(\.[^.]*$|$)/$1${pname}-${x.GOOS}-${x.GOARCH}-${version}$3/' $out/bin/*
|
||||||
|
|
||||||
|
runHook postInstall
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
})
|
||||||
|
host-systems)
|
||||||
|
);
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -3,7 +3,6 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"embed"
|
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"log"
|
"log"
|
||||||
@ -18,6 +17,7 @@ import (
|
|||||||
"golang.org/x/net/http2"
|
"golang.org/x/net/http2"
|
||||||
"golang.org/x/net/http2/h2c"
|
"golang.org/x/net/http2/h2c"
|
||||||
|
|
||||||
|
embed "github.com/spotdemo4/trevstack/server"
|
||||||
"github.com/spotdemo4/trevstack/server/internal/database"
|
"github.com/spotdemo4/trevstack/server/internal/database"
|
||||||
"github.com/spotdemo4/trevstack/server/internal/handlers/client"
|
"github.com/spotdemo4/trevstack/server/internal/handlers/client"
|
||||||
"github.com/spotdemo4/trevstack/server/internal/handlers/file"
|
"github.com/spotdemo4/trevstack/server/internal/handlers/file"
|
||||||
@ -26,9 +26,6 @@ import (
|
|||||||
"github.com/spotdemo4/trevstack/server/internal/interceptors"
|
"github.com/spotdemo4/trevstack/server/internal/interceptors"
|
||||||
)
|
)
|
||||||
|
|
||||||
var clientFS *embed.FS
|
|
||||||
var dbFS *embed.FS
|
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
logger := slog.New(slog.NewTextHandler(os.Stdout, &slog.HandlerOptions{}))
|
logger := slog.New(slog.NewTextHandler(os.Stdout, &slog.HandlerOptions{}))
|
||||||
slog.SetDefault(logger)
|
slog.SetDefault(logger)
|
||||||
@ -40,7 +37,7 @@ func main() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Migrate database
|
// Migrate database
|
||||||
err = database.Migrate(env.DatabaseURL, dbFS)
|
err = database.Migrate(env.DatabaseURL, embed.DBFS)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err.Error())
|
log.Fatal(err.Error())
|
||||||
}
|
}
|
||||||
@ -59,7 +56,7 @@ func main() {
|
|||||||
|
|
||||||
// Serve web interface
|
// Serve web interface
|
||||||
mux := http.NewServeMux()
|
mux := http.NewServeMux()
|
||||||
mux.Handle("/", client.NewClientHandler(env.Key, clientFS))
|
mux.Handle("/", client.NewClientHandler(env.Key, embed.ClientFS))
|
||||||
mux.Handle("/file/", file.NewFileHandler(sqlc, env.Key))
|
mux.Handle("/file/", file.NewFileHandler(sqlc, env.Key))
|
||||||
mux.Handle("/grpc/", http.StripPrefix("/grpc", api))
|
mux.Handle("/grpc/", http.StripPrefix("/grpc", api))
|
||||||
|
|
13
server/embed.go
Normal file
13
server/embed.go
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
//go:build !dev
|
||||||
|
|
||||||
|
package embed
|
||||||
|
|
||||||
|
import (
|
||||||
|
"embed"
|
||||||
|
)
|
||||||
|
|
||||||
|
//go:embed all:client
|
||||||
|
var ClientFS embed.FS
|
||||||
|
|
||||||
|
//go:embed db/migrations/*.sql
|
||||||
|
var DBFS embed.FS
|
10
server/embed_dev.go
Normal file
10
server/embed_dev.go
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
//go:build dev
|
||||||
|
|
||||||
|
package embed
|
||||||
|
|
||||||
|
import (
|
||||||
|
"embed"
|
||||||
|
)
|
||||||
|
|
||||||
|
var ClientFS embed.FS
|
||||||
|
var DBFS embed.FS
|
@ -2,6 +2,7 @@ package database
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"embed"
|
"embed"
|
||||||
|
"io"
|
||||||
"log"
|
"log"
|
||||||
"net/url"
|
"net/url"
|
||||||
|
|
||||||
@ -9,8 +10,9 @@ import (
|
|||||||
_ "github.com/spotdemo4/dbmate-sqlite-modernc/pkg/driver/sqlite" // Modernc sqlite
|
_ "github.com/spotdemo4/dbmate-sqlite-modernc/pkg/driver/sqlite" // Modernc sqlite
|
||||||
)
|
)
|
||||||
|
|
||||||
func Migrate(dsn string, dbFS *embed.FS) error {
|
func Migrate(dsn string, dbFS embed.FS) error {
|
||||||
if dbFS == nil {
|
_, err := dbFS.ReadDir(".")
|
||||||
|
if err == io.EOF {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -22,6 +24,7 @@ func Migrate(dsn string, dbFS *embed.FS) error {
|
|||||||
db := dbmate.New(dburl)
|
db := dbmate.New(dburl)
|
||||||
db.Driver()
|
db.Driver()
|
||||||
db.FS = dbFS
|
db.FS = dbFS
|
||||||
|
db.AutoDumpSchema = false
|
||||||
|
|
||||||
log.Println("Migrations:")
|
log.Println("Migrations:")
|
||||||
migrations, err := db.FindMigrations()
|
migrations, err := db.FindMigrations()
|
||||||
|
@ -2,14 +2,16 @@ package client
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"embed"
|
"embed"
|
||||||
|
"io"
|
||||||
"io/fs"
|
"io/fs"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
|
||||||
"github.com/spotdemo4/trevstack/server/internal/interceptors"
|
"github.com/spotdemo4/trevstack/server/internal/interceptors"
|
||||||
)
|
)
|
||||||
|
|
||||||
func NewClientHandler(key string, clientFS *embed.FS) http.Handler {
|
func NewClientHandler(key string, clientFS embed.FS) http.Handler {
|
||||||
if clientFS == nil {
|
_, err := clientFS.ReadDir(".")
|
||||||
|
if err == io.EOF {
|
||||||
return http.NotFoundHandler()
|
return http.NotFoundHandler()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,20 +0,0 @@
|
|||||||
//go:build !dev
|
|
||||||
|
|
||||||
package main
|
|
||||||
|
|
||||||
import (
|
|
||||||
"embed"
|
|
||||||
"log"
|
|
||||||
)
|
|
||||||
|
|
||||||
//go:embed all:client
|
|
||||||
var cFS embed.FS
|
|
||||||
|
|
||||||
//go:embed db/migrations/*.sql
|
|
||||||
var dFS embed.FS
|
|
||||||
|
|
||||||
func init() {
|
|
||||||
log.Println("initializing for production")
|
|
||||||
clientFS = &cFS
|
|
||||||
dbFS = &dFS
|
|
||||||
}
|
|
Loading…
x
Reference in New Issue
Block a user