Skip to content

Commit

Permalink
fix: unset NOTATION_USERNAME and NOTATION_PASSWORD to avoid leaking c…
Browse files Browse the repository at this point in the history
…redentials to plugin (#746)

Fix:unset credentials env after read the value (Resolves #709) 


Signed-off-by: Junjie Gao <junjiegao@microsoft.com>
  • Loading branch information
JeyJeyGao committed Jul 20, 2023
1 parent 50609fd commit 0cc39b3
Show file tree
Hide file tree
Showing 3 changed files with 60 additions and 0 deletions.
6 changes: 6 additions & 0 deletions cmd/notation/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,12 @@ func main() {
Use: "notation",
Short: "Notation - a tool to sign and verify artifacts",
SilenceUsage: true,
PersistentPreRun: func(cmd *cobra.Command, args []string) {
// unset registry credentials after read the value from environment
// to avoid leaking credentials
os.Unsetenv(defaultUsernameEnv)
os.Unsetenv(defaultPasswordEnv)
},
}
cmd.AddCommand(
signCommand(nil),
Expand Down
39 changes: 39 additions & 0 deletions cmd/notation/main_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
// Copyright The Notary Project Authors.
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

package main

import (
"os"
"testing"
)

func Test_UnsetEnvCredential(t *testing.T) {
const notationUsername = "NOTATION_USERNAME"
const notationPassword = "NOTATION_PASSWORD"
// Set environment variables for testing
os.Setenv(notationUsername, "testuser")
os.Setenv(notationPassword, "testpassword")
os.Args = []string{"notation", "version"}

main()

// check credentials environment variables are unset
if os.Getenv(notationUsername) != "" {
t.Errorf("expected %s to be unset", notationUsername)
}

if os.Getenv(notationPassword) != "" {
t.Errorf("expected %s to be unset", notationPassword)
}
}
15 changes: 15 additions & 0 deletions test/e2e/plugin/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,16 +15,31 @@ package main

import (
"encoding/json"
"errors"
"os"

"github.com/notaryproject/notation-go/plugin/proto"
"github.com/spf13/cobra"
)

const NOTATION_USERNAME = "NOTATION_USERNAME"
const NOTATION_PASSWORD = "NOTATION_PASSWORD"

func main() {
cmd := &cobra.Command{
Use: "plugin for Notation E2E test",
SilenceUsage: true,
SilenceErrors: true,
PersistentPreRunE: func(cmd *cobra.Command, args []string) error {
// check registry credentials are eliminated
if os.Getenv(NOTATION_USERNAME) != "" || os.Getenv(NOTATION_PASSWORD) != "" {
return &proto.RequestError{
Code: proto.ErrorCodeValidation,
Err: errors.New("registry credentials are not eliminated"),
}
}
return nil
},
}

cmd.AddCommand(
Expand Down

0 comments on commit 0cc39b3

Please sign in to comment.