From e7a988b2cd3e135d3482cc20146f1de8cac38026 Mon Sep 17 00:00:00 2001 From: Herman Slatman Date: Sat, 13 Nov 2021 00:46:34 +0100 Subject: [PATCH 1/2] Pin golangci-lint to v1.43.0 and fix issues --- .github/workflows/test.yml | 2 +- .golangci.yml | 6 ---- acme/api/account_test.go | 8 ++--- acme/api/handler.go | 2 +- acme/api/handler_test.go | 10 +++--- acme/api/middleware.go | 6 ++-- acme/api/middleware_test.go | 19 +++++------ acme/api/order_test.go | 8 ++--- acme/challenge.go | 4 +-- acme/challenge_test.go | 11 +++---- api/api_test.go | 24 +++++++------- api/revoke_test.go | 4 +-- api/ssh_test.go | 42 ++++++++++++------------ api/utils.go | 3 +- authority/authority_test.go | 8 ++--- authority/export.go | 4 +-- authority/provisioner/aws.go | 11 ++++--- authority/provisioner/azure.go | 4 +-- authority/provisioner/azure_test.go | 2 +- authority/provisioner/gcp.go | 4 +-- authority/provisioner/utils_test.go | 10 +++--- authority/provisioners.go | 6 ++-- authority/tls_test.go | 18 +++++----- ca/acmeClient.go | 5 ++- ca/acmeClient_test.go | 20 +++++------ ca/adminClient.go | 10 +++--- ca/bootstrap_test.go | 10 +++--- ca/ca_test.go | 12 +++---- ca/client.go | 7 ++-- ca/identity/client.go | 6 ++-- ca/identity/client_test.go | 6 ++-- ca/identity/identity.go | 13 ++++---- ca/provisioner_test.go | 4 +-- ca/renew.go | 26 +++++++-------- ca/tls_options_test.go | 20 +++++------ ca/tls_test.go | 10 +++--- cas/stepcas/stepcas_test.go | 4 +-- commands/app.go | 9 +++-- commands/export.go | 6 ++-- examples/basic-federation/client/main.go | 4 +-- examples/bootstrap-client/client.go | 4 +-- kms/cloudkms/cloudkms_test.go | 8 ++--- kms/cloudkms/signer_test.go | 8 ++--- kms/softkms/softkms_test.go | 8 ++--- kms/sshagentkms/sshagentkms_test.go | 15 ++++----- kms/uri/uri.go | 4 +-- scep/api/api.go | 3 +- templates/templates.go | 3 +- 48 files changed, 213 insertions(+), 228 deletions(-) diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 96655664..bfc861c7 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -33,7 +33,7 @@ jobs: uses: golangci/golangci-lint-action@v2 with: # Optional: version of golangci-lint to use in form of v1.2 or v1.2.3 or `latest` to use the latest version - version: 'latest' + version: 'v1.43.0' # Optional: working directory, useful for monorepos # working-directory: somedir diff --git a/.golangci.yml b/.golangci.yml index cf389517..67aac2df 100644 --- a/.golangci.yml +++ b/.golangci.yml @@ -73,9 +73,3 @@ issues: - error strings should not be capitalized or end with punctuation or a newline - Wrapf call needs 1 arg but has 2 args - cs.NegotiatedProtocolIsMutual is deprecated -# golangci.com configuration -# https://github.com/golangci/golangci/wiki/Configuration -service: - golangci-lint-version: 1.19.x # use the fixed version to not introduce new linters unexpectedly - prepare: - - echo "here I can run custom commands, but no preparation needed for this repo" diff --git a/acme/api/account_test.go b/acme/api/account_test.go index a45751a0..abee97a2 100644 --- a/acme/api/account_test.go +++ b/acme/api/account_test.go @@ -5,7 +5,7 @@ import ( "context" "encoding/json" "fmt" - "io/ioutil" + "io" "net/http/httptest" "net/url" "testing" @@ -263,7 +263,7 @@ func TestHandler_GetOrdersByAccountID(t *testing.T) { assert.Equals(t, res.StatusCode, tc.statusCode) - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() assert.FatalError(t, err) @@ -468,7 +468,7 @@ func TestHandler_NewAccount(t *testing.T) { assert.Equals(t, res.StatusCode, tc.statusCode) - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() assert.FatalError(t, err) @@ -668,7 +668,7 @@ func TestHandler_GetOrUpdateAccount(t *testing.T) { assert.Equals(t, res.StatusCode, tc.statusCode) - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() assert.FatalError(t, err) diff --git a/acme/api/handler.go b/acme/api/handler.go index b05bd0c4..394986e1 100644 --- a/acme/api/handler.go +++ b/acme/api/handler.go @@ -17,7 +17,7 @@ import ( ) func link(url, typ string) string { - return fmt.Sprintf("<%s>;rel=\"%s\"", url, typ) + return fmt.Sprintf("<%s>;rel=%q", url, typ) } // Clock that returns time in UTC rounded to seconds. diff --git a/acme/api/handler_test.go b/acme/api/handler_test.go index 8112ad4c..14e00f12 100644 --- a/acme/api/handler_test.go +++ b/acme/api/handler_test.go @@ -7,7 +7,7 @@ import ( "encoding/json" "encoding/pem" "fmt" - "io/ioutil" + "io" "net/http" "net/http/httptest" "net/url" @@ -89,7 +89,7 @@ func TestHandler_GetDirectory(t *testing.T) { assert.Equals(t, res.StatusCode, tc.statusCode) - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() assert.FatalError(t, err) @@ -261,7 +261,7 @@ func TestHandler_GetAuthorization(t *testing.T) { assert.Equals(t, res.StatusCode, tc.statusCode) - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() assert.FatalError(t, err) @@ -404,7 +404,7 @@ func TestHandler_GetCertificate(t *testing.T) { assert.Equals(t, res.StatusCode, tc.statusCode) - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() assert.FatalError(t, err) @@ -660,7 +660,7 @@ func TestHandler_GetChallenge(t *testing.T) { assert.Equals(t, res.StatusCode, tc.statusCode) - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() assert.FatalError(t, err) diff --git a/acme/api/middleware.go b/acme/api/middleware.go index bc67dbc6..be531ca8 100644 --- a/acme/api/middleware.go +++ b/acme/api/middleware.go @@ -4,7 +4,7 @@ import ( "context" "crypto/rsa" "errors" - "io/ioutil" + "io" "net/http" "net/url" "strings" @@ -118,7 +118,7 @@ func (h *Handler) verifyContentType(next nextHTTP) nextHTTP { // parseJWS is a middleware that parses a request body into a JSONWebSignature struct. func (h *Handler) parseJWS(next nextHTTP) nextHTTP { return func(w http.ResponseWriter, r *http.Request) { - body, err := ioutil.ReadAll(r.Body) + body, err := io.ReadAll(r.Body) if err != nil { api.WriteError(w, acme.WrapErrorISE(err, "failed to read request body")) return @@ -378,7 +378,7 @@ func (h *Handler) verifyAndExtractJWSPayload(next nextHTTP) nextHTTP { } ctx = context.WithValue(ctx, payloadContextKey, &payloadInfo{ value: payload, - isPostAsGet: string(payload) == "", + isPostAsGet: len(payload) == 0, isEmptyJSON: string(payload) == "{}", }) next(w, r.WithContext(ctx)) diff --git a/acme/api/middleware_test.go b/acme/api/middleware_test.go index e8d22d53..9b36d316 100644 --- a/acme/api/middleware_test.go +++ b/acme/api/middleware_test.go @@ -8,7 +8,6 @@ import ( "encoding/json" "fmt" "io" - "io/ioutil" "net/http" "net/http/httptest" "net/url" @@ -148,7 +147,7 @@ func TestHandler_addNonce(t *testing.T) { assert.Equals(t, res.StatusCode, tc.statusCode) - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() assert.FatalError(t, err) @@ -205,7 +204,7 @@ func TestHandler_addDirLink(t *testing.T) { assert.Equals(t, res.StatusCode, tc.statusCode) - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() assert.FatalError(t, err) @@ -332,7 +331,7 @@ func TestHandler_verifyContentType(t *testing.T) { assert.Equals(t, res.StatusCode, tc.statusCode) - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() assert.FatalError(t, err) @@ -400,7 +399,7 @@ func TestHandler_isPostAsGet(t *testing.T) { assert.Equals(t, res.StatusCode, tc.statusCode) - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() assert.FatalError(t, err) @@ -490,7 +489,7 @@ func TestHandler_parseJWS(t *testing.T) { assert.Equals(t, res.StatusCode, tc.statusCode) - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() assert.FatalError(t, err) @@ -689,7 +688,7 @@ func TestHandler_verifyAndExtractJWSPayload(t *testing.T) { assert.Equals(t, res.StatusCode, tc.statusCode) - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() assert.FatalError(t, err) @@ -891,7 +890,7 @@ func TestHandler_lookupJWK(t *testing.T) { assert.Equals(t, res.StatusCode, tc.statusCode) - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() assert.FatalError(t, err) @@ -1087,7 +1086,7 @@ func TestHandler_extractJWK(t *testing.T) { assert.Equals(t, res.StatusCode, tc.statusCode) - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() assert.FatalError(t, err) @@ -1454,7 +1453,7 @@ func TestHandler_validateJWS(t *testing.T) { assert.Equals(t, res.StatusCode, tc.statusCode) - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() assert.FatalError(t, err) diff --git a/acme/api/order_test.go b/acme/api/order_test.go index 3c6d768f..1ce034e7 100644 --- a/acme/api/order_test.go +++ b/acme/api/order_test.go @@ -7,7 +7,7 @@ import ( "encoding/base64" "encoding/json" "fmt" - "io/ioutil" + "io" "net/http/httptest" "net/url" "reflect" @@ -430,7 +430,7 @@ func TestHandler_GetOrder(t *testing.T) { assert.Equals(t, res.StatusCode, tc.statusCode) - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() assert.FatalError(t, err) @@ -1343,7 +1343,7 @@ func TestHandler_NewOrder(t *testing.T) { assert.Equals(t, res.StatusCode, tc.statusCode) - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() assert.FatalError(t, err) @@ -1633,7 +1633,7 @@ func TestHandler_FinalizeOrder(t *testing.T) { assert.Equals(t, res.StatusCode, tc.statusCode) - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() assert.FatalError(t, err) diff --git a/acme/challenge.go b/acme/challenge.go index b880708c..bfe1937d 100644 --- a/acme/challenge.go +++ b/acme/challenge.go @@ -12,7 +12,7 @@ import ( "encoding/json" "errors" "fmt" - "io/ioutil" + "io" "net" "net/http" "net/url" @@ -89,7 +89,7 @@ func http01Validate(ctx context.Context, ch *Challenge, db DB, jwk *jose.JSONWeb "error doing http GET for url %s with status code %d", u, resp.StatusCode)) } - body, err := ioutil.ReadAll(resp.Body) + body, err := io.ReadAll(resp.Body) if err != nil { return WrapErrorISE(err, "error reading "+ "response body for url %s", u) diff --git a/acme/challenge_test.go b/acme/challenge_test.go index a522790f..d8ce4d76 100644 --- a/acme/challenge_test.go +++ b/acme/challenge_test.go @@ -15,7 +15,6 @@ import ( "encoding/hex" "fmt" "io" - "io/ioutil" "math/big" "net" "net/http" @@ -707,7 +706,7 @@ func TestHTTP01Validate(t *testing.T) { vo: &ValidateChallengeOptions{ HTTPGet: func(url string) (*http.Response, error) { return &http.Response{ - Body: ioutil.NopCloser(bytes.NewBufferString("foo")), + Body: io.NopCloser(bytes.NewBufferString("foo")), }, nil }, }, @@ -733,7 +732,7 @@ func TestHTTP01Validate(t *testing.T) { vo: &ValidateChallengeOptions{ HTTPGet: func(url string) (*http.Response, error) { return &http.Response{ - Body: ioutil.NopCloser(bytes.NewBufferString("foo")), + Body: io.NopCloser(bytes.NewBufferString("foo")), }, nil }, }, @@ -775,7 +774,7 @@ func TestHTTP01Validate(t *testing.T) { vo: &ValidateChallengeOptions{ HTTPGet: func(url string) (*http.Response, error) { return &http.Response{ - Body: ioutil.NopCloser(bytes.NewBufferString("foo")), + Body: io.NopCloser(bytes.NewBufferString("foo")), }, nil }, }, @@ -818,7 +817,7 @@ func TestHTTP01Validate(t *testing.T) { vo: &ValidateChallengeOptions{ HTTPGet: func(url string) (*http.Response, error) { return &http.Response{ - Body: ioutil.NopCloser(bytes.NewBufferString(expKeyAuth)), + Body: io.NopCloser(bytes.NewBufferString(expKeyAuth)), }, nil }, }, @@ -860,7 +859,7 @@ func TestHTTP01Validate(t *testing.T) { vo: &ValidateChallengeOptions{ HTTPGet: func(url string) (*http.Response, error) { return &http.Response{ - Body: ioutil.NopCloser(bytes.NewBufferString(expKeyAuth)), + Body: io.NopCloser(bytes.NewBufferString(expKeyAuth)), }, nil }, }, diff --git a/api/api_test.go b/api/api_test.go index 89596165..05d592f0 100644 --- a/api/api_test.go +++ b/api/api_test.go @@ -16,7 +16,7 @@ import ( "encoding/json" "encoding/pem" "fmt" - "io/ioutil" + "io" "math/big" "net/http" "net/http/httptest" @@ -788,7 +788,7 @@ func Test_caHandler_Health(t *testing.T) { t.Errorf("caHandler.Health StatusCode = %d, wants 200", res.StatusCode) } - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() if err != nil { t.Errorf("caHandler.Health unexpected error = %v", err) @@ -829,7 +829,7 @@ func Test_caHandler_Root(t *testing.T) { t.Errorf("caHandler.Root StatusCode = %d, wants %d", res.StatusCode, tt.statusCode) } - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() if err != nil { t.Errorf("caHandler.Root unexpected error = %v", err) @@ -902,7 +902,7 @@ func Test_caHandler_Sign(t *testing.T) { t.Errorf("caHandler.Root StatusCode = %d, wants %d", res.StatusCode, tt.statusCode) } - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() if err != nil { t.Errorf("caHandler.Root unexpected error = %v", err) @@ -954,7 +954,7 @@ func Test_caHandler_Renew(t *testing.T) { t.Errorf("caHandler.Renew StatusCode = %d, wants %d", res.StatusCode, tt.statusCode) } - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() if err != nil { t.Errorf("caHandler.Renew unexpected error = %v", err) @@ -1015,7 +1015,7 @@ func Test_caHandler_Rekey(t *testing.T) { t.Errorf("caHandler.Rekey StatusCode = %d, wants %d", res.StatusCode, tt.statusCode) } - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() if err != nil { t.Errorf("caHandler.Rekey unexpected error = %v", err) @@ -1038,12 +1038,12 @@ func Test_caHandler_Provisioners(t *testing.T) { r *http.Request } - req, err := http.NewRequest("GET", "http://example.com/provisioners?cursor=foo&limit=20", nil) + req, err := http.NewRequest("GET", "http://example.com/provisioners?cursor=foo&limit=20", http.NoBody) if err != nil { t.Fatal(err) } - reqLimitFail, err := http.NewRequest("GET", "http://example.com/provisioners?limit=abc", nil) + reqLimitFail, err := http.NewRequest("GET", "http://example.com/provisioners?limit=abc", http.NoBody) if err != nil { t.Fatal(err) } @@ -1105,7 +1105,7 @@ func Test_caHandler_Provisioners(t *testing.T) { if res.StatusCode != tt.statusCode { t.Errorf("caHandler.Provisioners StatusCode = %d, wants %d", res.StatusCode, tt.statusCode) } - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() if err != nil { t.Errorf("caHandler.Provisioners unexpected error = %v", err) @@ -1175,7 +1175,7 @@ func Test_caHandler_ProvisionerKey(t *testing.T) { if res.StatusCode != tt.statusCode { t.Errorf("caHandler.Provisioners StatusCode = %d, wants %d", res.StatusCode, tt.statusCode) } - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() if err != nil { t.Errorf("caHandler.Provisioners unexpected error = %v", err) @@ -1225,7 +1225,7 @@ func Test_caHandler_Roots(t *testing.T) { t.Errorf("caHandler.Roots StatusCode = %d, wants %d", res.StatusCode, tt.statusCode) } - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() if err != nil { t.Errorf("caHandler.Roots unexpected error = %v", err) @@ -1271,7 +1271,7 @@ func Test_caHandler_Federation(t *testing.T) { t.Errorf("caHandler.Federation StatusCode = %d, wants %d", res.StatusCode, tt.statusCode) } - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() if err != nil { t.Errorf("caHandler.Federation unexpected error = %v", err) diff --git a/api/revoke_test.go b/api/revoke_test.go index f44acebf..4ed4e3fe 100644 --- a/api/revoke_test.go +++ b/api/revoke_test.go @@ -6,7 +6,7 @@ import ( "crypto/tls" "crypto/x509" "encoding/json" - "io/ioutil" + "io" "net/http" "net/http/httptest" "strings" @@ -233,7 +233,7 @@ func Test_caHandler_Revoke(t *testing.T) { assert.Equals(t, tc.statusCode, res.StatusCode) - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() assert.FatalError(t, err) diff --git a/api/ssh_test.go b/api/ssh_test.go index a2e8748f..a3d7da0d 100644 --- a/api/ssh_test.go +++ b/api/ssh_test.go @@ -10,7 +10,7 @@ import ( "encoding/base64" "encoding/json" "fmt" - "io/ioutil" + "io" "net/http" "net/http/httptest" "reflect" @@ -299,14 +299,14 @@ func Test_caHandler_SSHSign(t *testing.T) { body []byte statusCode int }{ - {"ok-user", userReq, nil, user, nil, nil, nil, nil, nil, []byte(fmt.Sprintf(`{"crt":"%s"}`, userB64)), http.StatusCreated}, - {"ok-host", hostReq, nil, host, nil, nil, nil, nil, nil, []byte(fmt.Sprintf(`{"crt":"%s"}`, hostB64)), http.StatusCreated}, - {"ok-user-add", userAddReq, nil, user, nil, user, nil, nil, nil, []byte(fmt.Sprintf(`{"crt":"%s","addUserCrt":"%s"}`, userB64, userB64)), http.StatusCreated}, - {"ok-user-identity", userIdentityReq, nil, user, nil, user, nil, identityCerts, nil, []byte(fmt.Sprintf(`{"crt":"%s","identityCrt":[%s]}`, userB64, identityCertsPEM)), http.StatusCreated}, + {"ok-user", userReq, nil, user, nil, nil, nil, nil, nil, []byte(fmt.Sprintf(`{"crt":%q}`, userB64)), http.StatusCreated}, + {"ok-host", hostReq, nil, host, nil, nil, nil, nil, nil, []byte(fmt.Sprintf(`{"crt":%q}`, hostB64)), http.StatusCreated}, + {"ok-user-add", userAddReq, nil, user, nil, user, nil, nil, nil, []byte(fmt.Sprintf(`{"crt":%q,"addUserCrt":%q}`, userB64, userB64)), http.StatusCreated}, + {"ok-user-identity", userIdentityReq, nil, user, nil, user, nil, identityCerts, nil, []byte(fmt.Sprintf(`{"crt":%q,"identityCrt":[%s]}`, userB64, identityCertsPEM)), http.StatusCreated}, {"fail-body", []byte("bad-json"), nil, nil, nil, nil, nil, nil, nil, nil, http.StatusBadRequest}, {"fail-validate", []byte("{}"), nil, nil, nil, nil, nil, nil, nil, nil, http.StatusBadRequest}, {"fail-publicKey", []byte(`{"publicKey":"Zm9v","ott":"ott"}`), nil, nil, nil, nil, nil, nil, nil, nil, http.StatusBadRequest}, - {"fail-publicKey", []byte(fmt.Sprintf(`{"publicKey":"%s","ott":"ott","addUserPublicKey":"Zm9v"}`, base64.StdEncoding.EncodeToString(user.Key.Marshal()))), nil, nil, nil, nil, nil, nil, nil, nil, http.StatusBadRequest}, + {"fail-publicKey", []byte(fmt.Sprintf(`{"publicKey":%q,"ott":"ott","addUserPublicKey":"Zm9v"}`, base64.StdEncoding.EncodeToString(user.Key.Marshal()))), nil, nil, nil, nil, nil, nil, nil, nil, http.StatusBadRequest}, {"fail-authorize", userReq, fmt.Errorf("an-error"), nil, nil, nil, nil, nil, nil, nil, http.StatusUnauthorized}, {"fail-signSSH", userReq, nil, nil, fmt.Errorf("an-error"), nil, nil, nil, nil, nil, http.StatusForbidden}, {"fail-SignSSHAddUser", userAddReq, nil, user, nil, nil, fmt.Errorf("an-error"), nil, nil, nil, http.StatusForbidden}, @@ -338,7 +338,7 @@ func Test_caHandler_SSHSign(t *testing.T) { t.Errorf("caHandler.SignSSH StatusCode = %d, wants %d", res.StatusCode, tt.statusCode) } - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() if err != nil { t.Errorf("caHandler.SignSSH unexpected error = %v", err) @@ -368,10 +368,10 @@ func Test_caHandler_SSHRoots(t *testing.T) { body []byte statusCode int }{ - {"ok", &authority.SSHKeys{HostKeys: []ssh.PublicKey{host}, UserKeys: []ssh.PublicKey{user}}, nil, []byte(fmt.Sprintf(`{"userKey":["%s"],"hostKey":["%s"]}`, userB64, hostB64)), http.StatusOK}, - {"many", &authority.SSHKeys{HostKeys: []ssh.PublicKey{host, host}, UserKeys: []ssh.PublicKey{user, user}}, nil, []byte(fmt.Sprintf(`{"userKey":["%s","%s"],"hostKey":["%s","%s"]}`, userB64, userB64, hostB64, hostB64)), http.StatusOK}, - {"user", &authority.SSHKeys{UserKeys: []ssh.PublicKey{user}}, nil, []byte(fmt.Sprintf(`{"userKey":["%s"]}`, userB64)), http.StatusOK}, - {"host", &authority.SSHKeys{HostKeys: []ssh.PublicKey{host}}, nil, []byte(fmt.Sprintf(`{"hostKey":["%s"]}`, hostB64)), http.StatusOK}, + {"ok", &authority.SSHKeys{HostKeys: []ssh.PublicKey{host}, UserKeys: []ssh.PublicKey{user}}, nil, []byte(fmt.Sprintf(`{"userKey":[%q],"hostKey":[%q]}`, userB64, hostB64)), http.StatusOK}, + {"many", &authority.SSHKeys{HostKeys: []ssh.PublicKey{host, host}, UserKeys: []ssh.PublicKey{user, user}}, nil, []byte(fmt.Sprintf(`{"userKey":[%q,%q],"hostKey":[%q,%q]}`, userB64, userB64, hostB64, hostB64)), http.StatusOK}, + {"user", &authority.SSHKeys{UserKeys: []ssh.PublicKey{user}}, nil, []byte(fmt.Sprintf(`{"userKey":[%q]}`, userB64)), http.StatusOK}, + {"host", &authority.SSHKeys{HostKeys: []ssh.PublicKey{host}}, nil, []byte(fmt.Sprintf(`{"hostKey":[%q]}`, hostB64)), http.StatusOK}, {"empty", &authority.SSHKeys{}, nil, nil, http.StatusNotFound}, {"error", nil, fmt.Errorf("an error"), nil, http.StatusInternalServerError}, } @@ -392,7 +392,7 @@ func Test_caHandler_SSHRoots(t *testing.T) { t.Errorf("caHandler.SSHRoots StatusCode = %d, wants %d", res.StatusCode, tt.statusCode) } - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() if err != nil { t.Errorf("caHandler.SSHRoots unexpected error = %v", err) @@ -422,10 +422,10 @@ func Test_caHandler_SSHFederation(t *testing.T) { body []byte statusCode int }{ - {"ok", &authority.SSHKeys{HostKeys: []ssh.PublicKey{host}, UserKeys: []ssh.PublicKey{user}}, nil, []byte(fmt.Sprintf(`{"userKey":["%s"],"hostKey":["%s"]}`, userB64, hostB64)), http.StatusOK}, - {"many", &authority.SSHKeys{HostKeys: []ssh.PublicKey{host, host}, UserKeys: []ssh.PublicKey{user, user}}, nil, []byte(fmt.Sprintf(`{"userKey":["%s","%s"],"hostKey":["%s","%s"]}`, userB64, userB64, hostB64, hostB64)), http.StatusOK}, - {"user", &authority.SSHKeys{UserKeys: []ssh.PublicKey{user}}, nil, []byte(fmt.Sprintf(`{"userKey":["%s"]}`, userB64)), http.StatusOK}, - {"host", &authority.SSHKeys{HostKeys: []ssh.PublicKey{host}}, nil, []byte(fmt.Sprintf(`{"hostKey":["%s"]}`, hostB64)), http.StatusOK}, + {"ok", &authority.SSHKeys{HostKeys: []ssh.PublicKey{host}, UserKeys: []ssh.PublicKey{user}}, nil, []byte(fmt.Sprintf(`{"userKey":[%q],"hostKey":[%q]}`, userB64, hostB64)), http.StatusOK}, + {"many", &authority.SSHKeys{HostKeys: []ssh.PublicKey{host, host}, UserKeys: []ssh.PublicKey{user, user}}, nil, []byte(fmt.Sprintf(`{"userKey":[%q,%q],"hostKey":[%q,%q]}`, userB64, userB64, hostB64, hostB64)), http.StatusOK}, + {"user", &authority.SSHKeys{UserKeys: []ssh.PublicKey{user}}, nil, []byte(fmt.Sprintf(`{"userKey":[%q]}`, userB64)), http.StatusOK}, + {"host", &authority.SSHKeys{HostKeys: []ssh.PublicKey{host}}, nil, []byte(fmt.Sprintf(`{"hostKey":[%q]}`, hostB64)), http.StatusOK}, {"empty", &authority.SSHKeys{}, nil, nil, http.StatusNotFound}, {"error", nil, fmt.Errorf("an error"), nil, http.StatusInternalServerError}, } @@ -446,7 +446,7 @@ func Test_caHandler_SSHFederation(t *testing.T) { t.Errorf("caHandler.SSHFederation StatusCode = %d, wants %d", res.StatusCode, tt.statusCode) } - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() if err != nil { t.Errorf("caHandler.SSHFederation unexpected error = %v", err) @@ -506,7 +506,7 @@ func Test_caHandler_SSHConfig(t *testing.T) { t.Errorf("caHandler.SSHConfig StatusCode = %d, wants %d", res.StatusCode, tt.statusCode) } - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() if err != nil { t.Errorf("caHandler.SSHConfig unexpected error = %v", err) @@ -553,7 +553,7 @@ func Test_caHandler_SSHCheckHost(t *testing.T) { t.Errorf("caHandler.SSHCheckHost StatusCode = %d, wants %d", res.StatusCode, tt.statusCode) } - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() if err != nil { t.Errorf("caHandler.SSHCheckHost unexpected error = %v", err) @@ -604,7 +604,7 @@ func Test_caHandler_SSHGetHosts(t *testing.T) { t.Errorf("caHandler.SSHGetHosts StatusCode = %d, wants %d", res.StatusCode, tt.statusCode) } - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() if err != nil { t.Errorf("caHandler.SSHGetHosts unexpected error = %v", err) @@ -659,7 +659,7 @@ func Test_caHandler_SSHBastion(t *testing.T) { t.Errorf("caHandler.SSHBastion StatusCode = %d, wants %d", res.StatusCode, tt.statusCode) } - body, err := ioutil.ReadAll(res.Body) + body, err := io.ReadAll(res.Body) res.Body.Close() if err != nil { t.Errorf("caHandler.SSHBastion unexpected error = %v", err) diff --git a/api/utils.go b/api/utils.go index bf45db53..fa56ed6b 100644 --- a/api/utils.go +++ b/api/utils.go @@ -3,7 +3,6 @@ package api import ( "encoding/json" "io" - "io/ioutil" "log" "net/http" @@ -102,7 +101,7 @@ func ReadJSON(r io.Reader, v interface{}) error { // ReadProtoJSON reads JSON from the request body and stores it in the value // pointed by v. func ReadProtoJSON(r io.Reader, m proto.Message) error { - data, err := ioutil.ReadAll(r) + data, err := io.ReadAll(r) if err != nil { return errs.Wrap(http.StatusBadRequest, err, "error reading request body") } diff --git a/authority/authority_test.go b/authority/authority_test.go index 1e18a24f..abb06cf4 100644 --- a/authority/authority_test.go +++ b/authority/authority_test.go @@ -7,8 +7,8 @@ import ( "crypto/x509" "encoding/hex" "fmt" - "io/ioutil" "net" + "os" "reflect" "testing" "time" @@ -195,7 +195,7 @@ func TestAuthority_GetDatabase(t *testing.T) { } func TestNewEmbedded(t *testing.T) { - caPEM, err := ioutil.ReadFile("testdata/certs/root_ca.crt") + caPEM, err := os.ReadFile("testdata/certs/root_ca.crt") assert.FatalError(t, err) crt, err := pemutil.ReadCertificate("testdata/certs/intermediate_ca.crt") @@ -268,7 +268,7 @@ func TestNewEmbedded(t *testing.T) { } func TestNewEmbedded_Sign(t *testing.T) { - caPEM, err := ioutil.ReadFile("testdata/certs/root_ca.crt") + caPEM, err := os.ReadFile("testdata/certs/root_ca.crt") assert.FatalError(t, err) crt, err := pemutil.ReadCertificate("testdata/certs/intermediate_ca.crt") @@ -294,7 +294,7 @@ func TestNewEmbedded_Sign(t *testing.T) { } func TestNewEmbedded_GetTLSCertificate(t *testing.T) { - caPEM, err := ioutil.ReadFile("testdata/certs/root_ca.crt") + caPEM, err := os.ReadFile("testdata/certs/root_ca.crt") assert.FatalError(t, err) crt, err := pemutil.ReadCertificate("testdata/certs/intermediate_ca.crt") diff --git a/authority/export.go b/authority/export.go index 8a5a257f..d1096fa5 100644 --- a/authority/export.go +++ b/authority/export.go @@ -2,8 +2,8 @@ package authority import ( "encoding/json" - "io/ioutil" "net/url" + "os" "path/filepath" "strings" @@ -257,7 +257,7 @@ func mustReadFileOrURI(fn string, m map[string][]byte) string { panic(err) } if ok { - b, err := ioutil.ReadFile(config.StepAbs(fn)) + b, err := os.ReadFile(config.StepAbs(fn)) if err != nil { panic(errors.Wrapf(err, "error reading %s", fn)) } diff --git a/authority/provisioner/aws.go b/authority/provisioner/aws.go index cd129b7b..fdad7b4a 100644 --- a/authority/provisioner/aws.go +++ b/authority/provisioner/aws.go @@ -9,9 +9,10 @@ import ( "encoding/json" "encoding/pem" "fmt" - "io/ioutil" + "io" "net" "net/http" + "os" "strings" "time" @@ -165,7 +166,7 @@ func newAWSConfig(certPath string) (*awsConfig, error) { if certPath == "" { certBytes = []byte(awsCertificate) } else { - if b, err := ioutil.ReadFile(certPath); err == nil { + if b, err := os.ReadFile(certPath); err == nil { certBytes = b } else { return nil, errors.Wrapf(err, "error reading %s", certPath) @@ -569,7 +570,7 @@ func (p *AWS) readURLv2(url string) (*http.Response, error) { client := http.Client{} // first get the token - req, err := http.NewRequest(http.MethodPut, p.config.tokenURL, nil) + req, err := http.NewRequest(http.MethodPut, p.config.tokenURL, http.NoBody) if err != nil { return nil, err } @@ -582,7 +583,7 @@ func (p *AWS) readURLv2(url string) (*http.Response, error) { if resp.StatusCode >= 400 { return nil, fmt.Errorf("Request for API token returned non-successful status code %d", resp.StatusCode) } - token, err := ioutil.ReadAll(resp.Body) + token, err := io.ReadAll(resp.Body) if err != nil { return nil, err } @@ -602,7 +603,7 @@ func (p *AWS) readURLv2(url string) (*http.Response, error) { func (p *AWS) readResponseBody(resp *http.Response) ([]byte, error) { defer resp.Body.Close() - b, err := ioutil.ReadAll(resp.Body) + b, err := io.ReadAll(resp.Body) if err != nil { return nil, err } diff --git a/authority/provisioner/azure.go b/authority/provisioner/azure.go index a90d1728..55d77f49 100644 --- a/authority/provisioner/azure.go +++ b/authority/provisioner/azure.go @@ -6,7 +6,7 @@ import ( "crypto/x509" "encoding/hex" "encoding/json" - "io/ioutil" + "io" "net/http" "regexp" "strings" @@ -173,7 +173,7 @@ func (p *Azure) GetIdentityToken(subject, caURL string) (string, error) { } defer resp.Body.Close() - b, err := ioutil.ReadAll(resp.Body) + b, err := io.ReadAll(resp.Body) if err != nil { return "", errors.Wrap(err, "error reading identity token response") } diff --git a/authority/provisioner/azure_test.go b/authority/provisioner/azure_test.go index b7c321a6..7f8d6017 100644 --- a/authority/provisioner/azure_test.go +++ b/authority/provisioner/azure_test.go @@ -107,7 +107,7 @@ func TestAzure_GetIdentityToken(t *testing.T) { w.Write([]byte(t1)) default: w.Header().Add("Content-Type", "application/json") - w.Write([]byte(fmt.Sprintf(`{"access_token":"%s"}`, t1))) + fmt.Fprintf(w, `{"access_token":"%s"}`, t1) } })) defer srv.Close() diff --git a/authority/provisioner/gcp.go b/authority/provisioner/gcp.go index 98d776d1..e46f4ce4 100644 --- a/authority/provisioner/gcp.go +++ b/authority/provisioner/gcp.go @@ -7,7 +7,7 @@ import ( "crypto/x509" "encoding/hex" "fmt" - "io/ioutil" + "io" "net/http" "net/url" "strings" @@ -183,7 +183,7 @@ func (p *GCP) GetIdentityToken(subject, caURL string) (string, error) { return "", errors.Wrap(err, "error doing identity request, are you in a GCP VM?") } defer resp.Body.Close() - b, err := ioutil.ReadAll(resp.Body) + b, err := io.ReadAll(resp.Body) if err != nil { return "", errors.Wrap(err, "error on identity request") } diff --git a/authority/provisioner/utils_test.go b/authority/provisioner/utils_test.go index e39efbcf..fe2678fc 100644 --- a/authority/provisioner/utils_test.go +++ b/authority/provisioner/utils_test.go @@ -10,9 +10,9 @@ import ( "encoding/json" "encoding/pem" "fmt" - "io/ioutil" "net/http" "net/http/httptest" + "os" "strings" "time" @@ -188,7 +188,7 @@ func generateJWK() (*JWK, error) { } func generateK8sSA(inputPubKey interface{}) (*K8sSA, error) { - fooPubB, err := ioutil.ReadFile("./testdata/certs/foo.pub") + fooPubB, err := os.ReadFile("./testdata/certs/foo.pub") if err != nil { return nil, err } @@ -196,7 +196,7 @@ func generateK8sSA(inputPubKey interface{}) (*K8sSA, error) { if err != nil { return nil, err } - barPubB, err := ioutil.ReadFile("./testdata/certs/bar.pub") + barPubB, err := os.ReadFile("./testdata/certs/bar.pub") if err != nil { return nil, err } @@ -234,7 +234,7 @@ func generateSSHPOP() (*SSHPOP, error) { return nil, err } - userB, err := ioutil.ReadFile("./testdata/certs/ssh_user_ca_key.pub") + userB, err := os.ReadFile("./testdata/certs/ssh_user_ca_key.pub") if err != nil { return nil, err } @@ -242,7 +242,7 @@ func generateSSHPOP() (*SSHPOP, error) { if err != nil { return nil, err } - hostB, err := ioutil.ReadFile("./testdata/certs/ssh_host_ca_key.pub") + hostB, err := os.ReadFile("./testdata/certs/ssh_host_ca_key.pub") if err != nil { return nil, err } diff --git a/authority/provisioners.go b/authority/provisioners.go index 7e02126f..e394e7e9 100644 --- a/authority/provisioners.go +++ b/authority/provisioners.go @@ -6,7 +6,7 @@ import ( "encoding/json" "encoding/pem" "fmt" - "io/ioutil" + "os" "github.com/pkg/errors" "github.com/smallstep/certificates/authority/admin" @@ -524,7 +524,7 @@ func provisionerOptionsToLinkedca(p *provisioner.Options) (*linkedca.Template, * x509Template.Template = []byte(p.SSH.Template) } else if p.X509.TemplateFile != "" { filename := step.StepAbs(p.X509.TemplateFile) - if x509Template.Template, err = ioutil.ReadFile(filename); err != nil { + if x509Template.Template, err = os.ReadFile(filename); err != nil { return nil, nil, errors.Wrap(err, "error reading x509 template") } } @@ -540,7 +540,7 @@ func provisionerOptionsToLinkedca(p *provisioner.Options) (*linkedca.Template, * sshTemplate.Template = []byte(p.SSH.Template) } else if p.SSH.TemplateFile != "" { filename := step.StepAbs(p.SSH.TemplateFile) - if sshTemplate.Template, err = ioutil.ReadFile(filename); err != nil { + if sshTemplate.Template, err = os.ReadFile(filename); err != nil { return nil, nil, errors.Wrap(err, "error reading ssh template") } } diff --git a/authority/tls_test.go b/authority/tls_test.go index f1d1748d..158e6f4f 100644 --- a/authority/tls_test.go +++ b/authority/tls_test.go @@ -538,15 +538,15 @@ ZYtQ9Ot36qc= if tc.csr.Subject.CommonName == "" { assert.Equals(t, leaf.Subject, pkix.Name{}) } else { - assert.Equals(t, fmt.Sprintf("%v", leaf.Subject), - fmt.Sprintf("%v", &pkix.Name{ + assert.Equals(t, leaf.Subject.String(), + pkix.Name{ Country: []string{tmplt.Country}, Organization: []string{tmplt.Organization}, Locality: []string{tmplt.Locality}, StreetAddress: []string{tmplt.StreetAddress}, Province: []string{tmplt.Province}, CommonName: "smallstep test", - })) + }.String()) assert.Equals(t, leaf.DNSNames, []string{"test.smallstep.com"}) } assert.Equals(t, leaf.Issuer, intermediate.Subject) @@ -718,15 +718,15 @@ func TestAuthority_Renew(t *testing.T) { assert.True(t, leaf.NotAfter.Before(expiry.Add(time.Minute))) tmplt := a.config.AuthorityConfig.Template - assert.Equals(t, fmt.Sprintf("%v", leaf.Subject), - fmt.Sprintf("%v", &pkix.Name{ + assert.Equals(t, leaf.Subject.String(), + pkix.Name{ Country: []string{tmplt.Country}, Organization: []string{tmplt.Organization}, Locality: []string{tmplt.Locality}, StreetAddress: []string{tmplt.StreetAddress}, Province: []string{tmplt.Province}, CommonName: tmplt.CommonName, - })) + }.String()) assert.Equals(t, leaf.Issuer, intermediate.Subject) assert.Equals(t, leaf.SignatureAlgorithm, x509.ECDSAWithSHA256) @@ -925,15 +925,15 @@ func TestAuthority_Rekey(t *testing.T) { assert.True(t, leaf.NotAfter.Before(expiry.Add(time.Minute))) tmplt := a.config.AuthorityConfig.Template - assert.Equals(t, fmt.Sprintf("%v", leaf.Subject), - fmt.Sprintf("%v", &pkix.Name{ + assert.Equals(t, leaf.Subject.String(), + pkix.Name{ Country: []string{tmplt.Country}, Organization: []string{tmplt.Organization}, Locality: []string{tmplt.Locality}, StreetAddress: []string{tmplt.StreetAddress}, Province: []string{tmplt.Province}, CommonName: tmplt.CommonName, - })) + }.String()) assert.Equals(t, leaf.Issuer, intermediate.Subject) assert.Equals(t, leaf.SignatureAlgorithm, x509.ECDSAWithSHA256) diff --git a/ca/acmeClient.go b/ca/acmeClient.go index d1f40f32..28451a45 100644 --- a/ca/acmeClient.go +++ b/ca/acmeClient.go @@ -7,7 +7,6 @@ import ( "encoding/pem" "fmt" "io" - "io/ioutil" "net/http" "strings" @@ -292,7 +291,7 @@ func (c *ACMEClient) GetCertificate(url string) (*x509.Certificate, []*x509.Cert return nil, nil, readACMEError(resp.Body) } defer resp.Body.Close() - bodyBytes, err := ioutil.ReadAll(resp.Body) + bodyBytes, err := io.ReadAll(resp.Body) if err != nil { return nil, nil, errors.Wrap(err, "error reading GET certificate response") } @@ -338,7 +337,7 @@ func (c *ACMEClient) GetAccountOrders() ([]string, error) { func readACMEError(r io.ReadCloser) error { defer r.Close() - b, err := ioutil.ReadAll(r) + b, err := io.ReadAll(r) if err != nil { return errors.Wrap(err, "error reading from body") } diff --git a/ca/acmeClient_test.go b/ca/acmeClient_test.go index 656a82cf..d22c4972 100644 --- a/ca/acmeClient_test.go +++ b/ca/acmeClient_test.go @@ -5,7 +5,7 @@ import ( "encoding/base64" "encoding/json" "encoding/pem" - "io/ioutil" + "io" "net/http" "net/http/httptest" "testing" @@ -317,7 +317,7 @@ func TestACMEClient_post(t *testing.T) { } // validate jws request protected headers and body - body, err := ioutil.ReadAll(req.Body) + body, err := io.ReadAll(req.Body) assert.FatalError(t, err) jws, err := jose.ParseJWS(string(body)) assert.FatalError(t, err) @@ -455,7 +455,7 @@ func TestACMEClient_NewOrder(t *testing.T) { } // validate jws request protected headers and body - body, err := ioutil.ReadAll(req.Body) + body, err := io.ReadAll(req.Body) assert.FatalError(t, err) jws, err := jose.ParseJWS(string(body)) assert.FatalError(t, err) @@ -575,7 +575,7 @@ func TestACMEClient_GetOrder(t *testing.T) { } // validate jws request protected headers and body - body, err := ioutil.ReadAll(req.Body) + body, err := io.ReadAll(req.Body) assert.FatalError(t, err) jws, err := jose.ParseJWS(string(body)) assert.FatalError(t, err) @@ -695,7 +695,7 @@ func TestACMEClient_GetAuthz(t *testing.T) { } // validate jws request protected headers and body - body, err := ioutil.ReadAll(req.Body) + body, err := io.ReadAll(req.Body) assert.FatalError(t, err) jws, err := jose.ParseJWS(string(body)) assert.FatalError(t, err) @@ -815,7 +815,7 @@ func TestACMEClient_GetChallenge(t *testing.T) { } // validate jws request protected headers and body - body, err := ioutil.ReadAll(req.Body) + body, err := io.ReadAll(req.Body) assert.FatalError(t, err) jws, err := jose.ParseJWS(string(body)) assert.FatalError(t, err) @@ -936,7 +936,7 @@ func TestACMEClient_ValidateChallenge(t *testing.T) { } // validate jws request protected headers and body - body, err := ioutil.ReadAll(req.Body) + body, err := io.ReadAll(req.Body) assert.FatalError(t, err) jws, err := jose.ParseJWS(string(body)) assert.FatalError(t, err) @@ -1061,7 +1061,7 @@ func TestACMEClient_FinalizeOrder(t *testing.T) { } // validate jws request protected headers and body - body, err := ioutil.ReadAll(req.Body) + body, err := io.ReadAll(req.Body) assert.FatalError(t, err) jws, err := jose.ParseJWS(string(body)) assert.FatalError(t, err) @@ -1188,7 +1188,7 @@ func TestACMEClient_GetAccountOrders(t *testing.T) { } // validate jws request protected headers and body - body, err := ioutil.ReadAll(req.Body) + body, err := io.ReadAll(req.Body) assert.FatalError(t, err) jws, err := jose.ParseJWS(string(body)) assert.FatalError(t, err) @@ -1317,7 +1317,7 @@ func TestACMEClient_GetCertificate(t *testing.T) { } // validate jws request protected headers and body - body, err := ioutil.ReadAll(req.Body) + body, err := io.ReadAll(req.Body) assert.FatalError(t, err) jws, err := jose.ParseJWS(string(body)) assert.FatalError(t, err) diff --git a/ca/adminClient.go b/ca/adminClient.go index 6022f677..2e447f55 100644 --- a/ca/adminClient.go +++ b/ca/adminClient.go @@ -197,7 +197,7 @@ func (c *AdminClient) GetAdminsPaginate(opts ...AdminOption) (*adminAPI.GetAdmin if err != nil { return nil, errors.Wrapf(err, "error generating admin token") } - req, err := http.NewRequest("GET", u.String(), nil) + req, err := http.NewRequest("GET", u.String(), http.NoBody) if err != nil { return nil, errors.Wrapf(err, "create GET %s request failed", u) } @@ -284,7 +284,7 @@ func (c *AdminClient) RemoveAdmin(id string) error { if err != nil { return errors.Wrapf(err, "error generating admin token") } - req, err := http.NewRequest("DELETE", u.String(), nil) + req, err := http.NewRequest("DELETE", u.String(), http.NoBody) if err != nil { return errors.Wrapf(err, "create DELETE %s request failed", u) } @@ -363,7 +363,7 @@ func (c *AdminClient) GetProvisioner(opts ...ProvisionerOption) (*linkedca.Provi if err != nil { return nil, errors.Wrapf(err, "error generating admin token") } - req, err := http.NewRequest("GET", u.String(), nil) + req, err := http.NewRequest("GET", u.String(), http.NoBody) if err != nil { return nil, errors.Wrapf(err, "create PUT %s request failed", u) } @@ -402,7 +402,7 @@ func (c *AdminClient) GetProvisionersPaginate(opts ...ProvisionerOption) (*admin if err != nil { return nil, errors.Wrapf(err, "error generating admin token") } - req, err := http.NewRequest("GET", u.String(), nil) + req, err := http.NewRequest("GET", u.String(), http.NoBody) if err != nil { return nil, errors.Wrapf(err, "create PUT %s request failed", u) } @@ -472,7 +472,7 @@ func (c *AdminClient) RemoveProvisioner(opts ...ProvisionerOption) error { if err != nil { return errors.Wrapf(err, "error generating admin token") } - req, err := http.NewRequest("DELETE", u.String(), nil) + req, err := http.NewRequest("DELETE", u.String(), http.NoBody) if err != nil { return errors.Wrapf(err, "create DELETE %s request failed", u) } diff --git a/ca/bootstrap_test.go b/ca/bootstrap_test.go index e7d0e401..7c1bc908 100644 --- a/ca/bootstrap_test.go +++ b/ca/bootstrap_test.go @@ -3,7 +3,7 @@ package ca import ( "context" "crypto/tls" - "io/ioutil" + "io" "net" "net/http" "net/http/httptest" @@ -382,7 +382,7 @@ func TestBootstrapClientServerRotation(t *testing.T) { return errors.Wrapf(err, "client.Get(%s) failed", srvURL) } defer resp.Body.Close() - b, err := ioutil.ReadAll(resp.Body) + b, err := io.ReadAll(resp.Body) if err != nil { return errors.Wrap(err, "client.Get() error reading response") } @@ -499,7 +499,7 @@ func TestBootstrapClientServerFederation(t *testing.T) { return errors.Wrapf(err, "client.Get(%s) failed", srvURL) } defer resp.Body.Close() - b, err := ioutil.ReadAll(resp.Body) + b, err := io.ReadAll(resp.Body) if err != nil { return errors.Wrap(err, "client.Get() error reading response") } @@ -589,9 +589,9 @@ func TestBootstrapListener(t *testing.T) { return } defer resp.Body.Close() - b, err := ioutil.ReadAll(resp.Body) + b, err := io.ReadAll(resp.Body) if err != nil { - t.Errorf("ioutil.ReadAll() error = %v", err) + t.Errorf("io.ReadAll() error = %v", err) return } if string(b) != "ok" { diff --git a/ca/ca_test.go b/ca/ca_test.go index ff264db7..0f7cb02e 100644 --- a/ca/ca_test.go +++ b/ca/ca_test.go @@ -294,15 +294,15 @@ ZEp7knvU2psWRw== assert.Equals(t, leaf.NotBefore, now.Truncate(time.Second)) assert.Equals(t, leaf.NotAfter, leafExpiry.Truncate(time.Second)) - assert.Equals(t, fmt.Sprintf("%v", leaf.Subject), - fmt.Sprintf("%v", &pkix.Name{ + assert.Equals(t, leaf.Subject.String(), + pkix.Name{ Country: []string{asn1dn.Country}, Organization: []string{asn1dn.Organization}, Locality: []string{asn1dn.Locality}, StreetAddress: []string{asn1dn.StreetAddress}, Province: []string{asn1dn.Province}, CommonName: asn1dn.CommonName, - })) + }.String()) assert.Equals(t, leaf.Issuer, intermediate.Subject) assert.Equals(t, leaf.SignatureAlgorithm, x509.ECDSAWithSHA256) @@ -641,10 +641,10 @@ func TestCARenew(t *testing.T) { assert.Equals(t, leaf.NotBefore, now.Truncate(time.Second)) assert.Equals(t, leaf.NotAfter, leafExpiry.Truncate(time.Second)) - assert.Equals(t, fmt.Sprintf("%v", leaf.Subject), - fmt.Sprintf("%v", &pkix.Name{ + assert.Equals(t, leaf.Subject.String(), + pkix.Name{ CommonName: asn1dn.CommonName, - })) + }.String()) assert.Equals(t, leaf.Issuer, intermediate.Subject) assert.Equals(t, leaf.SignatureAlgorithm, x509.ECDSAWithSHA256) diff --git a/ca/client.go b/ca/client.go index cfeddba0..df4561d8 100644 --- a/ca/client.go +++ b/ca/client.go @@ -15,7 +15,6 @@ import ( "encoding/json" "encoding/pem" "io" - "io/ioutil" "net/http" "net/url" "os" @@ -75,7 +74,7 @@ func (c *uaClient) SetTransport(tr http.RoundTripper) { } func (c *uaClient) Get(u string) (*http.Response, error) { - req, err := http.NewRequest("GET", u, nil) + req, err := http.NewRequest("GET", u, http.NoBody) if err != nil { return nil, errors.Wrapf(err, "new request GET %s failed", u) } @@ -350,7 +349,7 @@ func WithRetryFunc(fn RetryFunc) ClientOption { } func getTransportFromFile(filename string) (http.RoundTripper, error) { - data, err := ioutil.ReadFile(filename) + data, err := os.ReadFile(filename) if err != nil { return nil, errors.Wrapf(err, "error reading %s", filename) } @@ -1305,7 +1304,7 @@ func readJSON(r io.ReadCloser, v interface{}) error { func readProtoJSON(r io.ReadCloser, m proto.Message) error { defer r.Close() - data, err := ioutil.ReadAll(r) + data, err := io.ReadAll(r) if err != nil { return err } diff --git a/ca/identity/client.go b/ca/identity/client.go index 4377638f..7d5dcfcb 100644 --- a/ca/identity/client.go +++ b/ca/identity/client.go @@ -5,9 +5,9 @@ import ( "crypto/x509" "encoding/json" "fmt" - "io/ioutil" "net/http" "net/url" + "os" "github.com/pkg/errors" ) @@ -27,7 +27,7 @@ func (c *Client) ResolveReference(ref *url.URL) *url.URL { // $STEPPATH/config/defaults.json and the identity defined in // $STEPPATH/config/identity.json func LoadClient() (*Client, error) { - b, err := ioutil.ReadFile(DefaultsFile) + b, err := os.ReadFile(DefaultsFile) if err != nil { return nil, errors.Wrapf(err, "error reading %s", DefaultsFile) } @@ -65,7 +65,7 @@ func LoadClient() (*Client, error) { } // RootCAs - b, err = ioutil.ReadFile(defaults.Root) + b, err = os.ReadFile(defaults.Root) if err != nil { return nil, errors.Wrapf(err, "error loading %s", defaults.Root) } diff --git a/ca/identity/client_test.go b/ca/identity/client_test.go index 402ec7b8..0ed9b33b 100644 --- a/ca/identity/client_test.go +++ b/ca/identity/client_test.go @@ -3,10 +3,10 @@ package identity import ( "crypto/tls" "crypto/x509" - "io/ioutil" "net/http" "net/http/httptest" "net/url" + "os" "reflect" "testing" ) @@ -40,7 +40,7 @@ func TestClient(t *testing.T) { if err != nil { t.Fatal(err) } - b, err := ioutil.ReadFile("testdata/certs/root_ca.crt") + b, err := os.ReadFile("testdata/certs/root_ca.crt") if err != nil { t.Fatal(err) } @@ -114,7 +114,7 @@ func TestLoadClient(t *testing.T) { if err != nil { t.Fatal(err) } - b, err := ioutil.ReadFile("testdata/certs/root_ca.crt") + b, err := os.ReadFile("testdata/certs/root_ca.crt") if err != nil { t.Fatal(err) } diff --git a/ca/identity/identity.go b/ca/identity/identity.go index 0f022dd7..4c665850 100644 --- a/ca/identity/identity.go +++ b/ca/identity/identity.go @@ -7,7 +7,6 @@ import ( "crypto/x509" "encoding/json" "encoding/pem" - "io/ioutil" "net/http" "os" "path/filepath" @@ -61,7 +60,7 @@ type Identity struct { // LoadIdentity loads an identity present in the given filename. func LoadIdentity(filename string) (*Identity, error) { - b, err := ioutil.ReadFile(filename) + b, err := os.ReadFile(filename) if err != nil { return nil, errors.Wrapf(err, "error reading %s", filename) } @@ -112,7 +111,7 @@ func WriteDefaultIdentity(certChain []api.Certificate, key crypto.PrivateKey) er if err := pem.Encode(buf, block); err != nil { return errors.Wrap(err, "error encoding identity key") } - if err := ioutil.WriteFile(keyFilename, buf.Bytes(), 0600); err != nil { + if err := os.WriteFile(keyFilename, buf.Bytes(), 0600); err != nil { return errors.Wrap(err, "error writing identity certificate") } @@ -127,7 +126,7 @@ func WriteDefaultIdentity(certChain []api.Certificate, key crypto.PrivateKey) er }); err != nil { return errors.Wrap(err, "error writing identity json") } - if err := ioutil.WriteFile(IdentityFile, buf.Bytes(), 0600); err != nil { + if err := os.WriteFile(IdentityFile, buf.Bytes(), 0600); err != nil { return errors.Wrap(err, "error writing identity certificate") } @@ -153,7 +152,7 @@ func writeCertificate(filename string, certChain []api.Certificate) error { } } - if err := ioutil.WriteFile(filename, buf.Bytes(), 0600); err != nil { + if err := os.WriteFile(filename, buf.Bytes(), 0600); err != nil { return errors.Wrap(err, "error writing certificate") } @@ -263,7 +262,7 @@ func (i *Identity) GetCertPool() (*x509.CertPool, error) { if i.Root == "" { return nil, nil } - b, err := ioutil.ReadFile(i.Root) + b, err := os.ReadFile(i.Root) if err != nil { return nil, errors.Wrap(err, "error reading identity root") } @@ -320,7 +319,7 @@ func (i *Identity) Renew(client Renewer) error { } } certFilename := filepath.Join(identityDir, "identity.crt") - if err := ioutil.WriteFile(certFilename, buf.Bytes(), 0600); err != nil { + if err := os.WriteFile(certFilename, buf.Bytes(), 0600); err != nil { return errors.Wrap(err, "error writing identity certificate") } diff --git a/ca/provisioner_test.go b/ca/provisioner_test.go index ea0ca51e..01b54d17 100644 --- a/ca/provisioner_test.go +++ b/ca/provisioner_test.go @@ -1,8 +1,8 @@ package ca import ( - "io/ioutil" "net/url" + "os" "reflect" "testing" "time" @@ -45,7 +45,7 @@ func TestNewProvisioner(t *testing.T) { defer ca.Close() want := getTestProvisioner(t, ca.URL) - caBundle, err := ioutil.ReadFile("testdata/secrets/root_ca.crt") + caBundle, err := os.ReadFile("testdata/secrets/root_ca.crt") if err != nil { t.Fatal(err) } diff --git a/ca/renew.go b/ca/renew.go index 7d574748..915be787 100644 --- a/ca/renew.go +++ b/ca/renew.go @@ -18,7 +18,7 @@ var minCertDuration = time.Minute // TLSRenewer automatically renews a tls certificate using a RenewFunc. type TLSRenewer struct { - sync.RWMutex + renewMutex sync.RWMutex RenewCertificate RenewFunc cert *tls.Certificate timer *time.Timer @@ -81,9 +81,9 @@ func NewTLSRenewer(cert *tls.Certificate, fn RenewFunc, opts ...tlsRenewerOption func (r *TLSRenewer) Run() { cert := r.getCertificate() next := r.nextRenewDuration(cert.Leaf.NotAfter) - r.Lock() + r.renewMutex.Lock() r.timer = time.AfterFunc(next, r.renewCertificate) - r.Unlock() + r.renewMutex.Unlock() } // RunContext starts the certificate renewer for the given certificate. @@ -133,25 +133,25 @@ func (r *TLSRenewer) GetClientCertificate(*tls.CertificateRequestInfo) (*tls.Cer // if the timer does not fire e.g. when the CA is run from a laptop that // enters sleep mode. func (r *TLSRenewer) getCertificate() *tls.Certificate { - r.RLock() + r.renewMutex.RLock() cert := r.cert - r.RUnlock() + r.renewMutex.RUnlock() return cert } // getCertificateForCA returns the certificate using a read-only lock. It will // automatically renew the certificate if it has expired. func (r *TLSRenewer) getCertificateForCA() *tls.Certificate { - r.RLock() + r.renewMutex.RLock() // Force certificate renewal if the timer didn't run. // This is an special case that can happen after a computer sleep. if time.Now().After(r.certNotAfter) { - r.RUnlock() + r.renewMutex.RUnlock() r.renewCertificate() - r.RLock() + r.renewMutex.RLock() } cert := r.cert - r.RUnlock() + r.renewMutex.RUnlock() return cert } @@ -159,10 +159,10 @@ func (r *TLSRenewer) getCertificateForCA() *tls.Certificate { // updates certNotAfter with 1m of delta; this will force the renewal of the // certificate if it is about to expire. func (r *TLSRenewer) setCertificate(cert *tls.Certificate) { - r.Lock() + r.renewMutex.Lock() r.cert = cert r.certNotAfter = cert.Leaf.NotAfter.Add(-1 * time.Minute) - r.Unlock() + r.renewMutex.Unlock() } func (r *TLSRenewer) renewCertificate() { @@ -175,9 +175,9 @@ func (r *TLSRenewer) renewCertificate() { r.setCertificate(cert) next = r.nextRenewDuration(cert.Leaf.NotAfter) } - r.Lock() + r.renewMutex.Lock() r.timer.Reset(next) - r.Unlock() + r.renewMutex.Unlock() } func (r *TLSRenewer) nextRenewDuration(notAfter time.Time) time.Duration { diff --git a/ca/tls_options_test.go b/ca/tls_options_test.go index 8744bb2b..7d94926b 100644 --- a/ca/tls_options_test.go +++ b/ca/tls_options_test.go @@ -4,8 +4,8 @@ import ( "crypto/tls" "crypto/x509" "fmt" - "io/ioutil" "net/http" + "os" "reflect" "sort" "testing" @@ -202,7 +202,7 @@ func TestAddRootsToRootCAs(t *testing.T) { t.Fatal(err) } - root, err := ioutil.ReadFile("testdata/secrets/root_ca.crt") + root, err := os.ReadFile("testdata/secrets/root_ca.crt") if err != nil { t.Fatal(err) } @@ -256,7 +256,7 @@ func TestAddRootsToClientCAs(t *testing.T) { t.Fatal(err) } - root, err := ioutil.ReadFile("testdata/secrets/root_ca.crt") + root, err := os.ReadFile("testdata/secrets/root_ca.crt") if err != nil { t.Fatal(err) } @@ -310,12 +310,12 @@ func TestAddFederationToRootCAs(t *testing.T) { t.Fatal(err) } - root, err := ioutil.ReadFile("testdata/secrets/root_ca.crt") + root, err := os.ReadFile("testdata/secrets/root_ca.crt") if err != nil { t.Fatal(err) } - federated, err := ioutil.ReadFile("testdata/secrets/federated_ca.crt") + federated, err := os.ReadFile("testdata/secrets/federated_ca.crt") if err != nil { t.Fatal(err) } @@ -374,12 +374,12 @@ func TestAddFederationToClientCAs(t *testing.T) { t.Fatal(err) } - root, err := ioutil.ReadFile("testdata/secrets/root_ca.crt") + root, err := os.ReadFile("testdata/secrets/root_ca.crt") if err != nil { t.Fatal(err) } - federated, err := ioutil.ReadFile("testdata/secrets/federated_ca.crt") + federated, err := os.ReadFile("testdata/secrets/federated_ca.crt") if err != nil { t.Fatal(err) } @@ -438,7 +438,7 @@ func TestAddRootsToCAs(t *testing.T) { t.Fatal(err) } - root, err := ioutil.ReadFile("testdata/secrets/root_ca.crt") + root, err := os.ReadFile("testdata/secrets/root_ca.crt") if err != nil { t.Fatal(err) } @@ -492,12 +492,12 @@ func TestAddFederationToCAs(t *testing.T) { t.Fatal(err) } - root, err := ioutil.ReadFile("testdata/secrets/root_ca.crt") + root, err := os.ReadFile("testdata/secrets/root_ca.crt") if err != nil { t.Fatal(err) } - federated, err := ioutil.ReadFile("testdata/secrets/federated_ca.crt") + federated, err := os.ReadFile("testdata/secrets/federated_ca.crt") if err != nil { t.Fatal(err) } diff --git a/ca/tls_test.go b/ca/tls_test.go index ac1d84b6..93dbe9b3 100644 --- a/ca/tls_test.go +++ b/ca/tls_test.go @@ -8,7 +8,7 @@ import ( "crypto/tls" "crypto/x509" "encoding/hex" - "io/ioutil" + "io" "log" "net/http" "net/http/httptest" @@ -221,7 +221,7 @@ func TestClient_GetServerTLSConfig_http(t *testing.T) { return } defer resp.Body.Close() - b, err := ioutil.ReadAll(resp.Body) + b, err := io.ReadAll(resp.Body) if err != nil { t.Fatalf("ioutil.RealAdd() error = %v", err) } @@ -335,7 +335,7 @@ func TestClient_GetServerTLSConfig_renew(t *testing.T) { } defer resp.Body.Close() - b, err := ioutil.ReadAll(resp.Body) + b, err := io.ReadAll(resp.Body) if err != nil { t.Errorf("ioutil.RealAdd() error = %v", err) return @@ -374,9 +374,9 @@ func TestClient_GetServerTLSConfig_renew(t *testing.T) { } defer resp.Body.Close() - b, err := ioutil.ReadAll(resp.Body) + b, err := io.ReadAll(resp.Body) if err != nil { - t.Errorf("ioutil.RealAdd() error = %v", err) + t.Errorf("io.ReadAll() error = %v", err) return } if !bytes.Equal(b, []byte("ok")) { diff --git a/cas/stepcas/stepcas_test.go b/cas/stepcas/stepcas_test.go index f430a1dd..ad7851bf 100644 --- a/cas/stepcas/stepcas_test.go +++ b/cas/stepcas/stepcas_test.go @@ -91,7 +91,7 @@ func mustSerializeCrt(filename string, certs ...*x509.Certificate) { panic(err) } } - if err := ioutil.WriteFile(filename, buf.Bytes(), 0600); err != nil { + if err := os.WriteFile(filename, buf.Bytes(), 0600); err != nil { panic(err) } } @@ -105,7 +105,7 @@ func mustSerializeKey(filename string, key crypto.Signer) { Type: "PRIVATE KEY", Bytes: b, }) - if err := ioutil.WriteFile(filename, b, 0600); err != nil { + if err := os.WriteFile(filename, b, 0600); err != nil { panic(err) } } diff --git a/commands/app.go b/commands/app.go index 84232a6c..8c40de0e 100644 --- a/commands/app.go +++ b/commands/app.go @@ -4,7 +4,6 @@ import ( "bytes" "context" "fmt" - "io/ioutil" "net" "net/http" "os" @@ -98,7 +97,7 @@ To get a linked authority token: var password []byte if passFile != "" { - if password, err = ioutil.ReadFile(passFile); err != nil { + if password, err = os.ReadFile(passFile); err != nil { fatal(errors.Wrapf(err, "error reading %s", passFile)) } password = bytes.TrimRightFunc(password, unicode.IsSpace) @@ -106,7 +105,7 @@ To get a linked authority token: var sshHostPassword []byte if sshHostPassFile != "" { - if sshHostPassword, err = ioutil.ReadFile(sshHostPassFile); err != nil { + if sshHostPassword, err = os.ReadFile(sshHostPassFile); err != nil { fatal(errors.Wrapf(err, "error reading %s", sshHostPassFile)) } sshHostPassword = bytes.TrimRightFunc(sshHostPassword, unicode.IsSpace) @@ -114,7 +113,7 @@ To get a linked authority token: var sshUserPassword []byte if sshUserPassFile != "" { - if sshUserPassword, err = ioutil.ReadFile(sshUserPassFile); err != nil { + if sshUserPassword, err = os.ReadFile(sshUserPassFile); err != nil { fatal(errors.Wrapf(err, "error reading %s", sshUserPassFile)) } sshUserPassword = bytes.TrimRightFunc(sshUserPassword, unicode.IsSpace) @@ -122,7 +121,7 @@ To get a linked authority token: var issuerPassword []byte if issuerPassFile != "" { - if issuerPassword, err = ioutil.ReadFile(issuerPassFile); err != nil { + if issuerPassword, err = os.ReadFile(issuerPassFile); err != nil { fatal(errors.Wrapf(err, "error reading %s", issuerPassFile)) } issuerPassword = bytes.TrimRightFunc(issuerPassword, unicode.IsSpace) diff --git a/commands/export.go b/commands/export.go index 5586f576..19bfb1fa 100644 --- a/commands/export.go +++ b/commands/export.go @@ -4,7 +4,7 @@ import ( "bytes" "encoding/json" "fmt" - "io/ioutil" + "os" "unicode" "github.com/pkg/errors" @@ -72,14 +72,14 @@ func exportAction(ctx *cli.Context) error { } if passwordFile != "" { - b, err := ioutil.ReadFile(passwordFile) + b, err := os.ReadFile(passwordFile) if err != nil { return errors.Wrapf(err, "error reading %s", passwordFile) } cfg.Password = string(bytes.TrimRightFunc(b, unicode.IsSpace)) } if issuerPasswordFile != "" { - b, err := ioutil.ReadFile(issuerPasswordFile) + b, err := os.ReadFile(issuerPasswordFile) if err != nil { return errors.Wrapf(err, "error reading %s", issuerPasswordFile) } diff --git a/examples/basic-federation/client/main.go b/examples/basic-federation/client/main.go index e8c5140e..93e94f56 100644 --- a/examples/basic-federation/client/main.go +++ b/examples/basic-federation/client/main.go @@ -3,7 +3,7 @@ package main import ( "context" "fmt" - "io/ioutil" + "io" "os" "time" @@ -32,7 +32,7 @@ func main() { if err != nil { panic(err) } - b, err := ioutil.ReadAll(resp.Body) + b, err := io.ReadAll(resp.Body) resp.Body.Close() if err != nil { panic(err) diff --git a/examples/bootstrap-client/client.go b/examples/bootstrap-client/client.go index 109336be..4936eb6c 100644 --- a/examples/bootstrap-client/client.go +++ b/examples/bootstrap-client/client.go @@ -3,7 +3,7 @@ package main import ( "context" "fmt" - "io/ioutil" + "io" "os" "time" @@ -32,7 +32,7 @@ func main() { if err != nil { panic(err) } - b, err := ioutil.ReadAll(resp.Body) + b, err := io.ReadAll(resp.Body) resp.Body.Close() if err != nil { panic(err) diff --git a/kms/cloudkms/cloudkms_test.go b/kms/cloudkms/cloudkms_test.go index fefa6e2a..814e3638 100644 --- a/kms/cloudkms/cloudkms_test.go +++ b/kms/cloudkms/cloudkms_test.go @@ -4,7 +4,7 @@ import ( "context" "crypto" "fmt" - "io/ioutil" + "os" "reflect" "testing" @@ -165,7 +165,7 @@ func TestCloudKMS_Close(t *testing.T) { func TestCloudKMS_CreateSigner(t *testing.T) { keyName := "projects/p/locations/l/keyRings/k/cryptoKeys/c/cryptoKeyVersions/1" - pemBytes, err := ioutil.ReadFile("testdata/pub.pem") + pemBytes, err := os.ReadFile("testdata/pub.pem") if err != nil { t.Fatal(err) } @@ -223,7 +223,7 @@ func TestCloudKMS_CreateKey(t *testing.T) { testError := fmt.Errorf("an error") alreadyExists := status.Error(codes.AlreadyExists, "already exists") - pemBytes, err := ioutil.ReadFile("testdata/pub.pem") + pemBytes, err := os.ReadFile("testdata/pub.pem") if err != nil { t.Fatal(err) } @@ -389,7 +389,7 @@ func TestCloudKMS_GetPublicKey(t *testing.T) { keyName := "projects/p/locations/l/keyRings/k/cryptoKeys/c/cryptoKeyVersions/1" testError := fmt.Errorf("an error") - pemBytes, err := ioutil.ReadFile("testdata/pub.pem") + pemBytes, err := os.ReadFile("testdata/pub.pem") if err != nil { t.Fatal(err) } diff --git a/kms/cloudkms/signer_test.go b/kms/cloudkms/signer_test.go index a8f964f1..22d1fe19 100644 --- a/kms/cloudkms/signer_test.go +++ b/kms/cloudkms/signer_test.go @@ -7,7 +7,7 @@ import ( "crypto/x509" "fmt" "io" - "io/ioutil" + "os" "reflect" "testing" @@ -17,7 +17,7 @@ import ( ) func Test_newSigner(t *testing.T) { - pemBytes, err := ioutil.ReadFile("testdata/pub.pem") + pemBytes, err := os.ReadFile("testdata/pub.pem") if err != nil { t.Fatal(err) } @@ -70,7 +70,7 @@ func Test_newSigner(t *testing.T) { } func Test_signer_Public(t *testing.T) { - pemBytes, err := ioutil.ReadFile("testdata/pub.pem") + pemBytes, err := os.ReadFile("testdata/pub.pem") if err != nil { t.Fatal(err) } @@ -159,7 +159,7 @@ func Test_signer_Sign(t *testing.T) { } func TestSigner_SignatureAlgorithm(t *testing.T) { - pemBytes, err := ioutil.ReadFile("testdata/pub.pem") + pemBytes, err := os.ReadFile("testdata/pub.pem") if err != nil { t.Fatal(err) } diff --git a/kms/softkms/softkms_test.go b/kms/softkms/softkms_test.go index 9e293b07..907a7efe 100644 --- a/kms/softkms/softkms_test.go +++ b/kms/softkms/softkms_test.go @@ -11,7 +11,7 @@ import ( "crypto/x509" "encoding/pem" "fmt" - "io/ioutil" + "os" "reflect" "testing" @@ -78,7 +78,7 @@ func TestSoftKMS_CreateSigner(t *testing.T) { } // Read and decode file using standard packages - b, err := ioutil.ReadFile("testdata/priv.pem") + b, err := os.ReadFile("testdata/priv.pem") if err != nil { t.Fatal(err) } @@ -234,7 +234,7 @@ func TestSoftKMS_CreateKey(t *testing.T) { } func TestSoftKMS_GetPublicKey(t *testing.T) { - b, err := ioutil.ReadFile("testdata/pub.pem") + b, err := os.ReadFile("testdata/pub.pem") if err != nil { t.Fatal(err) } @@ -332,7 +332,7 @@ func TestSoftKMS_CreateDecrypter(t *testing.T) { if err != nil { t.Fatal(err) } - b, err := ioutil.ReadFile("testdata/rsa.priv.pem") + b, err := os.ReadFile("testdata/rsa.priv.pem") if err != nil { t.Fatal(err) } diff --git a/kms/sshagentkms/sshagentkms_test.go b/kms/sshagentkms/sshagentkms_test.go index d3a9e9f5..2c0a8aba 100644 --- a/kms/sshagentkms/sshagentkms_test.go +++ b/kms/sshagentkms/sshagentkms_test.go @@ -9,7 +9,6 @@ import ( "crypto/rand" "crypto/x509" "encoding/pem" - "io/ioutil" "net" "os" "os/exec" @@ -202,7 +201,7 @@ func TestNew(t *testing.T) { }) // Load ssh test fixtures - b, err := ioutil.ReadFile("testdata/ssh") + b, err := os.ReadFile("testdata/ssh") if err != nil { t.Fatal(err) } @@ -290,7 +289,7 @@ func TestSSHAgentKMS_CreateSigner(t *testing.T) { } // Read and decode file using standard packages - b, err := ioutil.ReadFile("testdata/priv.pem") + b, err := os.ReadFile("testdata/priv.pem") if err != nil { t.Fatal(err) } @@ -315,7 +314,7 @@ func TestSSHAgentKMS_CreateSigner(t *testing.T) { }) // Load ssh test fixtures - sshPubKeyStr, err := ioutil.ReadFile("testdata/ssh.pub") + sshPubKeyStr, err := os.ReadFile("testdata/ssh.pub") if err != nil { t.Fatal(err) } @@ -323,7 +322,7 @@ func TestSSHAgentKMS_CreateSigner(t *testing.T) { if err != nil { t.Fatal(err) } - b, err = ioutil.ReadFile("testdata/ssh") + b, err = os.ReadFile("testdata/ssh") if err != nil { t.Fatal(err) } @@ -499,7 +498,7 @@ func TestSSHAgentKMS_CreateKey(t *testing.T) { */ func TestSSHAgentKMS_GetPublicKey(t *testing.T) { - b, err := ioutil.ReadFile("testdata/pub.pem") + b, err := os.ReadFile("testdata/pub.pem") if err != nil { t.Fatal(err) } @@ -510,7 +509,7 @@ func TestSSHAgentKMS_GetPublicKey(t *testing.T) { } // Load ssh test fixtures - b, err = ioutil.ReadFile("testdata/ssh.pub") + b, err = os.ReadFile("testdata/ssh.pub") if err != nil { t.Fatal(err) } @@ -518,7 +517,7 @@ func TestSSHAgentKMS_GetPublicKey(t *testing.T) { if err != nil { t.Fatal(err) } - b, err = ioutil.ReadFile("testdata/ssh") + b, err = os.ReadFile("testdata/ssh") if err != nil { t.Fatal(err) } diff --git a/kms/uri/uri.go b/kms/uri/uri.go index 36e15e7d..a812f80b 100644 --- a/kms/uri/uri.go +++ b/kms/uri/uri.go @@ -3,8 +3,8 @@ package uri import ( "bytes" "encoding/hex" - "io/ioutil" "net/url" + "os" "strings" "unicode" @@ -140,7 +140,7 @@ func readFile(path string) ([]byte, error) { if err == nil && (u.Scheme == "" || u.Scheme == "file") && u.Path != "" { path = u.Path } - b, err := ioutil.ReadFile(path) + b, err := os.ReadFile(path) if err != nil { return nil, errors.Wrapf(err, "error reading %s", path) } diff --git a/scep/api/api.go b/scep/api/api.go index 4e02d4a1..0c8c469b 100644 --- a/scep/api/api.go +++ b/scep/api/api.go @@ -5,7 +5,6 @@ import ( "crypto/x509" "encoding/base64" "io" - "io/ioutil" "net/http" "net/url" "strings" @@ -167,7 +166,7 @@ func decodeSCEPRequest(r *http.Request) (SCEPRequest, error) { return SCEPRequest{}, errors.Errorf("unsupported operation: %s", operation) } case http.MethodPost: - body, err := ioutil.ReadAll(io.LimitReader(r.Body, maxPayloadSize)) + body, err := io.ReadAll(io.LimitReader(r.Body, maxPayloadSize)) if err != nil { return SCEPRequest{}, err } diff --git a/templates/templates.go b/templates/templates.go index 09416b68..4fd68ce9 100644 --- a/templates/templates.go +++ b/templates/templates.go @@ -2,7 +2,6 @@ package templates import ( "bytes" - "io/ioutil" "os" "path/filepath" "strings" @@ -167,7 +166,7 @@ func (t *Template) Load() error { switch { case t.TemplatePath != "": filename := config.StepAbs(t.TemplatePath) - b, err := ioutil.ReadFile(filename) + b, err := os.ReadFile(filename) if err != nil { return errors.Wrapf(err, "error reading %s", filename) } From 2c05f488f6f0e00aa6a1e3e19a0cf6534032b5c6 Mon Sep 17 00:00:00 2001 From: Herman Slatman Date: Sat, 13 Nov 2021 01:43:03 +0100 Subject: [PATCH 2/2] Remove support for Go 1.15 --- .github/workflows/test.yml | 2 +- go.mod | 2 +- go.sum | 3 --- 3 files changed, 2 insertions(+), 5 deletions(-) diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index bfc861c7..78b59f4b 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -14,7 +14,7 @@ jobs: runs-on: ubuntu-20.04 strategy: matrix: - go: [ '1.15', '1.16', '1.17' ] + go: [ '1.16', '1.17' ] steps: - name: Checkout diff --git a/go.mod b/go.mod index 5f234b7a..c31dca60 100644 --- a/go.mod +++ b/go.mod @@ -1,6 +1,6 @@ module github.com/smallstep/certificates -go 1.15 +go 1.16 require ( cloud.google.com/go v0.83.0 diff --git a/go.sum b/go.sum index 0f12f0a6..1ee17532 100644 --- a/go.sum +++ b/go.sum @@ -367,10 +367,8 @@ github.com/konsorten/go-windows-terminal-sequences v1.0.2 h1:DB17ag19krx9CFsz4o3 github.com/konsorten/go-windows-terminal-sequences v1.0.2/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ= github.com/kr/logfmt v0.0.0-20140226030751-b84e30acd515/go.mod h1:+0opPa2QZZtGFBFZlji/RkVcI2GknAs/DXo4wKdlNEc= github.com/kr/pretty v0.1.0/go.mod h1:dAy3ld7l9f0ibDNOQOHHMYYIIbhfbHSm3C4ZsoJORNo= -github.com/kr/pretty v0.2.0 h1:s5hAObm+yFO5uHYt5dYjxi2rXrsnmRpJx4OYvIWUaQs= github.com/kr/pretty v0.2.0/go.mod h1:ipq/a2n7PKx3OHsz4KJII5eveXtPO4qwEXGdVfWzfnI= github.com/kr/pty v1.1.1/go.mod h1:pFQYn66WHrOpPYNljwOMqo10TkYh1fy3cYio2l3bCsQ= -github.com/kr/text v0.1.0 h1:45sCR5RtlFHMR4UwH9sdQ5TC8v0qDQCHnXt+kaKSTVE= github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI= github.com/lightstep/lightstep-tracer-common/golang/gogo v0.0.0-20190605223551-bc2310a04743/go.mod h1:qklhhLq1aX+mtWk9cPHPzaBjWImj5ULL6C7HFJtXQMM= github.com/lightstep/lightstep-tracer-go v0.18.1/go.mod h1:jlF1pusYV4pidLvZ+XD0UBX0ZE6WURAspgAczcDHrL4= @@ -956,7 +954,6 @@ google.golang.org/protobuf v1.27.1/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQ gopkg.in/alecthomas/kingpin.v2 v2.2.6/go.mod h1:FMv+mEhP44yOT+4EoQTLFTRgOQ1FBLkstjWtayDeSgw= gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= gopkg.in/check.v1 v1.0.0-20180628173108-788fd7840127/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= -gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15 h1:YR8cESwS4TdDjEe65xsg0ogRM/Nc3DYOhEAlW+xobZo= gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= gopkg.in/cheggaaa/pb.v1 v1.0.25/go.mod h1:V/YB90LKu/1FcN3WVnfiiE5oMCibMjukxqG/qStrOgw= gopkg.in/errgo.v2 v2.1.0/go.mod h1:hNsd1EY+bozCKY1Ytp96fpM3vjJbqLJn88ws8XvfDNI=