diff --git a/go.mod b/go.mod index 9677e79..549cf0c 100644 --- a/go.mod +++ b/go.mod @@ -30,6 +30,7 @@ require ( github.com/Azure/go-autorest/autorest/date v0.3.0 // indirect github.com/Azure/go-autorest/logger v0.2.1 // indirect github.com/Azure/go-autorest/tracing v0.6.0 // indirect + github.com/Microsoft/go-winio v0.5.2 // indirect github.com/PaesslerAG/gval v1.0.0 // indirect github.com/PaesslerAG/jsonpath v0.1.1 // indirect github.com/ThalesIgnite/crypto11 v1.2.5 // indirect @@ -154,6 +155,7 @@ require ( github.com/sigstore/fulcio v0.1.2-0.20220114150912-86a2036f9bc7 // indirect github.com/sirupsen/logrus v1.8.1 // indirect github.com/skratchdot/open-golang v0.0.0-20200116055534-eef842397966 // indirect + github.com/slsa-framework/slsa-github-generator v1.0.1-0.20220620171932-8897a8c9a0fc // indirect github.com/soheilhy/cmux v0.1.5 // indirect github.com/spf13/afero v1.8.2 // indirect github.com/spf13/cast v1.5.0 // indirect diff --git a/go.sum b/go.sum index 7778827..f114675 100644 --- a/go.sum +++ b/go.sum @@ -184,6 +184,8 @@ github.com/Microsoft/go-winio v0.4.17-0.20210211115548-6eac466e5fa3/go.mod h1:JP github.com/Microsoft/go-winio v0.4.17-0.20210324224401-5516f17a5958/go.mod h1:JPGBdM1cNvN/6ISo+n8V5iA4v8pBzdOpzfwIujj1a84= github.com/Microsoft/go-winio v0.4.17/go.mod h1:JPGBdM1cNvN/6ISo+n8V5iA4v8pBzdOpzfwIujj1a84= github.com/Microsoft/go-winio v0.5.1/go.mod h1:JPGBdM1cNvN/6ISo+n8V5iA4v8pBzdOpzfwIujj1a84= +github.com/Microsoft/go-winio v0.5.2 h1:a9IhgEQBCUEk6QCdml9CiJGhAws+YwffDHEMp1VMrpA= +github.com/Microsoft/go-winio v0.5.2/go.mod h1:WpS1mjBmmwHBEWmogvA2mj8546UReBk4v8QkMxJ6pZY= github.com/Microsoft/hcsshim v0.8.6/go.mod h1:Op3hHsoHPAvb6lceZHDtd9OkTew38wNoXnJs8iY7rUg= github.com/Microsoft/hcsshim v0.8.7-0.20190325164909-8abdbb8205e4/go.mod h1:Op3hHsoHPAvb6lceZHDtd9OkTew38wNoXnJs8iY7rUg= github.com/Microsoft/hcsshim v0.8.7/go.mod h1:OHd7sQqRFrYd3RmSgbgji+ctCwkbq2wbEYNSzOYtcBQ= @@ -517,6 +519,7 @@ github.com/coreos/go-systemd/v22 v22.3.2 h1:D9/bQk5vlXQFZ6Kwuu6zaiXJ9oTPe68++AzA github.com/coreos/go-systemd/v22 v22.3.2/go.mod h1:Y58oyj3AT4RCenI/lSvhwexgC+NSVTIJ3seZv2GcEnc= github.com/coreos/pkg v0.0.0-20160727233714-3ac0863d7acf/go.mod h1:E3G3o1h8I7cfcXa63jLwjI0eiQQMgzzUDFVpN/nH/eA= github.com/coreos/pkg v0.0.0-20180928190104-399ea9e2e55f/go.mod h1:E3G3o1h8I7cfcXa63jLwjI0eiQQMgzzUDFVpN/nH/eA= +github.com/cpuguy83/go-md2man v1.0.10 h1:BSKMNlYxDvnunlTymqtgONjNnaRV1sTpcovwwjF22jk= github.com/cpuguy83/go-md2man v1.0.10/go.mod h1:SmD6nW6nTyfqj6ABTjUi3V3JVMnlJmwcJI5acqYI6dE= github.com/cpuguy83/go-md2man/v2 v2.0.0-20190314233015-f79a8a8ca69d/go.mod h1:maD7wRr/U5Z6m/iR4s+kqSMx2CaBsrgA7czyZG/E6dU= github.com/cpuguy83/go-md2man/v2 v2.0.0/go.mod h1:maD7wRr/U5Z6m/iR4s+kqSMx2CaBsrgA7czyZG/E6dU= @@ -944,6 +947,8 @@ github.com/googleapis/gax-go/v2 v2.1.0/go.mod h1:Q3nei7sK6ybPYH7twZdmQpAd1MKb7pf github.com/googleapis/gax-go/v2 v2.1.1/go.mod h1:hddJymUZASv3XPyGkUpKj8pPO47Rmb0eJc8R6ouapiM= github.com/googleapis/gax-go/v2 v2.2.0/go.mod h1:as02EH8zWkzwUoLbBaFeQ+arQaj/OthfcblKl4IGNaM= github.com/googleapis/gax-go/v2 v2.3.0/go.mod h1:b8LNqSzNabLiUpXKkY7HAR5jr6bIT99EXz9pXxye9YM= +github.com/googleapis/gax-go/v2 v2.4.0 h1:dS9eYAjhrE2RjmzYw2XAPvcXfmcQLtFEQWn0CR82awk= +github.com/googleapis/gax-go/v2 v2.4.0/go.mod h1:XOTVJ59hdnfJLIP/dh8n5CGryZR2LxK9wbMD5+iXC6c= github.com/googleapis/gnostic v0.4.1/go.mod h1:LRhVm6pbyptWbWbuZ38d1eyptfvIytN3ir6b65WBswg= github.com/googleapis/gnostic v0.5.1/go.mod h1:6U4PtQXGIEt/Z3h5MAT7FNofLnw9vXk2cUuW7uA/OeU= github.com/googleapis/gnostic v0.5.5 h1:9fHAtK0uDfpveeqqo1hkEZJcFvYXAiCN3UutL8F9xHw= @@ -1394,6 +1399,7 @@ github.com/onsi/gomega v1.7.0/go.mod h1:ex+gbHU/CVuBBDIJjb2X0qEXbFg53c61hWP/1Cpa github.com/onsi/gomega v1.7.1/go.mod h1:XdKZgCCFLUoM/7CFJVPcG8C1xQ1AJ0vpAezJrB7JYyY= github.com/onsi/gomega v1.10.1/go.mod h1:iN09h71vgCQne3DLsj+A5owkum+a2tYe+TOCB1ybHNo= github.com/onsi/gomega v1.10.3/go.mod h1:V9xEwhxec5O8UDM77eCW8vLymOMltsqPVYWrpDsH8xc= +github.com/onsi/gomega v1.11.0/go.mod h1:azGKhqFUon9Vuj0YmTfLSmx0FUwqXYSTl5re8lQLTUg= github.com/onsi/gomega v1.16.0/go.mod h1:HnhC7FXeEQY45zxNK3PPoIUhzk/80Xly9PcubAlGdZY= github.com/onsi/gomega v1.17.0/go.mod h1:HnhC7FXeEQY45zxNK3PPoIUhzk/80Xly9PcubAlGdZY= github.com/onsi/gomega v1.18.1 h1:M1GfJqGRrBrrGGsbxzV5dqM2U2ApXefZCQpkukxYRLE= @@ -1559,11 +1565,13 @@ github.com/rogpeppe/go-internal v1.2.2/go.mod h1:M8bDsm7K2OlrFYOpmOWEs/qY81heoFR github.com/rogpeppe/go-internal v1.3.0/go.mod h1:M8bDsm7K2OlrFYOpmOWEs/qY81heoFRclV5y23lUDJ4= github.com/rogpeppe/go-internal v1.6.1/go.mod h1:xXDCJY+GAPziupqXw64V24skbSoqbTEfhy4qGm1nDQc= github.com/rogpeppe/go-internal v1.6.2/go.mod h1:xXDCJY+GAPziupqXw64V24skbSoqbTEfhy4qGm1nDQc= -github.com/rogpeppe/go-internal v1.8.0 h1:FCbCCtXNOY3UtUuHUYaghJg4y7Fd14rXifAYUAtL9R8= github.com/rogpeppe/go-internal v1.8.0/go.mod h1:WmiCO8CzOY8rg0OYDC4/i/2WRWAB6poM+XZ2dLUbcbE= +github.com/rogpeppe/go-internal v1.8.1 h1:geMPLpDpQOgVyCg5z5GoRwLHepNdb71NXb67XFkP+Eg= +github.com/rogpeppe/go-internal v1.8.1/go.mod h1:JeRgkft04UBgHMgCIwADu4Pn6Mtm5d4nPKWu0nJ5d+o= github.com/rs/cors v1.7.0/go.mod h1:gFx+x8UowdsKA9AchylcLynDq+nNFfI8FkUZdN/jGCU= github.com/rs/cors v1.8.0/go.mod h1:EBwu+T5AvHOcXwvZIkQFjUN6s8Czyqw12GL/Y0tUyRM= github.com/russross/blackfriday v1.5.2/go.mod h1:JO/DiYxRf+HjHt06OyowR9PTA263kcR/rfWxYHBV53g= +github.com/russross/blackfriday v1.6.0 h1:KqfZb0pUVN2lYqZUYRddxF4OR8ZMURnJIG5Y3VRLtww= github.com/russross/blackfriday v1.6.0/go.mod h1:ti0ldHuxg49ri4ksnFxlkCfN+hvslNlmVHqNRXXJNAY= github.com/russross/blackfriday/v2 v2.0.1/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQDYRxCVz55jmeOWTM= github.com/russross/blackfriday/v2 v2.1.0 h1:JIOH55/0cWyOuilr9/qlrm0BSXldqnqwMsf35Ld67mk= @@ -1578,6 +1586,7 @@ github.com/safchain/ethtool v0.0.0-20190326074333-42ed695e3de8/go.mod h1:Z0q5wiB github.com/sagikazarmark/crypt v0.1.0/go.mod h1:B/mN0msZuINBtQ1zZLEQcegFJJf9vnYIR88KRMEuODE= github.com/sagikazarmark/crypt v0.3.0/go.mod h1:uD/D+6UF4SrIR1uGEv7bBNkNqLGqUr43MRiaGWX1Nig= github.com/sagikazarmark/crypt v0.4.0/go.mod h1:ALv2SRj7GxYV4HO9elxH9nS6M9gW+xDNxqmyJ6RfDFM= +github.com/sagikazarmark/crypt v0.6.0/go.mod h1:U8+INwJo3nBv1m6A/8OBXAq7Jnpspk5AxSgDyEQcea8= github.com/samuel/go-zookeeper v0.0.0-20190923202752-2cc03de413da/go.mod h1:gi+0XIa01GRL2eRQVjQkKGqKF3SF9vZR/HnPullcV2E= github.com/sanposhiho/wastedassign/v2 v2.0.6/go.mod h1:KyZ0MWTwxxBmfwn33zh3k1dmsbF2ud9pAAGfoLfjhtI= github.com/sassoftware/go-rpmutils v0.0.0-20190420191620-a8f1baeba37b/go.mod h1:am+Fp8Bt506lA3Rk3QCmSqmYmLMnPDhdDUcosQCAx+I= @@ -1628,6 +1637,10 @@ github.com/sirupsen/logrus v1.8.1/go.mod h1:yWOB1SBYBC5VeMP7gHvWumXLIWorT60ONWic github.com/sivchari/tenv v1.4.7/go.mod h1:5nF+bITvkebQVanjU6IuMbvIot/7ReNsUV7I5NbprB0= github.com/skratchdot/open-golang v0.0.0-20200116055534-eef842397966 h1:JIAuq3EEf9cgbU6AtGPK4CTG3Zf6CKMNqf0MHTggAUA= github.com/skratchdot/open-golang v0.0.0-20200116055534-eef842397966/go.mod h1:sUM3LWHvSMaG192sy56D9F7CNvL7jUJVXoqM1QKLnog= +github.com/slsa-framework/slsa-github-generator v1.0.1-0.20220620171932-8897a8c9a0fc h1:ma59DoPLKpxYKeh9lSWKtl+lpMH7MiBD0KAi5hnW9kQ= +github.com/slsa-framework/slsa-github-generator v1.0.1-0.20220620171932-8897a8c9a0fc/go.mod h1:vw7xGJ7M0g+5Nuw132CA4PI3mPWmvW1VzAGTruAReTY= +github.com/slsa-framework/slsa-github-generator v1.1.1-0.20220617181308-cb8f03b209bb h1:+MJddNTrgsFfjC4mWPlHHH1HMbAoQB/BVEsWmmSc/9Q= +github.com/slsa-framework/slsa-github-generator v1.1.1-0.20220617181308-cb8f03b209bb/go.mod h1:vw7xGJ7M0g+5Nuw132CA4PI3mPWmvW1VzAGTruAReTY= github.com/smallstep/assert v0.0.0-20200723003110-82e2b9b3b262/go.mod h1:MyOHs9Po2fbM1LHej6sBUT8ozbxmMOFG+E+rx/GSGuc= github.com/smartystreets/assertions v0.0.0-20180927180507-b2de0cb4f26d/go.mod h1:OnSkiWE9lh6wB0YB77sQom3nweQdgAjqCqsofrRNTgc= github.com/smartystreets/assertions v1.0.0/go.mod h1:kHHU4qYBaI3q23Pp3VPrmWhuIUrLW/7eUrw0BU5VaoM= @@ -1832,6 +1845,7 @@ go.etcd.io/bbolt v1.3.6 h1:/ecaJf0sk1l4l6V4awd65v2C3ILy7MSj+s/x1ADCIMU= go.etcd.io/bbolt v1.3.6/go.mod h1:qXsaaIqmgQH0T+OPdb99Bf+PKfBBQVAdyD6TY9G8XM4= go.etcd.io/etcd v0.0.0-20191023171146-3cf2f69b5738/go.mod h1:dnLIgRNXwCJa5e+c6mIZCrds/GIG4ncV9HhK5PX7jPg= go.etcd.io/etcd v0.0.0-20200513171258-e048e166ab9c/go.mod h1:xCI7ZzBfRuGgBXyXO6yfWfDmlWd35khcWpUa4L0xI/k= +go.etcd.io/etcd v0.5.0-alpha.5.0.20200910180754-dd1b699fc489 h1:1JFLBqwIgdyHN1ZtgjTBwO+blA6gVOmZurpiMEsETKo= go.etcd.io/etcd v0.5.0-alpha.5.0.20200910180754-dd1b699fc489/go.mod h1:yVHk9ub3CSBatqGNg7GRmsnfLWtoW60w4eDYfh7vHDg= go.etcd.io/etcd/api/v3 v3.5.0-alpha.0/go.mod h1:mPcW6aZJukV6Aa81LSKpBjQXTWlXB5r74ymPoSWa3Sw= go.etcd.io/etcd/api/v3 v3.5.0/go.mod h1:cbVKeC6lCfl7j/8jBhAK6aIYO9XOjdptoxU/nLQcPvs= @@ -1989,6 +2003,8 @@ golang.org/x/crypto v0.0.0-20211215153901-e495a2d5b3d3/go.mod h1:IxCIyHEi3zRg3s0 golang.org/x/crypto v0.0.0-20220131195533-30dcbda58838/go.mod h1:IxCIyHEi3zRg3s0A5j5BB6A9Jmi73HwBIUl50j+osU4= golang.org/x/crypto v0.0.0-20220411220226-7b82a4e95df4 h1:kUhD7nTDoI3fVd9G4ORWrbV5NY0liEs/Jg2pv5f+bBA= golang.org/x/crypto v0.0.0-20220411220226-7b82a4e95df4/go.mod h1:IxCIyHEi3zRg3s0A5j5BB6A9Jmi73HwBIUl50j+osU4= +golang.org/x/crypto v0.0.0-20220525230936-793ad666bf5e h1:T8NU3HyQ8ClP4SEE+KbFlg6n0NhuTsN4MyznaarGsZM= +golang.org/x/crypto v0.0.0-20220525230936-793ad666bf5e/go.mod h1:IxCIyHEi3zRg3s0A5j5BB6A9Jmi73HwBIUl50j+osU4= golang.org/x/exp v0.0.0-20190121172915-509febef88a4/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= golang.org/x/exp v0.0.0-20190306152737-a1d7652674e8/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= golang.org/x/exp v0.0.0-20190510132918-efd6b22b2522/go.mod h1:ZjyILWgesfNpC6sMxTJOJm9Kp84zZh5NQWvqDGG3Qr8= @@ -2087,6 +2103,7 @@ golang.org/x/net v0.0.0-20201224014010-6772e930b67b/go.mod h1:m0MpNAwzfU5UDzcl9v golang.org/x/net v0.0.0-20210119194325-5f4716e94777/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= golang.org/x/net v0.0.0-20210226172049-e18ecbb05110/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= golang.org/x/net v0.0.0-20210316092652-d523dce5a7f4/go.mod h1:RBQZq4jEuRlivfhVLdyRGr576XBO4/greRjx4P4O3yc= +golang.org/x/net v0.0.0-20210331212208-0fccb6fa2b5c/go.mod h1:p54w0d4576C0XHj96bSt6lcn1PtDYWL6XObtHCRCNQM= golang.org/x/net v0.0.0-20210405180319-a5a99cb37ef4/go.mod h1:p54w0d4576C0XHj96bSt6lcn1PtDYWL6XObtHCRCNQM= golang.org/x/net v0.0.0-20210410081132-afb366fc7cd1/go.mod h1:9tjilg8BloeKEkVJvy7fQ90B1CfIiPueXVOjqfkSzI8= golang.org/x/net v0.0.0-20210421230115-4e50805a0758/go.mod h1:72T/g9IO56b78aLF+1Kcs5dz7/ng1VjMUvfKvpfy+jM= @@ -2299,6 +2316,8 @@ golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9sn golang.org/x/term v0.0.0-20210615171337-6886f2dfbf5b/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8= golang.org/x/term v0.0.0-20210927222741-03fcf44c2211 h1:JGgROgKl9N8DuW20oFS5gxc+lE67/N3FcwmBPMe7ArY= golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8= +golang.org/x/term v0.0.0-20220526004731-065cf7ba2467 h1:CBpWXWQpIRjzmkkA+M7q9Fqnwd2mZr3AFqexg8YTfoM= +golang.org/x/term v0.0.0-20220526004731-065cf7ba2467/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8= golang.org/x/text v0.0.0-20170915032832-14c0d48ead0c/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= golang.org/x/text v0.3.1-0.20180807135948-17ff2d5776d2/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= @@ -2498,6 +2517,9 @@ google.golang.org/api v0.71.0/go.mod h1:4PyU6e6JogV1f9eA4voyrTY2batOLdgZ5qZ5HOCc google.golang.org/api v0.74.0/go.mod h1:ZpfMZOVRMywNyvJFeqL9HRWBgAuRfSjJFpe9QtRRyDs= google.golang.org/api v0.75.0/go.mod h1:pU9QmyHLnzlpar1Mjt4IbapUCy8J+6HD6GeELN69ljA= google.golang.org/api v0.77.0/go.mod h1:pU9QmyHLnzlpar1Mjt4IbapUCy8J+6HD6GeELN69ljA= +google.golang.org/api v0.78.0/go.mod h1:1Sg78yoMLOhlQTeF+ARBoytAcH1NNyyl390YMy6rKmw= +google.golang.org/api v0.81.0 h1:o8WF5AvfidafWbFjsRyupxyEQJNUWxLZJCK5NXrxZZ8= +google.golang.org/api v0.81.0/go.mod h1:FA6Mb/bZxj706H2j+j2d6mHEEaHBmbbWnkfvmorOCko= google.golang.org/appengine v1.1.0/go.mod h1:EbEs0AVv82hx2wNQdGPgUI5lhzA/G0D9YwlJXL52JkM= google.golang.org/appengine v1.2.0/go.mod h1:xpcJRLb0r/rnEns0DIKYYv+WjYCduHsrkT7/EB5XEv4= google.golang.org/appengine v1.3.0/go.mod h1:xpcJRLb0r/rnEns0DIKYYv+WjYCduHsrkT7/EB5XEv4= @@ -2688,6 +2710,7 @@ gopkg.in/check.v1 v1.0.0-20141024133853-64131543e789/go.mod h1:Co6ibVJAznAaIkqp8 gopkg.in/check.v1 v1.0.0-20180628173108-788fd7840127/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= gopkg.in/check.v1 v1.0.0-20200227125254-8fa46927fb4f/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= +gopkg.in/check.v1 v1.0.0-20200902074654-038fdea0a05b/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c h1:Hei/4ADfdWqJk1ZMxUNpqntNwaWcugrBjAiHlqqRiVk= gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c/go.mod h1:JHkPIbrfpd72SG/EVd6muEfDQjcINNoR0C8j2r3qZ4Q= gopkg.in/cheggaaa/pb.v1 v1.0.25/go.mod h1:V/YB90LKu/1FcN3WVnfiiE5oMCibMjukxqG/qStrOgw= @@ -2812,6 +2835,7 @@ sigs.k8s.io/apiserver-network-proxy/konnectivity-client v0.0.15/go.mod h1:LEScyz sigs.k8s.io/json v0.0.0-20211020170558-c049b76a60c6/go.mod h1:p4QtZmO4uMYipTQNzagwnNoseA6OxSUutVw05NhYDRs= sigs.k8s.io/json v0.0.0-20211208200746-9f7c6b3444d2 h1:kDi4JBNAsJWfz1aEXhO8Jg87JJaPNLh5tIzYHgStQ9Y= sigs.k8s.io/json v0.0.0-20211208200746-9f7c6b3444d2/go.mod h1:B+TnT182UBxE84DiCz4CVE26eOSDAeYCpfDnC2kdKMY= +sigs.k8s.io/release-utils v0.4.1-0.20220207182343-6dadf2228617/go.mod h1:t9pL38kZkTBVDcjL1y7ajrkNQFLiArVAjOVO0sxzFF0= sigs.k8s.io/release-utils v0.6.0 h1:wJDuzWJqPH4a5FAxAXE2aBvbB6UMIW7iYMhsKnIMQkA= sigs.k8s.io/release-utils v0.6.0/go.mod h1:kR1/DuYCJ4covppUasYNcA11OixC9O37B/E0ejRfb+c= sigs.k8s.io/structured-merge-diff/v4 v4.0.2/go.mod h1:bJZC9H9iH24zzfZ/41RGcq60oK1F7G282QMXDPYydCw= diff --git a/main_test.go b/main_test.go index c88a33a..35b9c9a 100644 --- a/main_test.go +++ b/main_test.go @@ -323,7 +323,7 @@ func Test_runVerify(t *testing.T) { name: "malicious: invalid signature expired certificate", artifact: "binary-linux-amd64-expired-cert", source: "github.com/slsa-framework/example-package", - err: pkg.ErrorNoValidRekorEntries, + err: pkg.ErrorRekorSearch, noversion: true, }, } diff --git a/pkg/provenance.go b/pkg/provenance.go index 1afe079..166ce0a 100644 --- a/pkg/provenance.go +++ b/pkg/provenance.go @@ -19,6 +19,8 @@ import ( cjson "github.com/docker/go/canonical/json" "github.com/go-openapi/runtime" + "github.com/go-openapi/strfmt" + "github.com/go-openapi/swag" "github.com/google/trillian/merkle/logverifier" "github.com/google/trillian/merkle/rfc6962" intoto "github.com/in-toto/in-toto-golang/in_toto" @@ -38,6 +40,7 @@ import ( intotod "github.com/sigstore/rekor/pkg/types/intoto/v0.0.1" "github.com/sigstore/rekor/pkg/util" "github.com/sigstore/sigstore/pkg/cryptoutils" + "github.com/slsa-framework/slsa-github-generator/signing/envelope" ) const ( @@ -77,6 +80,18 @@ func EnvelopeFromBytes(payload []byte) (env *dsselib.Envelope, err error) { return } +func intotoEntry(certPem []byte, provenance []byte) (*intotod.V001Entry, error) { + cert := strfmt.Base64(certPem) + return &intotod.V001Entry{ + IntotoObj: models.IntotoV001Schema{ + Content: &models.IntotoV001SchemaContent{ + Envelope: string(provenance), + }, + PublicKey: &cert, + }, + }, nil +} + // Get SHA256 Subject Digest from the provenance statement. func getSha256Digest(env *dsselib.Envelope) (string, error) { pyld, err := base64.StdEncoding.DecodeString(env.Payload) @@ -115,6 +130,64 @@ func GetRekorEntries(rClient *client.Rekor, artifactHash string) ([]string, erro return resp.GetPayload(), nil } +// GetRekorEntriesWithCert finds all entry UUIDs with the full intoto attestation. +// The attestation generated by the slsa-github-generator libraries contain a signing certificate. +func GetRekorEntriesWithCert(rClient *client.Rekor, artifactHash string, provenance []byte) (*dsselib.Envelope, *x509.Certificate, error) { + // Use intoto attestation to find rekor entry UUIDs. + params := entries.NewSearchLogQueryParams() + searchLogQuery := models.SearchLogQuery{} + certPem, err := envelope.GetCertFromEnvelope([]byte(provenance)) + if err != nil { + return nil, nil, fmt.Errorf("error getting certificate from provenance: %w", err) + } + + e, err := intotoEntry(certPem, provenance) + if err != nil { + return nil, nil, fmt.Errorf("error creating intoto entry: %w", err) + } + entry := models.Intoto{ + APIVersion: swag.String(e.APIVersion()), + Spec: e.IntotoObj, + } + entries := []models.ProposedEntry{&entry} + searchLogQuery.SetEntries(entries) + + params.SetEntry(&searchLogQuery) + resp, err := rClient.Entries.SearchLogQuery(params) + if err != nil { + return nil, nil, fmt.Errorf("%w: %s", ErrorRekorSearch, err.Error()) + } + + if len(resp.GetPayload()) != 1 { + return nil, nil, fmt.Errorf("%w: %s", ErrorRekorSearch, "no matching rekor entries") + } + + logEntry := resp.Payload[0] + for uuid, e := range logEntry { + if _, err := verifyTlogEntry(context.Background(), rClient, uuid, e); err != nil { + return nil, nil, fmt.Errorf("error verifying tlog entry: %w", err) + } + url := fmt.Sprintf("%v/%v/%v", defaultRekorAddr, "api/v1/log/entries", uuid) + fmt.Fprintf(os.Stderr, "Verified signature against tlog entry index %d at URL: %s\n", *e.LogIndex, url) + } + + env, err := EnvelopeFromBytes(provenance) + if err != nil { + return nil, nil, err + } + + certs, err := cryptoutils.UnmarshalCertificatesFromPEM(certPem) + if err != nil { + return nil, nil, err + } + if len(certs) != 1 { + return nil, nil, fmt.Errorf("error unmarshaling certificate from pem") + + } + + return env, certs[0], nil +} + func verifyRootHash(ctx context.Context, rekorClient *client.Rekor, proof *models.InclusionProof, pub *ecdsa.PublicKey) error { infoParams := tlog.NewGetLogInfoParamsWithContext(ctx) result, err := rekorClient.Tlog.GetLogInfo(infoParams) @@ -174,7 +247,7 @@ func verifyRootHash(ctx context.Context, rekorClient *client.Rekor, proof *model return nil } -func verifyTlogEntry(ctx context.Context, rekorClient *client.Rekor, uuid string) (*models.LogEntryAnon, error) { +func verifyTlogEntryByUUID(ctx context.Context, rekorClient *client.Rekor, uuid string) (*models.LogEntryAnon, error) { params := entries.NewGetLogEntryByUUIDParamsWithContext(ctx) params.EntryUUID = uuid @@ -187,6 +260,10 @@ func verifyTlogEntry(ctx context.Context, rekorClient *client.Rekor, uuid string return nil, errors.New("UUID value can not be extracted") } e := lep.Payload[params.EntryUUID] + return verifyTlogEntry(ctx, rekorClient, params.EntryUUID, e) +} + +func verifyTlogEntry(ctx context.Context, rekorClient *client.Rekor, uuid string, e models.LogEntryAnon) (*models.LogEntryAnon, error) { if e.Verification == nil || e.Verification.InclusionProof == nil { return nil, errors.New("inclusion proof not provided") } @@ -204,7 +281,7 @@ func verifyTlogEntry(ctx context.Context, rekorClient *client.Rekor, uuid string if err != nil { return nil, errors.New("error decoding hex encoded root hash") } - leafHash, err := hex.DecodeString(params.EntryUUID) + leafHash, err := hex.DecodeString(uuid) if err != nil { return nil, errors.New("error decoding hex encoded leaf hash") } @@ -300,7 +377,12 @@ func extractCert(e *models.LogEntryAnon) (*x509.Certificate, error) { // VerifyProvenanceSignature returns the verified DSSE envelope containing the provenance // and the signing certificate given the provenance and artifact hash. func VerifyProvenanceSignature(ctx context.Context, rClient *client.Rekor, provenance []byte, artifactHash string) (*dsselib.Envelope, *x509.Certificate, error) { - // Get Rekor entries corresponding to the binary artifact in the provenance. + // Get Rekor entries corresponding to provenance + if env, cert, err := GetRekorEntriesWithCert(rClient, artifactHash, provenance); err == nil { + return env, cert, nil + } + + // Fallback on using the redis search index to get matching UUIDs. uuids, err := GetRekorEntries(rClient, artifactHash) if err != nil { return nil, nil, err @@ -334,7 +416,7 @@ func FindSigningCertificate(ctx context.Context, uuids []string, dssePayload dss // * Check signature expiration against IntegratedTime in entry. // * If all succeed, return the signing certificate. for _, uuid := range uuids { - entry, err := verifyTlogEntry(ctx, rClient, uuid) + entry, err := verifyTlogEntryByUUID(ctx, rClient, uuid) if err != nil { continue } diff --git a/testdata/binary-linux-amd64-e2e-builder-repo b/testdata/binary-linux-amd64-e2e-builder-repo index b8dc921..1c869a3 100644 Binary files a/testdata/binary-linux-amd64-e2e-builder-repo and b/testdata/binary-linux-amd64-e2e-builder-repo differ diff --git a/testdata/binary-linux-amd64-e2e-builder-repo.intoto.jsonl b/testdata/binary-linux-amd64-e2e-builder-repo.intoto.jsonl index 54ac45a..2c35b23 100644 --- a/testdata/binary-linux-amd64-e2e-builder-repo.intoto.jsonl +++ b/testdata/binary-linux-amd64-e2e-builder-repo.intoto.jsonl @@ -1 +1 @@ -{"payloadType":"application/vnd.in-toto+json","payload":"{"_type":"https://in-toto.io/Statement/v0.1","predicateType":"https://slsa.dev/provenance/v0.2","subject":[{"name":"binary-linux-amd64","digest":{"sha256":"bf6cebef73af4e27ebcd0f3660423e7f3be343e08e5a42a3a83a44ede0d1886b"}}],"predicate":{"builder":{"id":"https://github.com/slsa-framework/slsa-github-generator/.github/workflows/builder_go_slsa3.yml@refs/heads/main"},"buildType":"https://github.com/slsa-framework/slsa-github-generator/go@v1","invocation":{"configSource":{"uri":"git+https://github.com/slsa-framework/example-package@refs/heads/main","digest":{"sha1":"393458cb0763a008fc832bdf3892a5d97c8f6cf3"},"entryPoint":".github/workflows/e2e.go.workflow_dispatch.main.config-noldflags.slsa3.yml"},"parameters":{},"environment":{"arch":"X64","github_actor":"laurentsimon","github_actor_id":"64505099","github_event_name":"workflow_dispatch","github_event_payload":{"inputs":null,"organization":{"avatar_url":"https://avatars.githubusercontent.com/u/80431187?v=4","description":"Supply-chain Levels for Software Artifacts","events_url":"https://api.github.com/orgs/slsa-framework/events","hooks_url":"https://api.github.com/orgs/slsa-framework/hooks","id":80431187,"issues_url":"https://api.github.com/orgs/slsa-framework/issues","login":"slsa-framework","members_url":"https://api.github.com/orgs/slsa-framework/members{/member}","node_id":"MDEyOk9yZ2FuaXphdGlvbjgwNDMxMTg3","public_members_url":"https://api.github.com/orgs/slsa-framework/public_members{/member}","repos_url":"https://api.github.com/orgs/slsa-framework/repos","url":"https://api.github.com/orgs/slsa-framework"},"ref":"refs/heads/main","repository":{"allow_forking":true,"archive_url":"https://api.github.com/repos/slsa-framework/example-package/{archive_format}{/ref}","archived":false,"assignees_url":"https://api.github.com/repos/slsa-framework/example-package/assignees{/user}","blobs_url":"https://api.github.com/repos/slsa-framework/example-package/git/blobs{/sha}","branches_url":"https://api.github.com/repos/slsa-framework/example-package/branches{/branch}","clone_url":"https://github.com/slsa-framework/example-package.git","collaborators_url":"https://api.github.com/repos/slsa-framework/example-package/collaborators{/collaborator}","comments_url":"https://api.github.com/repos/slsa-framework/example-package/comments{/number}","commits_url":"https://api.github.com/repos/slsa-framework/example-package/commits{/sha}","compare_url":"https://api.github.com/repos/slsa-framework/example-package/compare/{base}...{head}","contents_url":"https://api.github.com/repos/slsa-framework/example-package/contents/{+path}","contributors_url":"https://api.github.com/repos/slsa-framework/example-package/contributors","created_at":"2022-04-27T19:30:43Z","default_branch":"main","deployments_url":"https://api.github.com/repos/slsa-framework/example-package/deployments","description":null,"disabled":false,"downloads_url":"https://api.github.com/repos/slsa-framework/example-package/downloads","events_url":"https://api.github.com/repos/slsa-framework/example-package/events","fork":false,"forks":5,"forks_count":5,"forks_url":"https://api.github.com/repos/slsa-framework/example-package/forks","full_name":"slsa-framework/example-package","git_commits_url":"https://api.github.com/repos/slsa-framework/example-package/git/commits{/sha}","git_refs_url":"https://api.github.com/repos/slsa-framework/example-package/git/refs{/sha}","git_tags_url":"https://api.github.com/repos/slsa-framework/example-package/git/tags{/sha}","git_url":"git://github.com/slsa-framework/example-package.git","has_downloads":true,"has_issues":true,"has_pages":false,"has_projects":true,"has_wiki":true,"homepage":null,"hooks_url":"https://api.github.com/repos/slsa-framework/example-package/hooks","html_url":"https://github.com/slsa-framework/example-package","id":486325809,"is_template":false,"issue_comment_url":"https://api.github.com/repos/slsa-framework/example-package/issues/comments{/number}","issue_events_url":"https://api.github.com/repos/slsa-framework/example-package/issues/events{/number}","issues_url":"https://api.github.com/repos/slsa-framework/example-package/issues{/number}","keys_url":"https://api.github.com/repos/slsa-framework/example-package/keys{/key_id}","labels_url":"https://api.github.com/repos/slsa-framework/example-package/labels{/name}","language":"Shell","languages_url":"https://api.github.com/repos/slsa-framework/example-package/languages","license":{"key":"apache-2.0","name":"Apache License 2.0","node_id":"MDc6TGljZW5zZTI=","spdx_id":"Apache-2.0","url":"https://api.github.com/licenses/apache-2.0"},"merges_url":"https://api.github.com/repos/slsa-framework/example-package/merges","milestones_url":"https://api.github.com/repos/slsa-framework/example-package/milestones{/number}","mirror_url":null,"name":"example-package","node_id":"R_kgDOHPy-MQ","notifications_url":"https://api.github.com/repos/slsa-framework/example-package/notifications{?since,all,participating}","open_issues":10,"open_issues_count":10,"owner":{"avatar_url":"https://avatars.githubusercontent.com/u/80431187?v=4","events_url":"https://api.github.com/users/slsa-framework/events{/privacy}","followers_url":"https://api.github.com/users/slsa-framework/followers","following_url":"https://api.github.com/users/slsa-framework/following{/other_user}","gists_url":"https://api.github.com/users/slsa-framework/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/slsa-framework","id":80431187,"login":"slsa-framework","node_id":"MDEyOk9yZ2FuaXphdGlvbjgwNDMxMTg3","organizations_url":"https://api.github.com/users/slsa-framework/orgs","received_events_url":"https://api.github.com/users/slsa-framework/received_events","repos_url":"https://api.github.com/users/slsa-framework/repos","site_admin":false,"starred_url":"https://api.github.com/users/slsa-framework/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/slsa-framework/subscriptions","type":"Organization","url":"https://api.github.com/users/slsa-framework"},"private":false,"pulls_url":"https://api.github.com/repos/slsa-framework/example-package/pulls{/number}","pushed_at":"2022-06-02T03:44:59Z","releases_url":"https://api.github.com/repos/slsa-framework/example-package/releases{/id}","size":1192,"ssh_url":"git@github.com:slsa-framework/example-package.git","stargazers_count":1,"stargazers_url":"https://api.github.com/repos/slsa-framework/example-package/stargazers","statuses_url":"https://api.github.com/repos/slsa-framework/example-package/statuses/{sha}","subscribers_url":"https://api.github.com/repos/slsa-framework/example-package/subscribers","subscription_url":"https://api.github.com/repos/slsa-framework/example-package/subscription","svn_url":"https://github.com/slsa-framework/example-package","tags_url":"https://api.github.com/repos/slsa-framework/example-package/tags","teams_url":"https://api.github.com/repos/slsa-framework/example-package/teams","topics":[],"trees_url":"https://api.github.com/repos/slsa-framework/example-package/git/trees{/sha}","updated_at":"2022-05-15T19:48:40Z","url":"https://api.github.com/repos/slsa-framework/example-package","visibility":"public","watchers":1,"watchers_count":1},"sender":{"avatar_url":"https://avatars.githubusercontent.com/u/64505099?v=4","events_url":"https://api.github.com/users/laurentsimon/events{/privacy}","followers_url":"https://api.github.com/users/laurentsimon/followers","following_url":"https://api.github.com/users/laurentsimon/following{/other_user}","gists_url":"https://api.github.com/users/laurentsimon/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/laurentsimon","id":64505099,"login":"laurentsimon","node_id":"MDQ6VXNlcjY0NTA1MDk5","organizations_url":"https://api.github.com/users/laurentsimon/orgs","received_events_url":"https://api.github.com/users/laurentsimon/received_events","repos_url":"https://api.github.com/users/laurentsimon/repos","site_admin":false,"starred_url":"https://api.github.com/users/laurentsimon/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/laurentsimon/subscriptions","type":"User","url":"https://api.github.com/users/laurentsimon"},"workflow":".github/workflows/e2e.go.workflow_dispatch.main.config-noldflags.slsa3.yml"},"github_ref":"refs/heads/main","github_ref_type":"branch","github_repository_id":"486325809","github_repository_owner":"slsa-framework","github_repository_owner_id":"80431187","github_run_attempt":"1","github_run_id":"2425929392","github_run_number":"66","github_sha1":"393458cb0763a008fc832bdf3892a5d97c8f6cf3","os":"ubuntu20"}},"buildConfig":{"version":1,"steps":[{"command":["/opt/hostedtoolcache/go/1.18.2/x64/bin/go","mod","vendor"],"env":null,"workingDir":"/home/runner/work/example-package/example-package"},{"command":["/opt/hostedtoolcache/go/1.18.2/x64/bin/go","build","-mod=vendor","-trimpath","-tags=netgo","-o","binary-linux-amd64"],"env":["GOOS=linux","GOARCH=amd64","GO111MODULE=on","CGO_ENABLED=0"],"workingDir":"/home/runner/work/example-package/example-package"}]},"metadata":{"buildInvocationID":"2425929392-1","completeness":{"parameters":true,"environment":false,"materials":false},"reproducible":false},"materials":[{"uri":"git+https://github.com/slsa-framework/example-package@refs/heads/main","digest":{"sha1":"393458cb0763a008fc832bdf3892a5d97c8f6cf3"}},{"uri":"https://github.com/actions/virtual-environments/releases/tag/ubuntu20/20220515.1"}]}}","signatures":[{"keyid":"","sig":"MEUCIQCcW5vhzQKpCZf9BrCGsJm+xq+x6kHW/ON1P8fbk0NTkgIgLNCXvgURFCVtWKfWR+XsnqVtU6QqqQ73tHbLIu1GkNw="}]} \ No newline at end of file +{"payloadType":"application/vnd.in-toto+json","payload":"eyJfdHlwZSI6Imh0dHBzOi8vaW4tdG90by5pby9TdGF0ZW1lbnQvdjAuMSIsInByZWRpY2F0ZVR5cGUiOiJodHRwczovL3Nsc2EuZGV2L3Byb3ZlbmFuY2UvdjAuMiIsInN1YmplY3QiOlt7Im5hbWUiOiJiaW5hcnktbGludXgtYW1kNjQiLCJkaWdlc3QiOnsic2hhMjU2IjoiOWU2Y2FhZjFlOTIwYmQ2NzMyYjY5NjAxMjk5YTMwOWU4YmFhYTdkN2Y5Mjg5ZWE3ZmYwYjkyOTEyOTRkZmUxMiJ9fV0sInByZWRpY2F0ZSI6eyJidWlsZGVyIjp7ImlkIjoiaHR0cHM6Ly9naXRodWIuY29tL3Nsc2EtZnJhbWV3b3JrL3Nsc2EtZ2l0aHViLWdlbmVyYXRvci8uZ2l0aHViL3dvcmtmbG93cy9idWlsZGVyX2dvX3Nsc2EzLnltbEByZWZzL2hlYWRzL21haW4ifSwiYnVpbGRUeXBlIjoiaHR0cHM6Ly9naXRodWIuY29tL3Nsc2EtZnJhbWV3b3JrL3Nsc2EtZ2l0aHViLWdlbmVyYXRvci9nb0B2MSIsImludm9jYXRpb24iOnsiY29uZmlnU291cmNlIjp7InVyaSI6ImdpdCtodHRwczovL2dpdGh1Yi5jb20vc2xzYS1mcmFtZXdvcmsvZXhhbXBsZS1wYWNrYWdlQHJlZnMvaGVhZHMvbWFpbiIsImRpZ2VzdCI6eyJzaGExIjoiYTRiMGI1M2NiNDQ3MWE4NWZiYzE2MTBiODIwOGRlMGZhYTlhZjhhYSJ9LCJlbnRyeVBvaW50IjoiLmdpdGh1Yi93b3JrZmxvd3MvZTJlLmdvLnNjaGVkdWxlLm1haW4uY29uZmlnLWxkZmxhZ3MtbWFpbi1kaXIuc2xzYTMueW1sIn0sInBhcmFtZXRlcnMiOnt9LCJlbnZpcm9ubWVudCI6eyJhcmNoIjoiWDY0IiwiZ2l0aHViX2FjdG9yIjoibGF1cmVudHNpbW9uIiwiZ2l0aHViX2FjdG9yX2lkIjoiNjQ1MDUwOTkiLCJnaXRodWJfYmFzZV9yZWYiOiIiLCJnaXRodWJfZXZlbnRfbmFtZSI6InNjaGVkdWxlIiwiZ2l0aHViX2V2ZW50X3BheWxvYWQiOnsic2NoZWR1bGUiOiIwIDEwICogKiAqIn0sImdpdGh1Yl9oZWFkX3JlZiI6IiIsImdpdGh1Yl9yZWYiOiJyZWZzL2hlYWRzL21haW4iLCJnaXRodWJfcmVmX3R5cGUiOiJicmFuY2giLCJnaXRodWJfcmVwb3NpdG9yeV9pZCI6IjQ4NjMyNTgwOSIsImdpdGh1Yl9yZXBvc2l0b3J5X293bmVyIjoic2xzYS1mcmFtZXdvcmsiLCJnaXRodWJfcmVwb3NpdG9yeV9vd25lcl9pZCI6IjgwNDMxMTg3IiwiZ2l0aHViX3J1bl9hdHRlbXB0IjoiMSIsImdpdGh1Yl9ydW5faWQiOiIyNTI4MjQ2NDk4IiwiZ2l0aHViX3J1bl9udW1iZXIiOiI0NCIsImdpdGh1Yl9zaGExIjoiYTRiMGI1M2NiNDQ3MWE4NWZiYzE2MTBiODIwOGRlMGZhYTlhZjhhYSIsIm9zIjoidWJ1bnR1MjAifX0sImJ1aWxkQ29uZmlnIjp7InZlcnNpb24iOjEsInN0ZXBzIjpbeyJjb21tYW5kIjpbIi9vcHQvaG9zdGVkdG9vbGNhY2hlL2dvLzEuMTguMy94NjQvYmluL2dvIiwibW9kIiwidmVuZG9yIl0sImVudiI6bnVsbCwid29ya2luZ0RpciI6Ii9ob21lL3J1bm5lci93b3JrL2V4YW1wbGUtcGFja2FnZS9leGFtcGxlLXBhY2thZ2UvZTJlL2dvIn0seyJjb21tYW5kIjpbIi9vcHQvaG9zdGVkdG9vbGNhY2hlL2dvLzEuMTguMy94NjQvYmluL2dvIiwiYnVpbGQiLCItbW9kPXZlbmRvciIsIi10cmltcGF0aCIsIi10YWdzPW5ldGdvIiwiLWxkZmxhZ3M9LVggbWFpbi5naXRWZXJzaW9uPXYxLjIuMyAtWCBtYWluLmdpdENvbW1pdD1hYmNkZWYgLVggbWFpbi5naXRCcmFuY2g9bWFpbiAtWCBtYWluLmdpdE1haW49bWFpbi5nbyIsIi1vIiwiYmluYXJ5LWxpbnV4LWFtZDY0IiwibWFpbi5nbyJdLCJlbnYiOlsiR09PUz1saW51eCIsIkdPQVJDSD1hbWQ2NCIsIkdPMTExTU9EVUxFPW9uIiwiQ0dPX0VOQUJMRUQ9MCJdLCJ3b3JraW5nRGlyIjoiL2hvbWUvcnVubmVyL3dvcmsvZXhhbXBsZS1wYWNrYWdlL2V4YW1wbGUtcGFja2FnZS9lMmUvZ28ifV19LCJtZXRhZGF0YSI6eyJidWlsZEludm9jYXRpb25JRCI6IjI1MjgyNDY0OTgtMSIsImNvbXBsZXRlbmVzcyI6eyJwYXJhbWV0ZXJzIjp0cnVlLCJlbnZpcm9ubWVudCI6ZmFsc2UsIm1hdGVyaWFscyI6ZmFsc2V9LCJyZXByb2R1Y2libGUiOmZhbHNlfSwibWF0ZXJpYWxzIjpbeyJ1cmkiOiJnaXQraHR0cHM6Ly9naXRodWIuY29tL3Nsc2EtZnJhbWV3b3JrL2V4YW1wbGUtcGFja2FnZUByZWZzL2hlYWRzL21haW4iLCJkaWdlc3QiOnsic2hhMSI6ImE0YjBiNTNjYjQ0NzFhODVmYmMxNjEwYjgyMDhkZTBmYWE5YWY4YWEifX0seyJ1cmkiOiJodHRwczovL2dpdGh1Yi5jb20vYWN0aW9ucy92aXJ0dWFsLWVudmlyb25tZW50cy9yZWxlYXNlcy90YWcvdWJ1bnR1MjAvMjAyMjA2MTQuMCJ9XX19","signatures":[{"keyid":"","sig":"MEQCIFcm4ArFjP/AoyPqLgmPOA5Jcm+KwdBOXZCg9BCAQpYTAiA5LllgtRpB/Cf4FXD5N2wlPg3vv7QvaMNggYMHY42XMQ==","cert":"-----BEGIN CERTIFICATE-----\nMIIDczCCAvigAwIBAgITHdt+KB8Y21TqQwhJHsHuFu/3NjAKBggqhkjOPQQDAzAq\nMRUwEwYDVQQKEwxzaWdzdG9yZS5kZXYxETAPBgNVBAMTCHNpZ3N0b3JlMB4XDTIy\nMDYyMDEwMjI1MloXDTIyMDYyMDEwMzI1MVowADBZMBMGByqGSM49AgEGCCqGSM49\nAwEHA0IABOCEMIgJSAZHFXgqw1uZW1Mjs3kxPFi1IIwdzjIra7NDH/ujMw9JJ7QG\nNecUqw6LZ68K7BkubSHV+UU3AN/Uu8mjggIlMIICITAOBgNVHQ8BAf8EBAMCB4Aw\nEwYDVR0lBAwwCgYIKwYBBQUHAwMwDAYDVR0TAQH/BAIwADAdBgNVHQ4EFgQUnp0a\ni8vmr8QTU12L3nUl7tswwtkwHwYDVR0jBBgwFoAUWMAeX5FFpWapesyQoZMi0CrF\nxfowfAYDVR0RAQH/BHIwcIZuaHR0cHM6Ly9naXRodWIuY29tL3Nsc2EtZnJhbWV3\nb3JrL3Nsc2EtZ2l0aHViLWdlbmVyYXRvci8uZ2l0aHViL3dvcmtmbG93cy9idWls\nZGVyX2dvX3Nsc2EzLnltbEByZWZzL2hlYWRzL21haW4wHQYKKwYBBAGDvzABBgQP\ncmVmcy9oZWFkcy9tYWluMFYGCisGAQQBg78wAQQESC5naXRodWIvd29ya2Zsb3dz\nL2UyZS5nby5zY2hlZHVsZS5tYWluLmNvbmZpZy1sZGZsYWdzLW1haW4tZGlyLnNs\nc2EzLnltbDAsBgorBgEEAYO/MAEFBB5zbHNhLWZyYW1ld29yay9leGFtcGxlLXBh\nY2thZ2UwFgYKKwYBBAGDvzABAgQIc2NoZWR1bGUwNgYKKwYBBAGDvzABAwQoYTRi\nMGI1M2NiNDQ3MWE4NWZiYzE2MTBiODIwOGRlMGZhYTlhZjhhYTA5BgorBgEEAYO/\nMAEBBCtodHRwczovL3Rva2VuLmFjdGlvbnMuZ2l0aHVidXNlcmNvbnRlbnQuY29t\nMAoGCCqGSM49BAMDA2kAMGYCMQCT3GMdJy368nK8XZGXIvPONZYSnOgcmOjjnSXD\npFSKGOLllT2mDEUuV8I5xwFvD2cCMQDinrRDzXuWpqcMagoEn0iGxQ3vQLMxK65Z\nv3pjFhzaF7I7JjWbarjNrJPKSaTD3mo=\n-----END CERTIFICATE-----\n"}]} \ No newline at end of file diff --git a/testdata/binary-linux-amd64-expired-cert b/testdata/binary-linux-amd64-expired-cert index a54cec7..4eca6fd 100644 Binary files a/testdata/binary-linux-amd64-expired-cert and b/testdata/binary-linux-amd64-expired-cert differ diff --git a/testdata/binary-linux-amd64-expired-cert.intoto.jsonl b/testdata/binary-linux-amd64-expired-cert.intoto.jsonl index 1c1651c..f2d72a9 100644 --- a/testdata/binary-linux-amd64-expired-cert.intoto.jsonl +++ b/testdata/binary-linux-amd64-expired-cert.intoto.jsonl @@ -1 +1 @@ -{"payloadType":"application/vnd.in-toto+json","payload":"{"_type":"https://in-toto.io/Statement/v0.1","predicateType":"https://slsa.dev/provenance/v0.2","subject":[{"name":"binary-linux-amd64-config1","digest":{"sha256":"b1cca12c4e06d9036dfa7c64a5c0f2f90e3ae2ec7a809021bbf6ca67f25e7be8"}}],"predicate":{"builder":{"id":"https://github.com/asraa/slsa-github-generator/.github/workflows/builder_go_slsa3.yml@refs/heads/skip-rekor-upload"},"buildType":"https://github.com/slsa-framework/slsa-github-generator-go@v1","invocation":{"configSource":{"uri":"git+https://github.com/asraa/slsa-on-github-test@refs/heads/main","digest":{"sha1":"020a18c12e3d36600dc9f7f17f5fbeac4ef46da1"},"entryPoint":"Go SLSA Release"},"parameters":{},"environment":{"arch":"X64","github_actor":"asraa","github_base_ref":"","github_event_name":"workflow_dispatch","github_event_payload":{"inputs":null,"ref":"refs/heads/main","repository":{"allow_forking":true,"archive_url":"https://api.github.com/repos/asraa/slsa-on-github-test/{archive_format}{/ref}","archived":false,"assignees_url":"https://api.github.com/repos/asraa/slsa-on-github-test/assignees{/user}","blobs_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/blobs{/sha}","branches_url":"https://api.github.com/repos/asraa/slsa-on-github-test/branches{/branch}","clone_url":"https://github.com/asraa/slsa-on-github-test.git","collaborators_url":"https://api.github.com/repos/asraa/slsa-on-github-test/collaborators{/collaborator}","comments_url":"https://api.github.com/repos/asraa/slsa-on-github-test/comments{/number}","commits_url":"https://api.github.com/repos/asraa/slsa-on-github-test/commits{/sha}","compare_url":"https://api.github.com/repos/asraa/slsa-on-github-test/compare/{base}...{head}","contents_url":"https://api.github.com/repos/asraa/slsa-on-github-test/contents/{+path}","contributors_url":"https://api.github.com/repos/asraa/slsa-on-github-test/contributors","created_at":"2022-02-15T15:33:49Z","default_branch":"main","deployments_url":"https://api.github.com/repos/asraa/slsa-on-github-test/deployments","description":"Test for SLSA","disabled":false,"downloads_url":"https://api.github.com/repos/asraa/slsa-on-github-test/downloads","events_url":"https://api.github.com/repos/asraa/slsa-on-github-test/events","fork":true,"forks":0,"forks_count":0,"forks_url":"https://api.github.com/repos/asraa/slsa-on-github-test/forks","full_name":"asraa/slsa-on-github-test","git_commits_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/commits{/sha}","git_refs_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/refs{/sha}","git_tags_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/tags{/sha}","git_url":"git://github.com/asraa/slsa-on-github-test.git","has_downloads":true,"has_issues":false,"has_pages":false,"has_projects":true,"has_wiki":true,"homepage":null,"hooks_url":"https://api.github.com/repos/asraa/slsa-on-github-test/hooks","html_url":"https://github.com/asraa/slsa-on-github-test","id":459639150,"is_template":false,"issue_comment_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues/comments{/number}","issue_events_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues/events{/number}","issues_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues{/number}","keys_url":"https://api.github.com/repos/asraa/slsa-on-github-test/keys{/key_id}","labels_url":"https://api.github.com/repos/asraa/slsa-on-github-test/labels{/name}","language":"Go","languages_url":"https://api.github.com/repos/asraa/slsa-on-github-test/languages","license":{"key":"apache-2.0","name":"Apache License 2.0","node_id":"MDc6TGljZW5zZTI=","spdx_id":"Apache-2.0","url":"https://api.github.com/licenses/apache-2.0"},"merges_url":"https://api.github.com/repos/asraa/slsa-on-github-test/merges","milestones_url":"https://api.github.com/repos/asraa/slsa-on-github-test/milestones{/number}","mirror_url":null,"name":"slsa-on-github-test","node_id":"R_kgDOG2WJbg","notifications_url":"https://api.github.com/repos/asraa/slsa-on-github-test/notifications{?since,all,participating}","open_issues":0,"open_issues_count":0,"owner":{"avatar_url":"https://avatars.githubusercontent.com/u/5194569?v=4","events_url":"https://api.github.com/users/asraa/events{/privacy}","followers_url":"https://api.github.com/users/asraa/followers","following_url":"https://api.github.com/users/asraa/following{/other_user}","gists_url":"https://api.github.com/users/asraa/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/asraa","id":5194569,"login":"asraa","node_id":"MDQ6VXNlcjUxOTQ1Njk=","organizations_url":"https://api.github.com/users/asraa/orgs","received_events_url":"https://api.github.com/users/asraa/received_events","repos_url":"https://api.github.com/users/asraa/repos","site_admin":false,"starred_url":"https://api.github.com/users/asraa/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/asraa/subscriptions","type":"User","url":"https://api.github.com/users/asraa"},"private":false,"pulls_url":"https://api.github.com/repos/asraa/slsa-on-github-test/pulls{/number}","pushed_at":"2022-05-26T20:33:18Z","releases_url":"https://api.github.com/repos/asraa/slsa-on-github-test/releases{/id}","size":1336,"ssh_url":"git@github.com:asraa/slsa-on-github-test.git","stargazers_count":0,"stargazers_url":"https://api.github.com/repos/asraa/slsa-on-github-test/stargazers","statuses_url":"https://api.github.com/repos/asraa/slsa-on-github-test/statuses/{sha}","subscribers_url":"https://api.github.com/repos/asraa/slsa-on-github-test/subscribers","subscription_url":"https://api.github.com/repos/asraa/slsa-on-github-test/subscription","svn_url":"https://github.com/asraa/slsa-on-github-test","tags_url":"https://api.github.com/repos/asraa/slsa-on-github-test/tags","teams_url":"https://api.github.com/repos/asraa/slsa-on-github-test/teams","topics":[],"trees_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/trees{/sha}","updated_at":"2022-02-15T15:36:41Z","url":"https://api.github.com/repos/asraa/slsa-on-github-test","visibility":"public","watchers":0,"watchers_count":0},"sender":{"avatar_url":"https://avatars.githubusercontent.com/u/5194569?v=4","events_url":"https://api.github.com/users/asraa/events{/privacy}","followers_url":"https://api.github.com/users/asraa/followers","following_url":"https://api.github.com/users/asraa/following{/other_user}","gists_url":"https://api.github.com/users/asraa/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/asraa","id":5194569,"login":"asraa","node_id":"MDQ6VXNlcjUxOTQ1Njk=","organizations_url":"https://api.github.com/users/asraa/orgs","received_events_url":"https://api.github.com/users/asraa/received_events","repos_url":"https://api.github.com/users/asraa/repos","site_admin":false,"starred_url":"https://api.github.com/users/asraa/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/asraa/subscriptions","type":"User","url":"https://api.github.com/users/asraa"},"workflow":".github/workflows/slsa-reusable.yaml"},"github_head_ref":"","github_ref":"refs/heads/main","github_ref_type":"branch","github_run_attempt":"1","github_run_id":"2392986860","github_run_number":"141","github_sha1":"020a18c12e3d36600dc9f7f17f5fbeac4ef46da1","os":"ubuntu20"}},"buildConfig":{"version":1,"steps":[{"command":["/opt/hostedtoolcache/go/1.17.10/x64/bin/go","mod","vendor"],"env":null,"workingDir":"/home/runner/work/slsa-on-github-test/slsa-on-github-test"},{"command":["/opt/hostedtoolcache/go/1.17.10/x64/bin/go","build","-mod=vendor","-trimpath","-tags=netgo","-o","binary-linux-amd64-config1"],"env":["GOOS=linux","GOARCH=amd64","GO111MODULE=on","CGO_ENABLED=0"],"workingDir":"/home/runner/work/slsa-on-github-test/slsa-on-github-test"}]},"metadata":{"buildInvocationID":"2392986860-1","completeness":{"parameters":true,"environment":false,"materials":false},"reproducible":false},"materials":[{"uri":"git+https://github.com/asraa/slsa-on-github-test@refs/heads/main","digest":{"sha1":"020a18c12e3d36600dc9f7f17f5fbeac4ef46da1"}},{"uri":"https://github.com/actions/virtual-environments/releases/tag/ubuntu20/20220515.1"}]}}","signatures":[{"keyid":"","sig":"MEYCIQCrIaZlanN7gV/FPmA6sekhsjIM5D4uEaZwYxJszI9mDAIhAOItdSGuL8BLynLvJzNZmdY3eafccbJDY5i3gLOAzNq8"}]} \ No newline at end of file +{"payloadType":"application/vnd.in-toto+json","payload":"{"_type":"https://in-toto.io/Statement/v0.1","predicateType":"https://slsa.dev/provenance/v0.2","subject":[{"name":"binary-linux-amd64","digest":{"sha256":"4bdb495d05cbb9eb0722ec4fcfef8a02d5ca7a2fca0b0fed718447f89d39a589"}}],"predicate":{"builder":{"id":"https://github.com/asraa/slsa-github-generator/.github/workflows/builder_go_slsa3.yml@refs/heads/malicious"},"buildType":"https://github.com/slsa-framework/slsa-github-generator/go@v1","invocation":{"configSource":{"uri":"git+https://github.com/asraa/slsa-on-github-test@refs/heads/main","digest":{"sha1":"06f43f769174a538bf9ea44723d9c6c25ba4278d"},"entryPoint":".github/workflows/slsa-reusable.yaml"},"parameters":{},"environment":{"arch":"X64","github_actor":"asraa","github_actor_id":"5194569","github_base_ref":"","github_event_name":"workflow_dispatch","github_event_payload":{"inputs":null,"ref":"refs/heads/main","repository":{"allow_forking":true,"archive_url":"https://api.github.com/repos/asraa/slsa-on-github-test/{archive_format}{/ref}","archived":false,"assignees_url":"https://api.github.com/repos/asraa/slsa-on-github-test/assignees{/user}","blobs_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/blobs{/sha}","branches_url":"https://api.github.com/repos/asraa/slsa-on-github-test/branches{/branch}","clone_url":"https://github.com/asraa/slsa-on-github-test.git","collaborators_url":"https://api.github.com/repos/asraa/slsa-on-github-test/collaborators{/collaborator}","comments_url":"https://api.github.com/repos/asraa/slsa-on-github-test/comments{/number}","commits_url":"https://api.github.com/repos/asraa/slsa-on-github-test/commits{/sha}","compare_url":"https://api.github.com/repos/asraa/slsa-on-github-test/compare/{base}...{head}","contents_url":"https://api.github.com/repos/asraa/slsa-on-github-test/contents/{+path}","contributors_url":"https://api.github.com/repos/asraa/slsa-on-github-test/contributors","created_at":"2022-06-08T20:07:14Z","default_branch":"main","deployments_url":"https://api.github.com/repos/asraa/slsa-on-github-test/deployments","description":"Test for SLSA","disabled":false,"downloads_url":"https://api.github.com/repos/asraa/slsa-on-github-test/downloads","events_url":"https://api.github.com/repos/asraa/slsa-on-github-test/events","fork":true,"forks":0,"forks_count":0,"forks_url":"https://api.github.com/repos/asraa/slsa-on-github-test/forks","full_name":"asraa/slsa-on-github-test","git_commits_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/commits{/sha}","git_refs_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/refs{/sha}","git_tags_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/tags{/sha}","git_url":"git://github.com/asraa/slsa-on-github-test.git","has_downloads":true,"has_issues":false,"has_pages":false,"has_projects":true,"has_wiki":true,"homepage":null,"hooks_url":"https://api.github.com/repos/asraa/slsa-on-github-test/hooks","html_url":"https://github.com/asraa/slsa-on-github-test","id":501395242,"is_template":false,"issue_comment_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues/comments{/number}","issue_events_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues/events{/number}","issues_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues{/number}","keys_url":"https://api.github.com/repos/asraa/slsa-on-github-test/keys{/key_id}","labels_url":"https://api.github.com/repos/asraa/slsa-on-github-test/labels{/name}","language":"Go","languages_url":"https://api.github.com/repos/asraa/slsa-on-github-test/languages","license":{"key":"apache-2.0","name":"Apache License 2.0","node_id":"MDc6TGljZW5zZTI=","spdx_id":"Apache-2.0","url":"https://api.github.com/licenses/apache-2.0"},"merges_url":"https://api.github.com/repos/asraa/slsa-on-github-test/merges","milestones_url":"https://api.github.com/repos/asraa/slsa-on-github-test/milestones{/number}","mirror_url":null,"name":"slsa-on-github-test","node_id":"R_kgDOHeKvKg","notifications_url":"https://api.github.com/repos/asraa/slsa-on-github-test/notifications{?since,all,participating}","open_issues":0,"open_issues_count":0,"owner":{"avatar_url":"https://avatars.githubusercontent.com/u/5194569?v=4","events_url":"https://api.github.com/users/asraa/events{/privacy}","followers_url":"https://api.github.com/users/asraa/followers","following_url":"https://api.github.com/users/asraa/following{/other_user}","gists_url":"https://api.github.com/users/asraa/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/asraa","id":5194569,"login":"asraa","node_id":"MDQ6VXNlcjUxOTQ1Njk=","organizations_url":"https://api.github.com/users/asraa/orgs","received_events_url":"https://api.github.com/users/asraa/received_events","repos_url":"https://api.github.com/users/asraa/repos","site_admin":false,"starred_url":"https://api.github.com/users/asraa/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/asraa/subscriptions","type":"User","url":"https://api.github.com/users/asraa"},"private":false,"pulls_url":"https://api.github.com/repos/asraa/slsa-on-github-test/pulls{/number}","pushed_at":"2022-06-20T18:48:34Z","releases_url":"https://api.github.com/repos/asraa/slsa-on-github-test/releases{/id}","size":213,"ssh_url":"git@github.com:asraa/slsa-on-github-test.git","stargazers_count":0,"stargazers_url":"https://api.github.com/repos/asraa/slsa-on-github-test/stargazers","statuses_url":"https://api.github.com/repos/asraa/slsa-on-github-test/statuses/{sha}","subscribers_url":"https://api.github.com/repos/asraa/slsa-on-github-test/subscribers","subscription_url":"https://api.github.com/repos/asraa/slsa-on-github-test/subscription","svn_url":"https://github.com/asraa/slsa-on-github-test","tags_url":"https://api.github.com/repos/asraa/slsa-on-github-test/tags","teams_url":"https://api.github.com/repos/asraa/slsa-on-github-test/teams","topics":[],"trees_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/trees{/sha}","updated_at":"2022-06-08T20:09:58Z","url":"https://api.github.com/repos/asraa/slsa-on-github-test","visibility":"public","watchers":0,"watchers_count":0},"sender":{"avatar_url":"https://avatars.githubusercontent.com/u/5194569?v=4","events_url":"https://api.github.com/users/asraa/events{/privacy}","followers_url":"https://api.github.com/users/asraa/followers","following_url":"https://api.github.com/users/asraa/following{/other_user}","gists_url":"https://api.github.com/users/asraa/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/asraa","id":5194569,"login":"asraa","node_id":"MDQ6VXNlcjUxOTQ1Njk=","organizations_url":"https://api.github.com/users/asraa/orgs","received_events_url":"https://api.github.com/users/asraa/received_events","repos_url":"https://api.github.com/users/asraa/repos","site_admin":false,"starred_url":"https://api.github.com/users/asraa/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/asraa/subscriptions","type":"User","url":"https://api.github.com/users/asraa"},"workflow":".github/workflows/slsa-reusable.yaml"},"github_head_ref":"","github_ref":"refs/heads/main","github_ref_type":"branch","github_repository_id":"501395242","github_repository_owner":"asraa","github_repository_owner_id":"5194569","github_run_attempt":"1","github_run_id":"2530941975","github_run_number":"6","github_sha1":"06f43f769174a538bf9ea44723d9c6c25ba4278d","os":"ubuntu20"}},"buildConfig":{"version":1,"steps":[{"command":["/opt/hostedtoolcache/go/1.17.11/x64/bin/go","mod","vendor"],"env":null,"workingDir":"/home/runner/work/slsa-on-github-test/slsa-on-github-test"},{"command":["/opt/hostedtoolcache/go/1.17.11/x64/bin/go","build","-mod=vendor","-trimpath","-tags=netgo","-o","binary-linux-amd64"],"env":["GOOS=linux","GOARCH=amd64","CGO_ENABLED=0","GO111MODULE=on"],"workingDir":"/home/runner/work/slsa-on-github-test/slsa-on-github-test"}]},"metadata":{"buildInvocationID":"2530941975-1","completeness":{"parameters":true,"environment":false,"materials":false},"reproducible":false},"materials":[{"uri":"git+https://github.com/asraa/slsa-on-github-test@refs/heads/main","digest":{"sha1":"06f43f769174a538bf9ea44723d9c6c25ba4278d"}},{"uri":"https://github.com/actions/virtual-environments/releases/tag/ubuntu20/20220614.0"}]}}","signatures":[{"keyid":"","sig":"MEUCIEGHskCQqIQWnCNeEOwFtid/RzztToMFY2XEpQKxBaIYAiEA1t/zbqeUzsuk8r6USp8TkWKjTsvQWOmw4uHkqTgZclU=","cert":"-----BEGIN CERTIFICATE-----\nMIIDODCCAr+gAwIBAgITMoa25UIi6GouMb1ukl/On0sBHDAKBggqhkjOPQQDAzAq\nMRUwEwYDVQQKEwxzaWdzdG9yZS5kZXYxETAPBgNVBAMTCHNpZ3N0b3JlMB4XDTIy\nMDYyMDE4NTMwNFoXDTIyMDYyMDE5MDMwM1owADBZMBMGByqGSM49AgEGCCqGSM49\nAwEHA0IABCrWtMdg6i+jhD9X8MxqPS4m6Er4JHo2ZXtMT/6OSP1KVHz9NhJnOVb8\ny0ZAm5lpcfI/PtCPD9EogNxBvaUym4yjggHsMIIB6DAOBgNVHQ8BAf8EBAMCB4Aw\nEwYDVR0lBAwwCgYIKwYBBQUHAwMwDAYDVR0TAQH/BAIwADAdBgNVHQ4EFgQUa6Dw\n6r3io3VcQwmWfeO1JfsgOs8wHwYDVR0jBBgwFoAUWMAeX5FFpWapesyQoZMi0CrF\nxfoweAYDVR0RAQH/BG4wbIZqaHR0cHM6Ly9naXRodWIuY29tL2FzcmFhL3Nsc2Et\nZ2l0aHViLWdlbmVyYXRvci8uZ2l0aHViL3dvcmtmbG93cy9idWlsZGVyX2dvX3Ns\nc2EzLnltbEByZWZzL2hlYWRzL21hbGljaW91czAnBgorBgEEAYO/MAEFBBlhc3Jh\nYS9zbHNhLW9uLWdpdGh1Yi10ZXN0MDYGCisGAQQBg78wAQMEKDA2ZjQzZjc2OTE3\nNGE1MzhiZjllYTQ0NzIzZDljNmMyNWJhNDI3OGQwOQYKKwYBBAGDvzABAQQraHR0\ncHM6Ly90b2tlbi5hY3Rpb25zLmdpdGh1YnVzZXJjb250ZW50LmNvbTAdBgorBgEE\nAYO/MAEGBA9yZWZzL2hlYWRzL21haW4wHQYKKwYBBAGDvzABBAQPR28gU0xTQSBS\nZWxlYXNlMB8GCisGAQQBg78wAQIEEXdvcmtmbG93X2Rpc3BhdGNoMAoGCCqGSM49\nBAMDA2cAMGQCMDToU8nmZ4kSTgN5O1i/HJEeNMaCYrCPTi1zluPxS9luF65EIYJx\nZsjozB2f1MKW9gIwbgx8RjCOH2wCfgV3Wm6dOzs7g/Ag7tIerz7mpLXIBKH3RjfC\nErDmwEFlYyaKSqVu\n-----END CERTIFICATE-----\n"}]} \ No newline at end of file diff --git a/testdata/binary-linux-amd64-no-tlog-upload b/testdata/binary-linux-amd64-no-tlog-upload index 051611e..4eca6fd 100644 Binary files a/testdata/binary-linux-amd64-no-tlog-upload and b/testdata/binary-linux-amd64-no-tlog-upload differ diff --git a/testdata/binary-linux-amd64-no-tlog-upload.intoto.jsonl b/testdata/binary-linux-amd64-no-tlog-upload.intoto.jsonl index abc7336..6b5f488 100644 --- a/testdata/binary-linux-amd64-no-tlog-upload.intoto.jsonl +++ b/testdata/binary-linux-amd64-no-tlog-upload.intoto.jsonl @@ -1 +1 @@ -{"payloadType":"application/vnd.in-toto+json","payload":"{"_type":"https://in-toto.io/Statement/v0.1","predicateType":"https://slsa.dev/provenance/v0.2","subject":[{"name":"binary-linux-amd64-config1","digest":{"sha256":"a8d77055949711230508cd17d0ac14f4d198309133df2d2bc4ebfa1c20cf7687"}}],"predicate":{"builder":{"id":"https://github.com/asraa/slsa-github-generator/.github/workflows/builder_go_slsa3.yml@refs/heads/skip-rekor-upload"},"buildType":"https://github.com/slsa-framework/slsa-github-generator-go@v1","invocation":{"configSource":{"uri":"git+https://github.com/asraa/slsa-on-github-test@refs/heads/main","digest":{"sha1":"31712ebd16092d1d7b5182881840c9885abafd73"},"entryPoint":"Go SLSA Release"},"parameters":{},"environment":{"arch":"X64","github_actor":"asraa","github_base_ref":"","github_event_name":"workflow_dispatch","github_event_payload":{"inputs":null,"ref":"refs/heads/main","repository":{"allow_forking":true,"archive_url":"https://api.github.com/repos/asraa/slsa-on-github-test/{archive_format}{/ref}","archived":false,"assignees_url":"https://api.github.com/repos/asraa/slsa-on-github-test/assignees{/user}","blobs_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/blobs{/sha}","branches_url":"https://api.github.com/repos/asraa/slsa-on-github-test/branches{/branch}","clone_url":"https://github.com/asraa/slsa-on-github-test.git","collaborators_url":"https://api.github.com/repos/asraa/slsa-on-github-test/collaborators{/collaborator}","comments_url":"https://api.github.com/repos/asraa/slsa-on-github-test/comments{/number}","commits_url":"https://api.github.com/repos/asraa/slsa-on-github-test/commits{/sha}","compare_url":"https://api.github.com/repos/asraa/slsa-on-github-test/compare/{base}...{head}","contents_url":"https://api.github.com/repos/asraa/slsa-on-github-test/contents/{+path}","contributors_url":"https://api.github.com/repos/asraa/slsa-on-github-test/contributors","created_at":"2022-02-15T15:33:49Z","default_branch":"main","deployments_url":"https://api.github.com/repos/asraa/slsa-on-github-test/deployments","description":"Test for SLSA","disabled":false,"downloads_url":"https://api.github.com/repos/asraa/slsa-on-github-test/downloads","events_url":"https://api.github.com/repos/asraa/slsa-on-github-test/events","fork":true,"forks":0,"forks_count":0,"forks_url":"https://api.github.com/repos/asraa/slsa-on-github-test/forks","full_name":"asraa/slsa-on-github-test","git_commits_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/commits{/sha}","git_refs_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/refs{/sha}","git_tags_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/tags{/sha}","git_url":"git://github.com/asraa/slsa-on-github-test.git","has_downloads":true,"has_issues":false,"has_pages":false,"has_projects":true,"has_wiki":true,"homepage":null,"hooks_url":"https://api.github.com/repos/asraa/slsa-on-github-test/hooks","html_url":"https://github.com/asraa/slsa-on-github-test","id":459639150,"is_template":false,"issue_comment_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues/comments{/number}","issue_events_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues/events{/number}","issues_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues{/number}","keys_url":"https://api.github.com/repos/asraa/slsa-on-github-test/keys{/key_id}","labels_url":"https://api.github.com/repos/asraa/slsa-on-github-test/labels{/name}","language":"Go","languages_url":"https://api.github.com/repos/asraa/slsa-on-github-test/languages","license":{"key":"apache-2.0","name":"Apache License 2.0","node_id":"MDc6TGljZW5zZTI=","spdx_id":"Apache-2.0","url":"https://api.github.com/licenses/apache-2.0"},"merges_url":"https://api.github.com/repos/asraa/slsa-on-github-test/merges","milestones_url":"https://api.github.com/repos/asraa/slsa-on-github-test/milestones{/number}","mirror_url":null,"name":"slsa-on-github-test","node_id":"R_kgDOG2WJbg","notifications_url":"https://api.github.com/repos/asraa/slsa-on-github-test/notifications{?since,all,participating}","open_issues":0,"open_issues_count":0,"owner":{"avatar_url":"https://avatars.githubusercontent.com/u/5194569?v=4","events_url":"https://api.github.com/users/asraa/events{/privacy}","followers_url":"https://api.github.com/users/asraa/followers","following_url":"https://api.github.com/users/asraa/following{/other_user}","gists_url":"https://api.github.com/users/asraa/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/asraa","id":5194569,"login":"asraa","node_id":"MDQ6VXNlcjUxOTQ1Njk=","organizations_url":"https://api.github.com/users/asraa/orgs","received_events_url":"https://api.github.com/users/asraa/received_events","repos_url":"https://api.github.com/users/asraa/repos","site_admin":false,"starred_url":"https://api.github.com/users/asraa/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/asraa/subscriptions","type":"User","url":"https://api.github.com/users/asraa"},"private":false,"pulls_url":"https://api.github.com/repos/asraa/slsa-on-github-test/pulls{/number}","pushed_at":"2022-05-26T18:15:34Z","releases_url":"https://api.github.com/repos/asraa/slsa-on-github-test/releases{/id}","size":1333,"ssh_url":"git@github.com:asraa/slsa-on-github-test.git","stargazers_count":0,"stargazers_url":"https://api.github.com/repos/asraa/slsa-on-github-test/stargazers","statuses_url":"https://api.github.com/repos/asraa/slsa-on-github-test/statuses/{sha}","subscribers_url":"https://api.github.com/repos/asraa/slsa-on-github-test/subscribers","subscription_url":"https://api.github.com/repos/asraa/slsa-on-github-test/subscription","svn_url":"https://github.com/asraa/slsa-on-github-test","tags_url":"https://api.github.com/repos/asraa/slsa-on-github-test/tags","teams_url":"https://api.github.com/repos/asraa/slsa-on-github-test/teams","topics":[],"trees_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/trees{/sha}","updated_at":"2022-02-15T15:36:41Z","url":"https://api.github.com/repos/asraa/slsa-on-github-test","visibility":"public","watchers":0,"watchers_count":0},"sender":{"avatar_url":"https://avatars.githubusercontent.com/u/5194569?v=4","events_url":"https://api.github.com/users/asraa/events{/privacy}","followers_url":"https://api.github.com/users/asraa/followers","following_url":"https://api.github.com/users/asraa/following{/other_user}","gists_url":"https://api.github.com/users/asraa/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/asraa","id":5194569,"login":"asraa","node_id":"MDQ6VXNlcjUxOTQ1Njk=","organizations_url":"https://api.github.com/users/asraa/orgs","received_events_url":"https://api.github.com/users/asraa/received_events","repos_url":"https://api.github.com/users/asraa/repos","site_admin":false,"starred_url":"https://api.github.com/users/asraa/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/asraa/subscriptions","type":"User","url":"https://api.github.com/users/asraa"},"workflow":".github/workflows/slsa-reusable.yaml"},"github_head_ref":"","github_ref":"refs/heads/main","github_ref_type":"branch","github_run_attempt":"1","github_run_id":"2392356043","github_run_number":"139","github_sha1":"31712ebd16092d1d7b5182881840c9885abafd73","os":"ubuntu20"}},"buildConfig":{"version":1,"steps":[{"command":["/opt/hostedtoolcache/go/1.17.10/x64/bin/go","mod","vendor"],"env":null,"workingDir":"/home/runner/work/slsa-on-github-test/slsa-on-github-test"},{"command":["/opt/hostedtoolcache/go/1.17.10/x64/bin/go","build","-mod=vendor","-trimpath","-tags=netgo","-o","binary-linux-amd64-config1"],"env":["GOOS=linux","GOARCH=amd64","CGO_ENABLED=0","GO111MODULE=on"],"workingDir":"/home/runner/work/slsa-on-github-test/slsa-on-github-test"}]},"metadata":{"buildInvocationID":"2392356043-1","completeness":{"parameters":true,"environment":false,"materials":false},"reproducible":false},"materials":[{"uri":"git+https://github.com/asraa/slsa-on-github-test@refs/heads/main","digest":{"sha1":"31712ebd16092d1d7b5182881840c9885abafd73"}},{"uri":"https://github.com/actions/virtual-environments/releases/tag/ubuntu20/20220515.1"}]}}","signatures":[{"keyid":"","sig":"MEQCIEVFBL2XcHvWXJY63vR+M90gxusTZPs+cCMn9cIE4WL5AiAXBqT40sBw8NMwb9ORkidIbJfJ/Q/SS34XHoiCK9eqBw=="}]} \ No newline at end of file +{"payloadType":"application/vnd.in-toto+json","payload":"{"_type":"https://in-toto.io/Statement/v0.1","predicateType":"https://slsa.dev/provenance/v0.2","subject":[{"name":"binary-linux-amd64","digest":{"sha256":"4bdb495d05cbb9eb0722ec4fcfef8a02d5ca7a2fca0b0fed718447f89d39a589"}}],"predicate":{"builder":{"id":"https://github.com/asraa/slsa-github-generator/.github/workflows/builder_go_slsa3.yml@refs/heads/malicious"},"buildType":"https://github.com/slsa-framework/slsa-github-generator/go@v1","invocation":{"configSource":{"uri":"git+https://github.com/asraa/slsa-on-github-test@refs/heads/main","digest":{"sha1":"06f43f769174a538bf9ea44723d9c6c25ba4278d"},"entryPoint":".github/workflows/slsa-reusable.yaml"},"parameters":{},"environment":{"arch":"X64","github_actor":"asraa","github_actor_id":"5194569","github_base_ref":"","github_event_name":"workflow_dispatch","github_event_payload":{"inputs":null,"ref":"refs/heads/main","repository":{"allow_forking":true,"archive_url":"https://api.github.com/repos/asraa/slsa-on-github-test/{archive_format}{/ref}","archived":false,"assignees_url":"https://api.github.com/repos/asraa/slsa-on-github-test/assignees{/user}","blobs_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/blobs{/sha}","branches_url":"https://api.github.com/repos/asraa/slsa-on-github-test/branches{/branch}","clone_url":"https://github.com/asraa/slsa-on-github-test.git","collaborators_url":"https://api.github.com/repos/asraa/slsa-on-github-test/collaborators{/collaborator}","comments_url":"https://api.github.com/repos/asraa/slsa-on-github-test/comments{/number}","commits_url":"https://api.github.com/repos/asraa/slsa-on-github-test/commits{/sha}","compare_url":"https://api.github.com/repos/asraa/slsa-on-github-test/compare/{base}...{head}","contents_url":"https://api.github.com/repos/asraa/slsa-on-github-test/contents/{+path}","contributors_url":"https://api.github.com/repos/asraa/slsa-on-github-test/contributors","created_at":"2022-06-08T20:07:14Z","default_branch":"main","deployments_url":"https://api.github.com/repos/asraa/slsa-on-github-test/deployments","description":"Test for SLSA","disabled":false,"downloads_url":"https://api.github.com/repos/asraa/slsa-on-github-test/downloads","events_url":"https://api.github.com/repos/asraa/slsa-on-github-test/events","fork":true,"forks":0,"forks_count":0,"forks_url":"https://api.github.com/repos/asraa/slsa-on-github-test/forks","full_name":"asraa/slsa-on-github-test","git_commits_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/commits{/sha}","git_refs_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/refs{/sha}","git_tags_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/tags{/sha}","git_url":"git://github.com/asraa/slsa-on-github-test.git","has_downloads":true,"has_issues":false,"has_pages":false,"has_projects":true,"has_wiki":true,"homepage":null,"hooks_url":"https://api.github.com/repos/asraa/slsa-on-github-test/hooks","html_url":"https://github.com/asraa/slsa-on-github-test","id":501395242,"is_template":false,"issue_comment_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues/comments{/number}","issue_events_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues/events{/number}","issues_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues{/number}","keys_url":"https://api.github.com/repos/asraa/slsa-on-github-test/keys{/key_id}","labels_url":"https://api.github.com/repos/asraa/slsa-on-github-test/labels{/name}","language":"Go","languages_url":"https://api.github.com/repos/asraa/slsa-on-github-test/languages","license":{"key":"apache-2.0","name":"Apache License 2.0","node_id":"MDc6TGljZW5zZTI=","spdx_id":"Apache-2.0","url":"https://api.github.com/licenses/apache-2.0"},"merges_url":"https://api.github.com/repos/asraa/slsa-on-github-test/merges","milestones_url":"https://api.github.com/repos/asraa/slsa-on-github-test/milestones{/number}","mirror_url":null,"name":"slsa-on-github-test","node_id":"R_kgDOHeKvKg","notifications_url":"https://api.github.com/repos/asraa/slsa-on-github-test/notifications{?since,all,participating}","open_issues":0,"open_issues_count":0,"owner":{"avatar_url":"https://avatars.githubusercontent.com/u/5194569?v=4","events_url":"https://api.github.com/users/asraa/events{/privacy}","followers_url":"https://api.github.com/users/asraa/followers","following_url":"https://api.github.com/users/asraa/following{/other_user}","gists_url":"https://api.github.com/users/asraa/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/asraa","id":5194569,"login":"asraa","node_id":"MDQ6VXNlcjUxOTQ1Njk=","organizations_url":"https://api.github.com/users/asraa/orgs","received_events_url":"https://api.github.com/users/asraa/received_events","repos_url":"https://api.github.com/users/asraa/repos","site_admin":false,"starred_url":"https://api.github.com/users/asraa/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/asraa/subscriptions","type":"User","url":"https://api.github.com/users/asraa"},"private":false,"pulls_url":"https://api.github.com/repos/asraa/slsa-on-github-test/pulls{/number}","pushed_at":"2022-06-20T18:48:34Z","releases_url":"https://api.github.com/repos/asraa/slsa-on-github-test/releases{/id}","size":213,"ssh_url":"git@github.com:asraa/slsa-on-github-test.git","stargazers_count":0,"stargazers_url":"https://api.github.com/repos/asraa/slsa-on-github-test/stargazers","statuses_url":"https://api.github.com/repos/asraa/slsa-on-github-test/statuses/{sha}","subscribers_url":"https://api.github.com/repos/asraa/slsa-on-github-test/subscribers","subscription_url":"https://api.github.com/repos/asraa/slsa-on-github-test/subscription","svn_url":"https://github.com/asraa/slsa-on-github-test","tags_url":"https://api.github.com/repos/asraa/slsa-on-github-test/tags","teams_url":"https://api.github.com/repos/asraa/slsa-on-github-test/teams","topics":[],"trees_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/trees{/sha}","updated_at":"2022-06-08T20:09:58Z","url":"https://api.github.com/repos/asraa/slsa-on-github-test","visibility":"public","watchers":0,"watchers_count":0},"sender":{"avatar_url":"https://avatars.githubusercontent.com/u/5194569?v=4","events_url":"https://api.github.com/users/asraa/events{/privacy}","followers_url":"https://api.github.com/users/asraa/followers","following_url":"https://api.github.com/users/asraa/following{/other_user}","gists_url":"https://api.github.com/users/asraa/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/asraa","id":5194569,"login":"asraa","node_id":"MDQ6VXNlcjUxOTQ1Njk=","organizations_url":"https://api.github.com/users/asraa/orgs","received_events_url":"https://api.github.com/users/asraa/received_events","repos_url":"https://api.github.com/users/asraa/repos","site_admin":false,"starred_url":"https://api.github.com/users/asraa/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/asraa/subscriptions","type":"User","url":"https://api.github.com/users/asraa"},"workflow":".github/workflows/slsa-reusable.yaml"},"github_head_ref":"","github_ref":"refs/heads/main","github_ref_type":"branch","github_repository_id":"501395242","github_repository_owner":"asraa","github_repository_owner_id":"5194569","github_run_attempt":"1","github_run_id":"2530946732","github_run_number":"7","github_sha1":"06f43f769174a538bf9ea44723d9c6c25ba4278d","os":"ubuntu20"}},"buildConfig":{"version":1,"steps":[{"command":["/opt/hostedtoolcache/go/1.17.11/x64/bin/go","mod","vendor"],"env":null,"workingDir":"/home/runner/work/slsa-on-github-test/slsa-on-github-test"},{"command":["/opt/hostedtoolcache/go/1.17.11/x64/bin/go","build","-mod=vendor","-trimpath","-tags=netgo","-o","binary-linux-amd64"],"env":["GOOS=linux","GOARCH=amd64","GO111MODULE=on","CGO_ENABLED=0"],"workingDir":"/home/runner/work/slsa-on-github-test/slsa-on-github-test"}]},"metadata":{"buildInvocationID":"2530946732-1","completeness":{"parameters":true,"environment":false,"materials":false},"reproducible":false},"materials":[{"uri":"git+https://github.com/asraa/slsa-on-github-test@refs/heads/main","digest":{"sha1":"06f43f769174a538bf9ea44723d9c6c25ba4278d"}},{"uri":"https://github.com/actions/virtual-environments/releases/tag/ubuntu20/20220614.0"}]}}","signatures":[{"keyid":"","sig":"MEQCIFxbDH+ROTY4Oijjz4grA/AiQ4WpTsPWOKwPCEOyrsJAAiBZspaE1lzdeVJtmpLisSF8c/9fhBu8iNxA+4FAm6vVKw==","cert":"-----BEGIN CERTIFICATE-----\nMIIDOTCCAr+gAwIBAgITCqi/mZEnDsfSoI2sP9Ne5y6nBDAKBggqhkjOPQQDAzAq\nMRUwEwYDVQQKEwxzaWdzdG9yZS5kZXYxETAPBgNVBAMTCHNpZ3N0b3JlMB4XDTIy\nMDYyMDE4NTQwOFoXDTIyMDYyMDE5MDQwN1owADBZMBMGByqGSM49AgEGCCqGSM49\nAwEHA0IABJJ1vs77+bu4wo9LmKjAiBtaMFJkd6zG1sI79Za5mZ0gviYm867P+oUK\nyE57iP0corI9A+v8eNTM/wX2KGEIz4OjggHsMIIB6DAOBgNVHQ8BAf8EBAMCB4Aw\nEwYDVR0lBAwwCgYIKwYBBQUHAwMwDAYDVR0TAQH/BAIwADAdBgNVHQ4EFgQUdAxL\nZzwvDUhn7Qj+RRdCQ3FLPXUwHwYDVR0jBBgwFoAUWMAeX5FFpWapesyQoZMi0CrF\nxfoweAYDVR0RAQH/BG4wbIZqaHR0cHM6Ly9naXRodWIuY29tL2FzcmFhL3Nsc2Et\nZ2l0aHViLWdlbmVyYXRvci8uZ2l0aHViL3dvcmtmbG93cy9idWlsZGVyX2dvX3Ns\nc2EzLnltbEByZWZzL2hlYWRzL21hbGljaW91czA5BgorBgEEAYO/MAEBBCtodHRw\nczovL3Rva2VuLmFjdGlvbnMuZ2l0aHVidXNlcmNvbnRlbnQuY29tMB8GCisGAQQB\ng78wAQIEEXdvcmtmbG93X2Rpc3BhdGNoMB0GCisGAQQBg78wAQQED0dvIFNMU0Eg\nUmVsZWFzZTAnBgorBgEEAYO/MAEFBBlhc3JhYS9zbHNhLW9uLWdpdGh1Yi10ZXN0\nMB0GCisGAQQBg78wAQYED3JlZnMvaGVhZHMvbWFpbjA2BgorBgEEAYO/MAEDBCgw\nNmY0M2Y3NjkxNzRhNTM4YmY5ZWE0NDcyM2Q5YzZjMjViYTQyNzhkMAoGCCqGSM49\nBAMDA2gAMGUCMQCMhL/++CRob3nVLRhotO7CzolgN6/asR849n1t3Z960wjob/TC\nn+u44qMfBGZN1AcCMBX1KoBcqdaQsTC+1MJnaMHqF90jqsZ6dtByb2HVL7u8rIpz\nHzxVLvzGlSM/7BuGtw==\n-----END CERTIFICATE-----\n"}]} \ No newline at end of file diff --git a/testdata/binary-linux-amd64-untrusted-builder b/testdata/binary-linux-amd64-untrusted-builder index a54cec7..4eca6fd 100644 Binary files a/testdata/binary-linux-amd64-untrusted-builder and b/testdata/binary-linux-amd64-untrusted-builder differ diff --git a/testdata/binary-linux-amd64-untrusted-builder.intoto.jsonl b/testdata/binary-linux-amd64-untrusted-builder.intoto.jsonl index c4ebfed..0e76399 100644 --- a/testdata/binary-linux-amd64-untrusted-builder.intoto.jsonl +++ b/testdata/binary-linux-amd64-untrusted-builder.intoto.jsonl @@ -1 +1 @@ -{"payloadType":"application/vnd.in-toto+json","payload":"{"_type":"https://in-toto.io/Statement/v0.1","predicateType":"https://slsa.dev/provenance/v0.2","subject":[{"name":"binary-linux-amd64-config1","digest":{"sha256":"b1cca12c4e06d9036dfa7c64a5c0f2f90e3ae2ec7a809021bbf6ca67f25e7be8"}}],"predicate":{"builder":{"id":"https://github.com/asraa/slsa-github-generator/.github/workflows/builder_go_slsa3.yml@refs/heads/main"},"buildType":"https://github.com/slsa-framework/slsa-github-generator-go@v1","invocation":{"configSource":{"uri":"git+https://github.com/asraa/slsa-on-github-test@refs/heads/main","digest":{"sha1":"a5eec6f2de69d6cbb58ae751fcb6d52924f193b8"},"entryPoint":"Go SLSA Release"},"parameters":{},"environment":{"arch":"X64","github_actor":"asraa","github_base_ref":"","github_event_name":"workflow_dispatch","github_event_payload":{"inputs":null,"ref":"refs/heads/main","repository":{"allow_forking":true,"archive_url":"https://api.github.com/repos/asraa/slsa-on-github-test/{archive_format}{/ref}","archived":false,"assignees_url":"https://api.github.com/repos/asraa/slsa-on-github-test/assignees{/user}","blobs_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/blobs{/sha}","branches_url":"https://api.github.com/repos/asraa/slsa-on-github-test/branches{/branch}","clone_url":"https://github.com/asraa/slsa-on-github-test.git","collaborators_url":"https://api.github.com/repos/asraa/slsa-on-github-test/collaborators{/collaborator}","comments_url":"https://api.github.com/repos/asraa/slsa-on-github-test/comments{/number}","commits_url":"https://api.github.com/repos/asraa/slsa-on-github-test/commits{/sha}","compare_url":"https://api.github.com/repos/asraa/slsa-on-github-test/compare/{base}...{head}","contents_url":"https://api.github.com/repos/asraa/slsa-on-github-test/contents/{+path}","contributors_url":"https://api.github.com/repos/asraa/slsa-on-github-test/contributors","created_at":"2022-02-15T15:33:49Z","default_branch":"main","deployments_url":"https://api.github.com/repos/asraa/slsa-on-github-test/deployments","description":"Test for SLSA","disabled":false,"downloads_url":"https://api.github.com/repos/asraa/slsa-on-github-test/downloads","events_url":"https://api.github.com/repos/asraa/slsa-on-github-test/events","fork":true,"forks":0,"forks_count":0,"forks_url":"https://api.github.com/repos/asraa/slsa-on-github-test/forks","full_name":"asraa/slsa-on-github-test","git_commits_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/commits{/sha}","git_refs_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/refs{/sha}","git_tags_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/tags{/sha}","git_url":"git://github.com/asraa/slsa-on-github-test.git","has_downloads":true,"has_issues":false,"has_pages":false,"has_projects":true,"has_wiki":true,"homepage":null,"hooks_url":"https://api.github.com/repos/asraa/slsa-on-github-test/hooks","html_url":"https://github.com/asraa/slsa-on-github-test","id":459639150,"is_template":false,"issue_comment_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues/comments{/number}","issue_events_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues/events{/number}","issues_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues{/number}","keys_url":"https://api.github.com/repos/asraa/slsa-on-github-test/keys{/key_id}","labels_url":"https://api.github.com/repos/asraa/slsa-on-github-test/labels{/name}","language":"Go","languages_url":"https://api.github.com/repos/asraa/slsa-on-github-test/languages","license":{"key":"apache-2.0","name":"Apache License 2.0","node_id":"MDc6TGljZW5zZTI=","spdx_id":"Apache-2.0","url":"https://api.github.com/licenses/apache-2.0"},"merges_url":"https://api.github.com/repos/asraa/slsa-on-github-test/merges","milestones_url":"https://api.github.com/repos/asraa/slsa-on-github-test/milestones{/number}","mirror_url":null,"name":"slsa-on-github-test","node_id":"R_kgDOG2WJbg","notifications_url":"https://api.github.com/repos/asraa/slsa-on-github-test/notifications{?since,all,participating}","open_issues":0,"open_issues_count":0,"owner":{"avatar_url":"https://avatars.githubusercontent.com/u/5194569?v=4","events_url":"https://api.github.com/users/asraa/events{/privacy}","followers_url":"https://api.github.com/users/asraa/followers","following_url":"https://api.github.com/users/asraa/following{/other_user}","gists_url":"https://api.github.com/users/asraa/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/asraa","id":5194569,"login":"asraa","node_id":"MDQ6VXNlcjUxOTQ1Njk=","organizations_url":"https://api.github.com/users/asraa/orgs","received_events_url":"https://api.github.com/users/asraa/received_events","repos_url":"https://api.github.com/users/asraa/repos","site_admin":false,"starred_url":"https://api.github.com/users/asraa/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/asraa/subscriptions","type":"User","url":"https://api.github.com/users/asraa"},"private":false,"pulls_url":"https://api.github.com/repos/asraa/slsa-on-github-test/pulls{/number}","pushed_at":"2022-05-26T20:37:16Z","releases_url":"https://api.github.com/repos/asraa/slsa-on-github-test/releases{/id}","size":1336,"ssh_url":"git@github.com:asraa/slsa-on-github-test.git","stargazers_count":0,"stargazers_url":"https://api.github.com/repos/asraa/slsa-on-github-test/stargazers","statuses_url":"https://api.github.com/repos/asraa/slsa-on-github-test/statuses/{sha}","subscribers_url":"https://api.github.com/repos/asraa/slsa-on-github-test/subscribers","subscription_url":"https://api.github.com/repos/asraa/slsa-on-github-test/subscription","svn_url":"https://github.com/asraa/slsa-on-github-test","tags_url":"https://api.github.com/repos/asraa/slsa-on-github-test/tags","teams_url":"https://api.github.com/repos/asraa/slsa-on-github-test/teams","topics":[],"trees_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/trees{/sha}","updated_at":"2022-02-15T15:36:41Z","url":"https://api.github.com/repos/asraa/slsa-on-github-test","visibility":"public","watchers":0,"watchers_count":0},"sender":{"avatar_url":"https://avatars.githubusercontent.com/u/5194569?v=4","events_url":"https://api.github.com/users/asraa/events{/privacy}","followers_url":"https://api.github.com/users/asraa/followers","following_url":"https://api.github.com/users/asraa/following{/other_user}","gists_url":"https://api.github.com/users/asraa/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/asraa","id":5194569,"login":"asraa","node_id":"MDQ6VXNlcjUxOTQ1Njk=","organizations_url":"https://api.github.com/users/asraa/orgs","received_events_url":"https://api.github.com/users/asraa/received_events","repos_url":"https://api.github.com/users/asraa/repos","site_admin":false,"starred_url":"https://api.github.com/users/asraa/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/asraa/subscriptions","type":"User","url":"https://api.github.com/users/asraa"},"workflow":".github/workflows/slsa-reusable.yaml"},"github_head_ref":"","github_ref":"refs/heads/main","github_ref_type":"branch","github_run_attempt":"1","github_run_id":"2393004688","github_run_number":"142","github_sha1":"a5eec6f2de69d6cbb58ae751fcb6d52924f193b8","os":"ubuntu20"}},"buildConfig":{"version":1,"steps":[{"command":["/opt/hostedtoolcache/go/1.17.10/x64/bin/go","mod","vendor"],"env":null,"workingDir":"/home/runner/work/slsa-on-github-test/slsa-on-github-test"},{"command":["/opt/hostedtoolcache/go/1.17.10/x64/bin/go","build","-mod=vendor","-trimpath","-tags=netgo","-o","binary-linux-amd64-config1"],"env":["GOOS=linux","GOARCH=amd64","GO111MODULE=on","CGO_ENABLED=0"],"workingDir":"/home/runner/work/slsa-on-github-test/slsa-on-github-test"}]},"metadata":{"buildInvocationID":"2393004688-1","completeness":{"parameters":true,"environment":false,"materials":false},"reproducible":false},"materials":[{"uri":"git+https://github.com/asraa/slsa-on-github-test@refs/heads/main","digest":{"sha1":"a5eec6f2de69d6cbb58ae751fcb6d52924f193b8"}},{"uri":"https://github.com/actions/virtual-environments/releases/tag/ubuntu20/20220515.1"}]}}","signatures":[{"keyid":"","sig":"MEYCIQD9+lMlX4thcbxGL2Gdv5PQqoLd3QErI+PBP90fWQudyAIhAK9nhI4eoCKnkA7ludYA5E7BbEcr8huQcgvNJtk+tni/"}]} \ No newline at end of file +{"payloadType":"application/vnd.in-toto+json","payload":"{"_type":"https://in-toto.io/Statement/v0.1","predicateType":"https://slsa.dev/provenance/v0.2","subject":[{"name":"binary-linux-amd64","digest":{"sha256":"4bdb495d05cbb9eb0722ec4fcfef8a02d5ca7a2fca0b0fed718447f89d39a589"}}],"predicate":{"builder":{"id":"https://github.com/asraa/slsa-github-generator/.github/workflows/builder_go_slsa3.yml@refs/heads/malicious"},"buildType":"https://github.com/slsa-framework/slsa-github-generator/go@v1","invocation":{"configSource":{"uri":"git+https://github.com/asraa/slsa-on-github-test@refs/heads/main","digest":{"sha1":"06f43f769174a538bf9ea44723d9c6c25ba4278d"},"entryPoint":".github/workflows/slsa-reusable.yaml"},"parameters":{},"environment":{"arch":"X64","github_actor":"asraa","github_actor_id":"5194569","github_base_ref":"","github_event_name":"workflow_dispatch","github_event_payload":{"inputs":null,"ref":"refs/heads/main","repository":{"allow_forking":true,"archive_url":"https://api.github.com/repos/asraa/slsa-on-github-test/{archive_format}{/ref}","archived":false,"assignees_url":"https://api.github.com/repos/asraa/slsa-on-github-test/assignees{/user}","blobs_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/blobs{/sha}","branches_url":"https://api.github.com/repos/asraa/slsa-on-github-test/branches{/branch}","clone_url":"https://github.com/asraa/slsa-on-github-test.git","collaborators_url":"https://api.github.com/repos/asraa/slsa-on-github-test/collaborators{/collaborator}","comments_url":"https://api.github.com/repos/asraa/slsa-on-github-test/comments{/number}","commits_url":"https://api.github.com/repos/asraa/slsa-on-github-test/commits{/sha}","compare_url":"https://api.github.com/repos/asraa/slsa-on-github-test/compare/{base}...{head}","contents_url":"https://api.github.com/repos/asraa/slsa-on-github-test/contents/{+path}","contributors_url":"https://api.github.com/repos/asraa/slsa-on-github-test/contributors","created_at":"2022-06-08T20:07:14Z","default_branch":"main","deployments_url":"https://api.github.com/repos/asraa/slsa-on-github-test/deployments","description":"Test for SLSA","disabled":false,"downloads_url":"https://api.github.com/repos/asraa/slsa-on-github-test/downloads","events_url":"https://api.github.com/repos/asraa/slsa-on-github-test/events","fork":true,"forks":0,"forks_count":0,"forks_url":"https://api.github.com/repos/asraa/slsa-on-github-test/forks","full_name":"asraa/slsa-on-github-test","git_commits_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/commits{/sha}","git_refs_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/refs{/sha}","git_tags_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/tags{/sha}","git_url":"git://github.com/asraa/slsa-on-github-test.git","has_downloads":true,"has_issues":false,"has_pages":false,"has_projects":true,"has_wiki":true,"homepage":null,"hooks_url":"https://api.github.com/repos/asraa/slsa-on-github-test/hooks","html_url":"https://github.com/asraa/slsa-on-github-test","id":501395242,"is_template":false,"issue_comment_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues/comments{/number}","issue_events_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues/events{/number}","issues_url":"https://api.github.com/repos/asraa/slsa-on-github-test/issues{/number}","keys_url":"https://api.github.com/repos/asraa/slsa-on-github-test/keys{/key_id}","labels_url":"https://api.github.com/repos/asraa/slsa-on-github-test/labels{/name}","language":"Go","languages_url":"https://api.github.com/repos/asraa/slsa-on-github-test/languages","license":{"key":"apache-2.0","name":"Apache License 2.0","node_id":"MDc6TGljZW5zZTI=","spdx_id":"Apache-2.0","url":"https://api.github.com/licenses/apache-2.0"},"merges_url":"https://api.github.com/repos/asraa/slsa-on-github-test/merges","milestones_url":"https://api.github.com/repos/asraa/slsa-on-github-test/milestones{/number}","mirror_url":null,"name":"slsa-on-github-test","node_id":"R_kgDOHeKvKg","notifications_url":"https://api.github.com/repos/asraa/slsa-on-github-test/notifications{?since,all,participating}","open_issues":0,"open_issues_count":0,"owner":{"avatar_url":"https://avatars.githubusercontent.com/u/5194569?v=4","events_url":"https://api.github.com/users/asraa/events{/privacy}","followers_url":"https://api.github.com/users/asraa/followers","following_url":"https://api.github.com/users/asraa/following{/other_user}","gists_url":"https://api.github.com/users/asraa/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/asraa","id":5194569,"login":"asraa","node_id":"MDQ6VXNlcjUxOTQ1Njk=","organizations_url":"https://api.github.com/users/asraa/orgs","received_events_url":"https://api.github.com/users/asraa/received_events","repos_url":"https://api.github.com/users/asraa/repos","site_admin":false,"starred_url":"https://api.github.com/users/asraa/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/asraa/subscriptions","type":"User","url":"https://api.github.com/users/asraa"},"private":false,"pulls_url":"https://api.github.com/repos/asraa/slsa-on-github-test/pulls{/number}","pushed_at":"2022-06-20T18:48:34Z","releases_url":"https://api.github.com/repos/asraa/slsa-on-github-test/releases{/id}","size":213,"ssh_url":"git@github.com:asraa/slsa-on-github-test.git","stargazers_count":0,"stargazers_url":"https://api.github.com/repos/asraa/slsa-on-github-test/stargazers","statuses_url":"https://api.github.com/repos/asraa/slsa-on-github-test/statuses/{sha}","subscribers_url":"https://api.github.com/repos/asraa/slsa-on-github-test/subscribers","subscription_url":"https://api.github.com/repos/asraa/slsa-on-github-test/subscription","svn_url":"https://github.com/asraa/slsa-on-github-test","tags_url":"https://api.github.com/repos/asraa/slsa-on-github-test/tags","teams_url":"https://api.github.com/repos/asraa/slsa-on-github-test/teams","topics":[],"trees_url":"https://api.github.com/repos/asraa/slsa-on-github-test/git/trees{/sha}","updated_at":"2022-06-08T20:09:58Z","url":"https://api.github.com/repos/asraa/slsa-on-github-test","visibility":"public","watchers":0,"watchers_count":0},"sender":{"avatar_url":"https://avatars.githubusercontent.com/u/5194569?v=4","events_url":"https://api.github.com/users/asraa/events{/privacy}","followers_url":"https://api.github.com/users/asraa/followers","following_url":"https://api.github.com/users/asraa/following{/other_user}","gists_url":"https://api.github.com/users/asraa/gists{/gist_id}","gravatar_id":"","html_url":"https://github.com/asraa","id":5194569,"login":"asraa","node_id":"MDQ6VXNlcjUxOTQ1Njk=","organizations_url":"https://api.github.com/users/asraa/orgs","received_events_url":"https://api.github.com/users/asraa/received_events","repos_url":"https://api.github.com/users/asraa/repos","site_admin":false,"starred_url":"https://api.github.com/users/asraa/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/asraa/subscriptions","type":"User","url":"https://api.github.com/users/asraa"},"workflow":".github/workflows/slsa-reusable.yaml"},"github_head_ref":"","github_ref":"refs/heads/main","github_ref_type":"branch","github_repository_id":"501395242","github_repository_owner":"asraa","github_repository_owner_id":"5194569","github_run_attempt":"1","github_run_id":"2530954110","github_run_number":"8","github_sha1":"06f43f769174a538bf9ea44723d9c6c25ba4278d","os":"ubuntu20"}},"buildConfig":{"version":1,"steps":[{"command":["/opt/hostedtoolcache/go/1.17.11/x64/bin/go","mod","vendor"],"env":null,"workingDir":"/home/runner/work/slsa-on-github-test/slsa-on-github-test"},{"command":["/opt/hostedtoolcache/go/1.17.11/x64/bin/go","build","-mod=vendor","-trimpath","-tags=netgo","-o","binary-linux-amd64"],"env":["GOOS=linux","GOARCH=amd64","GO111MODULE=on","CGO_ENABLED=0"],"workingDir":"/home/runner/work/slsa-on-github-test/slsa-on-github-test"}]},"metadata":{"buildInvocationID":"2530954110-1","completeness":{"parameters":true,"environment":false,"materials":false},"reproducible":false},"materials":[{"uri":"git+https://github.com/asraa/slsa-on-github-test@refs/heads/main","digest":{"sha1":"06f43f769174a538bf9ea44723d9c6c25ba4278d"}},{"uri":"https://github.com/actions/virtual-environments/releases/tag/ubuntu20/20220614.0"}]}}","signatures":[{"keyid":"","sig":"MEYCIQCKGlBGnPQS7My8f9RedITm7aWyz1qzEYEc2APUfHbboQIhAN+yVB9QiwTGvwn0pd56wEHVvyG5hv3fsio5krJwZnOM","cert":"-----BEGIN CERTIFICATE-----\nMIIDOjCCAr+gAwIBAgITBR44z6V2n9ZJuu6lzMXOGZgj3jAKBggqhkjOPQQDAzAq\nMRUwEwYDVQQKEwxzaWdzdG9yZS5kZXYxETAPBgNVBAMTCHNpZ3N0b3JlMB4XDTIy\nMDYyMDE4NTUyN1oXDTIyMDYyMDE5MDUyNlowADBZMBMGByqGSM49AgEGCCqGSM49\nAwEHA0IABPh653iEaeB/Xscg59gVZ1iLQFxNzk8pb/KSe6dQllyR5FTtBNoLrzal\nkdUNltmd9SBHzq6XVNKbi3uUjxwRW9WjggHsMIIB6DAOBgNVHQ8BAf8EBAMCB4Aw\nEwYDVR0lBAwwCgYIKwYBBQUHAwMwDAYDVR0TAQH/BAIwADAdBgNVHQ4EFgQUr6ts\nHqoUM500XOCg2q40D5tdXnEwHwYDVR0jBBgwFoAUWMAeX5FFpWapesyQoZMi0CrF\nxfoweAYDVR0RAQH/BG4wbIZqaHR0cHM6Ly9naXRodWIuY29tL2FzcmFhL3Nsc2Et\nZ2l0aHViLWdlbmVyYXRvci8uZ2l0aHViL3dvcmtmbG93cy9idWlsZGVyX2dvX3Ns\nc2EzLnltbEByZWZzL2hlYWRzL21hbGljaW91czA2BgorBgEEAYO/MAEDBCgwNmY0\nM2Y3NjkxNzRhNTM4YmY5ZWE0NDcyM2Q5YzZjMjViYTQyNzhkMB8GCisGAQQBg78w\nAQIEEXdvcmtmbG93X2Rpc3BhdGNoMDkGCisGAQQBg78wAQEEK2h0dHBzOi8vdG9r\nZW4uYWN0aW9ucy5naXRodWJ1c2VyY29udGVudC5jb20wJwYKKwYBBAGDvzABBQQZ\nYXNyYWEvc2xzYS1vbi1naXRodWItdGVzdDAdBgorBgEEAYO/MAEEBA9HbyBTTFNB\nIFJlbGVhc2UwHQYKKwYBBAGDvzABBgQPcmVmcy9oZWFkcy9tYWluMAoGCCqGSM49\nBAMDA2kAMGYCMQC40a/bf/vbtNkm721irzoDaRBbxXjixe9cdrxOmpPn6sdrI9MH\nPceK4VXL3vsHHh4CMQCXDFtE94cSDTxWLL2kZ/7CYRkBbC05CDrGyzs4iLY/Ub+e\n75ktXAYALP+SsHam/2I=\n-----END CERTIFICATE-----\n"}]} \ No newline at end of file