mirror of
https://github.com/pgpainless/pgpainless.git
synced 2025-01-09 19:57:57 +01:00
Add RevocationState implementation from wot branch
This commit is contained in:
parent
405e67c0cb
commit
d019c0d5db
2 changed files with 144 additions and 13 deletions
|
@ -4,20 +4,128 @@
|
||||||
|
|
||||||
package org.pgpainless.algorithm;
|
package org.pgpainless.algorithm;
|
||||||
|
|
||||||
public enum RevocationState {
|
import org.pgpainless.util.DateUtil;
|
||||||
|
|
||||||
/**
|
import javax.annotation.Nonnull;
|
||||||
* Certificate is not revoked.
|
import java.util.Date;
|
||||||
*/
|
import java.util.NoSuchElementException;
|
||||||
notRevoked,
|
|
||||||
|
|
||||||
/**
|
public class RevocationState implements Comparable<RevocationState> {
|
||||||
* Certificate is revoked with a soft revocation.
|
|
||||||
*/
|
|
||||||
softRevoked,
|
|
||||||
|
|
||||||
/**
|
private final RevocationStateType type;
|
||||||
* Certificate is revoked with a hard revocation.
|
private final Date date;
|
||||||
*/
|
|
||||||
hardRevoked
|
private RevocationState(RevocationStateType type) {
|
||||||
|
this(type, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
private RevocationState(RevocationStateType type, Date date) {
|
||||||
|
this.type = type;
|
||||||
|
if (type == RevocationStateType.softRevoked && date == null) {
|
||||||
|
throw new NullPointerException("If type is 'softRevoked' then date cannot be null.");
|
||||||
|
}
|
||||||
|
this.date = date;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static RevocationState notRevoked() {
|
||||||
|
return new RevocationState(RevocationStateType.notRevoked);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static RevocationState softRevoked(@Nonnull Date date) {
|
||||||
|
return new RevocationState(RevocationStateType.softRevoked, date);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static RevocationState hardRevoked() {
|
||||||
|
return new RevocationState(RevocationStateType.hardRevoked);
|
||||||
|
}
|
||||||
|
|
||||||
|
public RevocationStateType getType() {
|
||||||
|
return type;
|
||||||
|
}
|
||||||
|
|
||||||
|
public @Nonnull Date getDate() {
|
||||||
|
if (!isSoftRevocation()) {
|
||||||
|
throw new NoSuchElementException("RevocationStateType is not equal to 'softRevoked'. Cannot extract date.");
|
||||||
|
}
|
||||||
|
return date;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isHardRevocation() {
|
||||||
|
return getType() == RevocationStateType.hardRevoked;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isSoftRevocation() {
|
||||||
|
return getType() == RevocationStateType.softRevoked;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isNotRevoked() {
|
||||||
|
return getType() == RevocationStateType.notRevoked;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
String out = getType().toString();
|
||||||
|
if (isSoftRevocation()) {
|
||||||
|
out = out + " (" + DateUtil.formatUTCDate(date) + ")";
|
||||||
|
}
|
||||||
|
return out;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int compareTo(@Nonnull RevocationState o) {
|
||||||
|
switch (getType()) {
|
||||||
|
case notRevoked:
|
||||||
|
if (o.isNotRevoked()) {
|
||||||
|
return 0;
|
||||||
|
} else {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
case softRevoked:
|
||||||
|
if (o.isNotRevoked()) {
|
||||||
|
return 1;
|
||||||
|
} else if (o.isSoftRevocation()) {
|
||||||
|
// Compare soft dates in reverse
|
||||||
|
return o.getDate().compareTo(getDate());
|
||||||
|
} else {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
case hardRevoked:
|
||||||
|
if (o.isHardRevocation()) {
|
||||||
|
return 0;
|
||||||
|
} else {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
default:
|
||||||
|
throw new AssertionError("Unknown type: " + type);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return type.hashCode() * 31 + (isSoftRevocation() ? getDate().hashCode() : 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object obj) {
|
||||||
|
if (obj == null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (this == obj) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (!(obj instanceof RevocationState)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
RevocationState other = (RevocationState) obj;
|
||||||
|
if (getType() != other.getType()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (isSoftRevocation()) {
|
||||||
|
return DateUtil.toSecondsPrecision(getDate()).getTime() == DateUtil.toSecondsPrecision(other.getDate()).getTime();
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,23 @@
|
||||||
|
// SPDX-FileCopyrightText: 2022 Paul Schaub <vanitasvitae@fsfe.org>
|
||||||
|
//
|
||||||
|
// SPDX-License-Identifier: Apache-2.0
|
||||||
|
|
||||||
|
package org.pgpainless.algorithm;
|
||||||
|
|
||||||
|
public enum RevocationStateType {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Certificate is not revoked.
|
||||||
|
*/
|
||||||
|
notRevoked,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Certificate is revoked with a soft revocation.
|
||||||
|
*/
|
||||||
|
softRevoked,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Certificate is revoked with a hard revocation.
|
||||||
|
*/
|
||||||
|
hardRevoked
|
||||||
|
}
|
Loading…
Reference in a new issue