go-openssl/digest.go
Jeff Wendling 4d3c3b16ef support session resumption and hooking into the ticket callback
Change-Id: I8e12e4c1f0a8b350853a41636035baf1cfb0c952
2015-06-09 20:31:03 +00:00

54 lines
1.4 KiB
Go

// Copyright (C) 2015 Space Monkey, Inc.
//
// 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.
// +build cgo
package openssl
// #include <openssl/evp.h>
import "C"
import (
"fmt"
"unsafe"
)
// Digest represents and openssl message digest.
type Digest struct {
ptr *C.EVP_MD
}
// GetDigestByName returns the Digest with the name or nil and an error if the
// digest was not found.
func GetDigestByName(name string) (*Digest, error) {
cname := C.CString(name)
defer C.free(unsafe.Pointer(cname))
p := C.EVP_get_digestbyname(cname)
if p == nil {
return nil, fmt.Errorf("Digest %v not found", name)
}
// we can consider digests to use static mem; don't need to free
return &Digest{ptr: p}, nil
}
// GetDigestByName returns the Digest with the NID or nil and an error if the
// digest was not found.
func GetDigestByNid(nid NID) (*Digest, error) {
sn, err := Nid2ShortName(nid)
if err != nil {
return nil, err
}
return GetDigestByName(sn)
}