Files
ifconfig.io/flake.nix

128 lines
3.4 KiB
Nix
Raw Normal View History

2020-11-15 21:05:14 -05:00
{
inputs = {
2020-11-17 12:36:21 -05:00
nixpkgs.url = "github:nixos/nixpkgs";
2020-11-15 21:05:14 -05:00
flake-compat = {
url = "github:edolstra/flake-compat";
flake = false;
};
};
2025-09-26 06:56:21 -04:00
outputs =
{ self, nixpkgs, ... }:
2020-11-15 21:05:14 -05:00
let
2025-09-26 06:56:21 -04:00
version = builtins.replaceStrings [ "\n" ] [ "" ] (builtins.readFile ./.version + versionSuffix);
2023-11-26 17:35:43 -05:00
versionSuffix =
if officialRelease then
""
else
"pre${
2025-09-26 06:56:21 -04:00
nixpkgs.lib.substring 0 8 (self.lastModifiedDate or self.lastModified)
}_${self.shortRev or "dirty"}";
2020-11-15 21:05:14 -05:00
officialRelease = false;
2025-09-26 06:56:21 -04:00
systems = [
"x86_64-linux"
"i686-linux"
"aarch64-linux"
"x86_64-darwin"
];
2020-11-15 21:05:14 -05:00
forAllSystems = f: nixpkgs.lib.genAttrs systems (system: f system);
# Memoize nixpkgs for different platforms for efficiency.
2025-09-26 06:56:21 -04:00
nixpkgsFor = forAllSystems (
system:
2020-11-15 21:05:14 -05:00
import nixpkgs {
inherit system;
overlays = [ self.overlay ];
2025-09-26 06:56:21 -04:00
}
);
2023-11-26 17:35:43 -05:00
in
{
2020-11-15 21:05:14 -05:00
overlay = final: prev: {
2025-09-26 06:56:21 -04:00
ifconfigio =
with final;
2020-11-15 21:05:14 -05:00
with pkgs;
(buildGoModule {
name = "ifconfig.io-${version}";
src = self;
2025-09-26 06:56:21 -04:00
vendorHash = "sha256-fc0xM3Dyfi75tuGMzqAn8dnk/zKpyF5r/8mJaWJ2LFw=";
2020-11-15 21:05:14 -05:00
2022-01-05 12:23:33 -05:00
tags = [ "jsoniter" ];
2020-11-15 21:05:14 -05:00
postInstall = ''
mkdir -p $out/usr/lib/ifconfig.io/
cp -r ./templates $out/usr/lib/ifconfig.io
'';
});
2020-11-16 21:42:21 -05:00
2025-09-26 06:56:21 -04:00
ifconfigio-docker =
with final;
2020-11-16 21:42:21 -05:00
with pkgs;
(dockerTools.buildLayeredImage {
name = "ifconfig.io";
tag = version;
created = "now";
2025-09-26 06:56:21 -04:00
contents = [
ifconfigio
busybox
];
2020-11-16 21:42:21 -05:00
config = {
Cmd = "/bin/ifconfig.io";
WorkingDir = "/usr/lib/ifconfig.io";
2025-09-26 06:56:21 -04:00
ExposedPorts = {
"8080" = { };
};
Env = [
"HOSTNAME=ifconfig.io"
"TLS=0"
"TLSCERT="
"TLSKEY="
];
2020-11-16 21:42:21 -05:00
};
});
2020-11-15 21:05:14 -05:00
};
2020-11-16 21:42:21 -05:00
packages = forAllSystems (system: {
inherit (nixpkgsFor.${system}) ifconfigio ifconfigio-docker;
});
2025-09-26 06:56:21 -04:00
defaultPackage = forAllSystems (system: self.packages.${system}.ifconfigio);
2020-11-15 21:05:14 -05:00
2025-09-26 06:56:21 -04:00
nixosModules.ifconfigio =
{ pkgs, lib, ... }:
{
nixpkgs.overlays = [ self.overlay ];
users.users.ifconfigio = {
description = "ifconfig.io daemon user";
group = "ifconfigio";
isSystemUser = true;
home = "/opt/ifconfig";
2023-11-26 17:35:43 -05:00
};
2025-09-26 06:56:21 -04:00
users.groups.ifconfigio = { };
systemd.services.ifconfigio = {
description = "ifconfig.io web service";
enable = true;
wantedBy = [ "multi-user.target" ];
environment = {
GIN_MODE = lib.mkDefault "release";
TLS = lib.mkDefault "0";
};
script = ''
# For some reason the systemd WorkingDir is not doing what we need
# so we `cd` to it explicitly.
cd "${pkgs.ifconfigio}/usr/lib/ifconfig.io"
exec "${pkgs.ifconfigio}/bin/ifconfig.io"
'';
serviceConfig = {
User = "ifconfigio";
WorkingDir = "${pkgs.ifconfigio}/usr/lib/ifconfig.io";
LimitNOFILE = 200000;
};
2023-11-26 17:35:43 -05:00
};
};
2020-11-15 21:05:14 -05:00
};
}