Jan Dittberner
65c5bac2d9
This commit provides real CRL support with persistent storage of CRLs as well as support for delta CRLs using github.com/balacode/go-delta
34 lines
1 KiB
Go
34 lines
1 KiB
Go
/*
|
|
Copyright 2021-2022 CAcert Inc.
|
|
SPDX-License-Identifier: Apache-2.0
|
|
|
|
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 revoking
|
|
|
|
import (
|
|
"crypto/x509/pkix"
|
|
"math/big"
|
|
)
|
|
|
|
// A Repository for storing certificate status information
|
|
type Repository interface {
|
|
// StoreRevocation stores information about a revoked certificate.
|
|
StoreRevocation(*pkix.RevokedCertificate) error
|
|
LoadCRL(*big.Int) ([]byte, error)
|
|
StoreCRL(*big.Int, []byte) error
|
|
RevokedCertificates() ([]pkix.RevokedCertificate, error)
|
|
NextCRLNumber() (*big.Int, error)
|
|
CleanUp()
|
|
}
|