Skip to content

Commit

Permalink
feat: Introduce darwin-specific client (#80)
Browse files Browse the repository at this point in the history
Introduces a darwin-specific client under the package name "darwin" for accessing the keychain APIs directly, bypassing the RPC mechanism of the universal client.

Usage:
import "github.com/googleapis/enterprise-certificate-proxy/darwin"
  • Loading branch information
andyrzhao authored Jun 7, 2023
1 parent 399642e commit d6d5a59
Show file tree
Hide file tree
Showing 6 changed files with 68 additions and 7 deletions.
1 change: 1 addition & 0 deletions .github/workflows/test-client.yml
Original file line number Diff line number Diff line change
Expand Up @@ -28,4 +28,5 @@ jobs:
uses: golangci/golangci-lint-action@v3
with:
version: latest
working-directory: ./client
args: -E gofmt --max-same-issues 0
2 changes: 1 addition & 1 deletion build/scripts/darwin_amd64.sh
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ mkdir -p ./build/bin/darwin_amd64
# Build the signer binary
cd ./internal/signer/darwin
go build
mv signer ./../../../build/bin/darwin_amd64/ecp
mv darwin ./../../../build/bin/darwin_amd64/ecp
cd ./../../..

# Build the signer library
Expand Down
2 changes: 1 addition & 1 deletion build/scripts/darwin_arm64.sh
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ mkdir -p ./build/bin/darwin_arm64
# Build the signer binary
cd ./internal/signer/darwin
CGO_ENABLED=1 GO111MODULE=on GOARCH=arm64 go build
mv signer ./../../../build/bin/darwin_arm64/ecp
mv darwin ./../../../build/bin/darwin_arm64/ecp
cd ./../../..

# Build the signer library
Expand Down
62 changes: 62 additions & 0 deletions darwin/client.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,62 @@
// Copyright 2023 Google LLC.
// 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
//
// https://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.

//go:build darwin && cgo
// +build darwin,cgo

// Package darwin contains a darwin-specific client for accessing the keychain APIs directly,
// bypassing the RPC mechanism of the universal client.
package darwin

import (
"crypto"
"io"

"github.com/googleapis/enterprise-certificate-proxy/internal/signer/darwin/keychain"
)

// SecureKey is a public wrapper for the internal keychain implementation.
type SecureKey struct {
key *keychain.Key
}

// CertificateChain returns the SecureKey's raw X509 cert chain. This contains the public key.
func (sk *SecureKey) CertificateChain() [][]byte {
return sk.key.CertificateChain()
}

// Public returns the public key for this SecureKey.
func (sk *SecureKey) Public() crypto.PublicKey {
return sk.key.Public()
}

// Sign signs a message digest, using the specified signer options.
func (sk *SecureKey) Sign(_ io.Reader, digest []byte, opts crypto.SignerOpts) (signed []byte, err error) {
return sk.key.Sign(nil, digest, opts)
}

// Close frees up resources associated with the underlying key.
func (sk *SecureKey) Close() {
sk.key.Close()
}

// NewSecureKey returns a handle to the first available certificate and private key pair in
// the MacOS Keychain matching the issuer CN filter. This includes both the current login keychain
// for the user as well as the system keychain.
func NewSecureKey(issuerCN string) (*SecureKey, error) {
k, err := keychain.Cred(issuerCN)
if err != nil {
return nil, err
}
return &SecureKey{key: k}, nil
}
3 changes: 0 additions & 3 deletions internal/signer/darwin/go.mod

This file was deleted.

5 changes: 3 additions & 2 deletions internal/signer/darwin/signer.go
Original file line number Diff line number Diff line change
Expand Up @@ -26,9 +26,10 @@ import (
"log"
"net/rpc"
"os"
"signer/keychain"
"signer/util"
"time"

"github.com/googleapis/enterprise-certificate-proxy/internal/signer/darwin/keychain"
"github.com/googleapis/enterprise-certificate-proxy/internal/signer/darwin/util"
)

// If ECP Logging is enabled return true
Expand Down

0 comments on commit d6d5a59

Please sign in to comment.