Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions .envrc
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
use nix
2 changes: 2 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -47,3 +47,5 @@ next-env.d.ts

# virtual env for gitlint
/env-gitlint
.direnv
result
21 changes: 21 additions & 0 deletions default.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
{
sources ? import ./npins,
pkgs ? import sources.nixpkgs { },
}:

let
inherit (pkgs.lib.filesets) toSource unions;
in

{
devShell = pkgs.mkShell {
name = "hackdays.dev";

packages = with pkgs; [
nodejs
yarn
];
};

package = pkgs.callPackage ./package.nix { };
}
80 changes: 80 additions & 0 deletions npins/default.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,80 @@
# Generated by npins. Do not modify; will be overwritten regularly
let
data = builtins.fromJSON (builtins.readFile ./sources.json);
version = data.version;

mkSource =
spec:
assert spec ? type;
let
path =
if spec.type == "Git" then
mkGitSource spec
else if spec.type == "GitRelease" then
mkGitSource spec
else if spec.type == "PyPi" then
mkPyPiSource spec
else if spec.type == "Channel" then
mkChannelSource spec
else
builtins.throw "Unknown source type ${spec.type}";
in
spec // { outPath = path; };

mkGitSource =
{
repository,
revision,
url ? null,
hash,
branch ? null,
...
}:
assert repository ? type;
# At the moment, either it is a plain git repository (which has an url), or it is a GitHub/GitLab repository
# In the latter case, there we will always be an url to the tarball
if url != null then
(builtins.fetchTarball {
inherit url;
sha256 = hash; # FIXME: check nix version & use SRI hashes
})
else
assert repository.type == "Git";
let
urlToName =
url: rev:
let
matched = builtins.match "^.*/([^/]*)(\\.git)?$" repository.url;

short = builtins.substring 0 7 rev;

appendShort = if (builtins.match "[a-f0-9]*" rev) != null then "-${short}" else "";
in
"${if matched == null then "source" else builtins.head matched}${appendShort}";
name = urlToName repository.url revision;
in
builtins.fetchGit {
url = repository.url;
rev = revision;
inherit name;
# hash = hash;
};

mkPyPiSource =
{ url, hash, ... }:
builtins.fetchurl {
inherit url;
sha256 = hash;
};

mkChannelSource =
{ url, hash, ... }:
builtins.fetchTarball {
inherit url;
sha256 = hash;
};
in
if version == 3 then
builtins.mapAttrs (_: mkSource) data.pins
else
throw "Unsupported format version ${toString version} in sources.json. Try running `npins upgrade`"
11 changes: 11 additions & 0 deletions npins/sources.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
{
"pins": {
"nixpkgs": {
"type": "Channel",
"name": "nixpkgs-unstable",
"url": "https://releases.nixos.org/nixpkgs/nixpkgs-25.05pre776565.63158b9cbb6e/nixexprs.tar.xz",
"hash": "0l91nfx2j2j279z4zsp2fm1rrl38lxiw2y94zkn82860xynfl9z1"
}
},
"version": 3
}
71 changes: 71 additions & 0 deletions package.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,71 @@
{
stdenv,
lib,
fetchYarnDeps,
nodejs,
yarn,
fixup-yarn-lock,
}:

let
inherit (lib.fileset) toSource unions;
in

stdenv.mkDerivation {
pname = "hackdays";
version = "0.1";

offlineCache = fetchYarnDeps {
yarnLock = ./yarn.lock;
hash = "sha256-10b8l45zXYZRiNwvwuG8q/8IrupV3AEJxliwCpgkMeE=";
};

src = toSource {
root = ./.;

fileset = unions [
./public
./src
./eslint.config.mjs
./favicon.ico
./next.config.ts
./package.json
./postcss.config.js
./tailwind.config.ts
./tsconfig.json
./yarn.lock
];
};

nativeBuildInputs = [
fixup-yarn-lock
nodejs
yarn
];

configurePhase = ''
runHook preConfigure

export HOME=$(pwd)

fixup-yarn-lock yarn.lock
yarn config --offline set yarn-offline-mirror $offlineCache
yarn install --offline --frozen-lockfile --no-progress --non-interactive

patchShebangs node_modules

runHook postConfigure
'';

buildPhase = ''
runHook preBuild

yarn build

runHook postBuild
'';

installPhase = ''
mv out $out
'';
}
1 change: 1 addition & 0 deletions shell.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
(import ./. { }).devShell