Merge pull request #150 from cquintana92/feature/lock-global-pgp-fields

Use a lock to protect global pgp fields from concurrent read/write operations
This commit is contained in:
wussler 2021-10-19 10:10:18 +02:00 committed by GitHub
commit ff2d068b47
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 26 additions and 3 deletions

View file

@ -12,10 +12,10 @@ jobs:
runs-on: macos-latest runs-on: macos-latest
steps: steps:
- name: Set up xcode 12.2 - name: Set up xcode 13.0
uses: maxim-lobanov/setup-xcode@v1 uses: maxim-lobanov/setup-xcode@v1
with: with:
xcode-version: 12.2 xcode-version: 13.0
id: xcode id: xcode
- name: Set up Go 1.x - name: Set up Go 1.x

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/), 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). 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 ## [2.2.4] 2021-09-29
### Fixed ### Fixed
- Use the provided `verifyTime` instead of the current time when verifying embedded signatures. - 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 provides a high-level API for common OpenPGP functionality.
package crypto package crypto
import "sync"
// GopenPGP is used as a "namespace" for many of the functions in this package. // 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. // It is a struct that keeps track of time skew between server and client.
type GopenPGP struct { type GopenPGP struct {
latestServerTime int64 latestServerTime int64
generationOffset int64 generationOffset int64
lock *sync.RWMutex
} }
var pgp = GopenPGP{} var pgp = GopenPGP{
latestServerTime: 0,
generationOffset: 0,
lock: &sync.RWMutex{},
}
// clone returns a clone of the byte slice. Internal function used to make sure // clone returns a clone of the byte slice. Internal function used to make sure
// we don't retain a reference to external data. // we don't retain a reference to external data.

View file

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