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
|
// Copyright The Notary Project Authors.
// 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 tspclient
import (
"fmt"
"time"
)
// Timestamp denotes the time at which the timestamp token was created by the TSA
//
// Reference: RFC 3161 2.4.2
type Timestamp struct {
// Value is the GenTime of TSTInfo
Value time.Time
// Accuracy is the Accuracy of TSTInfo
Accuracy time.Duration
}
// BoundedBefore returns true if the upper limit of the time at which the
// timestamp token was created is before or equal to u.
//
// Reference: RFC 3161 2.4.2
func (t *Timestamp) BoundedBefore(u time.Time) bool {
timestampUpperLimit := t.Value.Add(t.Accuracy)
return timestampUpperLimit.Before(u) || timestampUpperLimit.Equal(u)
}
// BoundedAfter returns true if the lower limit of the time at which the
// timestamp token was created is after or equal to u.
//
// Reference: RFC 3161 2.4.2
func (t *Timestamp) BoundedAfter(u time.Time) bool {
timestampLowerLimit := t.Value.Add(-t.Accuracy)
return timestampLowerLimit.After(u) || timestampLowerLimit.Equal(u)
}
// Format returns a string of t in format layout.
// The output is a timestamp range calculated with its accuracy.
func (t *Timestamp) Format(layout string) string {
lowerBound := t.Value.Add(-t.Accuracy)
upperBound := t.Value.Add(t.Accuracy)
return fmt.Sprintf("[%s, %s]", lowerBound.Format(layout), upperBound.Format(layout))
}
|