// Copyright 2022 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 // // 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 stubkeymanager defines key managers for testing primitives. package stubkeymanager import ( "io" "google.golang.org/protobuf/proto" "github.com/google/tink/go/core/registry" "github.com/google/tink/go/internal/internalregistry" tinkpb "github.com/google/tink/go/proto/tink_go_proto" ) // StubKeyManager is a key manager for testing. type StubKeyManager struct { URL string Prim interface{} Key proto.Message KeyData *tinkpb.KeyData } var _ (registry.KeyManager) = (*StubKeyManager)(nil) // Primitive returns the stub primitive. func (km *StubKeyManager) Primitive(serializedKey []byte) (interface{}, error) { return km.Prim, nil } // NewKey returns the stub Key. func (km *StubKeyManager) NewKey(serializedKeyFormat []byte) (proto.Message, error) { return km.Key, nil } // NewKeyData returns the stub KeyData. func (km *StubKeyManager) NewKeyData(serializedKeyFormat []byte) (*tinkpb.KeyData, error) { return km.KeyData, nil } // DoesSupport returns true if this KeyManager supports key type identified by typeURL. func (km *StubKeyManager) DoesSupport(typeURL string) bool { return typeURL == km.URL } // TypeURL returns the stub type url. func (km *StubKeyManager) TypeURL() string { return km.URL } // StubPrivateKeyManager is a private key manager for testing. type StubPrivateKeyManager struct { StubKeyManager PubKeyData *tinkpb.KeyData } var _ (registry.PrivateKeyManager) = (*StubPrivateKeyManager)(nil) // PublicKeyData returns the stub public key data. func (skm *StubPrivateKeyManager) PublicKeyData(serializedKey []byte) (*tinkpb.KeyData, error) { return skm.PubKeyData, nil } // StubDerivableKeyManager is a derivable key manager for testing. type StubDerivableKeyManager struct { StubKeyManager KeyMatType tinkpb.KeyData_KeyMaterialType DerKey proto.Message DerErr error } var _ (internalregistry.DerivableKeyManager) = (*StubDerivableKeyManager)(nil) // KeyMaterialType returns the stub key material type. func (dkm *StubDerivableKeyManager) KeyMaterialType() tinkpb.KeyData_KeyMaterialType { return dkm.KeyMatType } // DeriveKey returns the stub derived key and error. func (dkm *StubDerivableKeyManager) DeriveKey(serializedKeyFormat []byte, pseudorandomness io.Reader) (proto.Message, error) { return dkm.DerKey, dkm.DerErr }