1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61
|
// 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"
"fmt"
"unsafe"
)
// 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(fmt.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(fmt.Errorf("parquet: key missing for id %d", keyID))
}
return k
}
|