{ nix-thunk }: self: super: rec { botan2 = (super.botan2.overrideAttrs (old: { # Get rid of some patches that nixpkgs was applying to botan2 and which didn't apply to the branch. patches = []; # The --with-openssl flag didn't work for some reason, might need further figuring out. configurePhase = builtins.replaceStrings [ "--with-openssl" ] [ " " ] old.configurePhase; # Here, we use nix-thunk to get the source of the correct branch of the botan repo via a thunk. # Nix thunks are essentially references to git repositories that can be unpacked to their # source in-place when working on the project, or packed up into a few small files. # After installing the nix-thunk command from https://github.com/obsidiansystems/nix-thunk # you can run: # nix-thunk unpack dep/botan # from the top level of this repo to clone a copy of the botan git repo at the appropriate # commit, and work on it from there. Similarly, # nix-thunk pack dep/botan # will pack it back up again, provided that the changes have been pushed somewhere. # Note: there's a bug in the current version of Obelisk which occasionally gives it some trouble # if certain repos are unpacked. If you have any trouble running an ob command # (ob run, ob repl, etc.) with a thunk unpacked, try adding the flag --no-interpret dep # and hopefully that will sort it out. src = nix-thunk.thunkSource ./dep/botan; })).override (old: { # Also, turn on debugging. extraConfigureFlags = "--debug-mode"; }); # For whatever reason, it seems callCabal2nix below wants to use the botan package rather than botan2. # We could override the pkgconfigDepends of the resulting package, but this is easier. botan = self.botan2; # Next, we'll try to obtain challenge-bypass-ristretto-ffi, for which we have a nix flake. # To use the flake, we'll obtain Eelco Dolstra's flake-compat. flake-compat = import (fetchTarball { url = "https://github.com/edolstra/flake-compat/archive/35bb57c0c8d8b62bbfd284272c928ceb64ddbde9.tar.gz"; sha256 = "sha256:1prd9b1xx8c0sfwnyzkspplh30m613j42l1k789s521f4kv4c2z2"; }); # This has the top level of the flake... challenge-bypass-ristretto-ffi-flake = (self.flake-compat { src = nix-thunk.thunkSource ./dep/python-challenge-bypass-ristretto ; }).defaultNix; # ... from which we can extract whatever packages we need. challenge-bypass-ristretto-ffi = challenge-bypass-ristretto-ffi-flake.packages."${builtins.currentSystem}".libchallenge_bypass_ristretto_ffi; challenge-bypass-ristretto-ffi-android = challenge-bypass-ristretto-ffi-flake.legacyPackages."${builtins.currentSystem}".pkgsCross.aarch64-android.libchallenge_bypass_ristretto_ffi; # We can branch on the target platform to choose between the different architecture libraries from the flake. Modifying the flake might be easier. libchallenge_bypass_ristretto_ffi = if self.stdenv.targetPlatform.isAndroid then challenge-bypass-ristretto-ffi-flake.legacyPackages.${builtins.currentSystem}.pkgsCross.aarch64-android.libchallenge_bypass_ristretto_ffi else challenge-bypass-ristretto-ffi-flake.packages.${builtins.currentSystem}.libchallenge_bypass_ristretto_ffi; }