Lock global gopenpgp fields

This commit is contained in:
Carlos Quintana 2021-10-18 11:33:02 +02:00 committed by Carlos Quintana
parent d1b2846135
commit 9f25490f61
No known key found for this signature in database
GPG key ID: 68324E212E167F8E
3 changed files with 24 additions and 1 deletions

View file

@ -4,6 +4,10 @@ All notable changes to this project will be documented in this file.
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
## [Unreleased]
### Fixed
- Protect the global `pgp` variable fields with a lock.
## [2.2.4] 2021-09-29
### Fixed
- Use the provided `verifyTime` instead of the current time when verifying embedded signatures.

View file

@ -1,14 +1,21 @@
// Package crypto provides a high-level API for common OpenPGP functionality.
package crypto
import "sync"
// GopenPGP is used as a "namespace" for many of the functions in this package.
// It is a struct that keeps track of time skew between server and client.
type GopenPGP struct {
latestServerTime int64
generationOffset int64
lock *sync.Mutex
}
var pgp = GopenPGP{}
var pgp = GopenPGP{
latestServerTime: 0,
generationOffset: 0,
lock: &sync.Mutex{},
}
// clone returns a clone of the byte slice. Internal function used to make sure
// we don't retain a reference to external data.

View file

@ -6,6 +6,9 @@ import (
// UpdateTime updates cached time.
func UpdateTime(newTime int64) {
pgp.lock.Lock()
defer pgp.lock.Unlock()
if newTime > pgp.latestServerTime {
pgp.latestServerTime = newTime
}
@ -13,6 +16,9 @@ func UpdateTime(newTime int64) {
// SetKeyGenerationOffset updates the offset when generating keys.
func SetKeyGenerationOffset(offset int64) {
pgp.lock.Lock()
defer pgp.lock.Unlock()
pgp.generationOffset = offset
}
@ -30,6 +36,9 @@ func GetTime() time.Time {
// getNow returns the latest server time.
func getNow() time.Time {
pgp.lock.Lock()
defer pgp.lock.Unlock()
if pgp.latestServerTime == 0 {
return time.Now()
}
@ -44,6 +53,9 @@ func getTimeGenerator() func() time.Time {
// getNowKeyGenerationOffset returns the current time with the key generation offset.
func getNowKeyGenerationOffset() time.Time {
pgp.lock.Lock()
defer pgp.lock.Unlock()
if pgp.latestServerTime == 0 {
return time.Unix(time.Now().Unix()+pgp.generationOffset, 0)
}