blob: 49c2f76d262030ef48d012ab586e03412c72c484 (
plain) (
tree)
|
|
{
description = "A CLI to manage public SSH keys for GitHub.";
inputs = {
flake-utils.url = "github:numtide/flake-utils";
nixpkgs.url = "github:NixOS/nixpkgs";
rust-overlay.url = "github:oxalica/rust-overlay";
naersk.url = "github:nmattia/naersk";
};
outputs =
{ self
, flake-utils
, nixpkgs
, naersk
, rust-overlay
}:
flake-utils.lib.eachDefaultSystem
(system:
let
overlays = [ (import rust-overlay) ];
pkgs = import nixpkgs { inherit system overlays; };
rust-toolchain =
(pkgs.rust-bin.fromRustupToolchainFile ./rust-toolchain.toml).override {
extensions = [ "rust-src" ];
};
naersk-lib = naersk.lib."${system}".override {
rustc = rust-toolchain;
};
in
rec
{
packages.gh-ssh-keys = naersk-lib.buildPackage {
pname = "gh-ssh-keys";
root = ./.;
buildInputs = with pkgs; [
pkg-config
openssl
];
};
defaultPackage = packages.gh-ssh-keys;
devShell = pkgs.mkShell {
nativeBuildInputs = with pkgs; [
rust-toolchain
openssl
pkg-config
cargo-audit
cargo-deny
cargo-cross
rust-analyzer
] ++ pkgs.lib.optionals (pkgs.stdenv.isLinux) (with pkgs; [ cargo-watch ]);
shellHook = ''
cargo --version
'';
};
})
// {
overlay = final: prev: {
gh-ssh-keys = self.defaultPackage.${prev.system};
};
};
}
|