• Vorpal@programming.dev
    link
    fedilink
    arrow-up
    7
    ·
    10 months ago

    Due to the recent xz trouble I presume? Good idea, I was thinking about this on an ecosystem wise scale (e.g. all of crates.io or all of a Linux distro) which is a much harder problem to solve.

    Not sure if the tag logic is needed though. I thought cargo embedded the commit ID in the published package?

    Also I’m amazed that the name cargo-goggles was available.

    • Paolo BarboliniOP
      link
      fedilink
      arrow-up
      4
      ·
      10 months ago

      Correct. To be clear, the xz vulnerability shows that this is just a very small step, but it will at least make git repo audits more useful since you will then know that the crates.io release matches.

      Unfortunately, the git commit isn’t always available, either because of releases made with old versions of cargo, or because maintainers deliberately publish with cargo publish --allow-dirty or cargo hack --no-dev-deps

      • Vorpal@programming.dev
        link
        fedilink
        arrow-up
        3
        ·
        10 months ago

        Yes, obviously there are more ways to hide malicious code.

        As for the git commit ID, I didn’t see you using it even when it was available though? But perhaps that could be a weakness, if the commit ID used does not match the tag in the repo, that would be a red flag too. That could be worth checking.

        • Paolo BarboliniOP
          link
          fedilink
          arrow-up
          2
          ·
          10 months ago

          I’m not completely sure what to do here because many crates seem to get published from the release PR branch, not the main one, so the commit id is usually unreliable anyway.

          On one side I want something strict that can’t be easily bypassed, on the other if everything’s a red flag you’ll just ignore it

          • Vorpal@programming.dev
            link
            fedilink
            arrow-up
            2
            ·
            edit-2
            10 months ago

            Hm, that is a fair point. Perhaps it would make sense to produce a table of checks: indicate which checks each dependency fails/passes, and then colour code them with severity.

            Some experimentation on real world code is probably needed. I plan to try this tool on my own projects soon (after I manually verified that your crate match your git code (hah! Bootstrap problem), I already reviewed your code on github and it seemed to do what it claims).