blob: b3c36c497ca55b5603147989e9e99b3b1159c17b [file] [log] [blame]
// Licensed to the Apache Software Foundation (ASF) under one
// or more contributor license agreements. See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership. The ASF licenses this file
// to you 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 encryption
import (
"encoding/binary"
"unsafe"
"golang.org/x/xerrors"
)
// StringKeyIDRetriever implements the KeyRetriever interface GetKey
// to allow setting in keys with a string id.
type StringKeyIDRetriever map[string]string
// PutKey adds a key with the given string ID that can be retrieved
func (s StringKeyIDRetriever) PutKey(keyID, key string) {
s[keyID] = key
}
// GetKey expects the keymetadata to match one of the keys that were added
// with PutKey and panics if the key cannot be found.
func (s StringKeyIDRetriever) GetKey(keyMetadata []byte) string {
k, ok := s[*(*string)(unsafe.Pointer(&keyMetadata))]
if !ok {
panic(xerrors.Errorf("parquet: key missing for id %s", keyMetadata))
}
return k
}
// IntegerKeyIDRetriever is used for using unsigned 32bit integers as key ids.
type IntegerKeyIDRetriever map[uint32]string
// PutKey adds keys with uint32 IDs
func (i IntegerKeyIDRetriever) PutKey(keyID uint32, key string) {
i[keyID] = key
}
// GetKey expects the key metadata bytes to be a little endian uint32 which
// is then used to retrieve the key bytes. Panics if the key id cannot be found.
func (i IntegerKeyIDRetriever) GetKey(keyMetadata []byte) string {
keyID := binary.LittleEndian.Uint32(keyMetadata)
k, ok := i[keyID]
if !ok {
panic(xerrors.Errorf("parquet: key missing for id %d", keyID))
}
return k
}