5f8cf0048e
The biggest benefit is that we no longer have to update the registry package. This means that just about any cargo package can be built by nix. No longer does `cargo update` need to be feared because it will update to packages newer then what is available in nixpkgs. Instead of fetching the cargo registry this bundles all the source code into a "vendor/" folder. This also uses the new --frozen and --locked flags which is nice. Currently cargo-vendor only provides binaries for Linux and macOS 64-bit. This can be solved by building it for the other architectures and uploading it somewhere (like the NixOS cache). This also has the downside that it requires a change to everyone's deps hash. And if the old one is used because it was cached it will fail to build as it will attempt to use the old version. For this reason the attribute has been renamed to `cargoSha256`. Authors: * Kevin Cox <kevincox@kevincox.ca> * Jörg Thalheim <Mic92@users.noreply.github.com> * zimbatm <zimbatm@zimbatm.com>
33 lines
838 B
Nix
33 lines
838 B
Nix
{ stdenv, fetchFromGitHub, rustPlatform, makeWrapper, openssl }:
|
|
|
|
with rustPlatform;
|
|
|
|
buildRustPackage rec {
|
|
name = "cfdyndns-${version}";
|
|
version = "0.0.1";
|
|
src = fetchFromGitHub {
|
|
owner = "colemickens";
|
|
repo = "cfdyndns";
|
|
rev = "v${version}";
|
|
sha256 = "1mcdjykrgh0jq6k6y664lai8sbgzk6j7k0r944f43vg63d1jql5b";
|
|
};
|
|
|
|
cargoSha256 = "0k9d6pxsb4gvkqs00g71c1nnz773iccg4vajgn33qdym6m6qsjwy";
|
|
|
|
buildInputs = [ makeWrapper openssl ];
|
|
|
|
installPhase = ''
|
|
mkdir -p $out/bin
|
|
cp -p target/release/cfdyndns $out/bin/
|
|
'';
|
|
|
|
meta = with stdenv.lib; {
|
|
description = "CloudFlare Dynamic DNS Client";
|
|
homepage = https://github.com/colemickens/cfdyndns;
|
|
license = stdenv.lib.licenses.mit;
|
|
maintainers = with maintainers; [ colemickens ];
|
|
platforms = with platforms; linux;
|
|
broken = true;
|
|
};
|
|
}
|