All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.nimbusds.jwt.util.DateUtils Maven / Gradle / Ivy

Go to download

Java library for Javascript Object Signing and Encryption (JOSE) and JSON Web Tokens (JWT)

There is a newer version: 9.48
Show newest version
/*
 * nimbus-jose-jwt
 *
 * Copyright 2012-2016, Connect2id Ltd.
 *
 * 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 com.nimbusds.jwt.util;


import java.util.Date;


/**
 * Date utilities.
 */
public class DateUtils {


	/**
	 * Converts the specified date object to a Unix epoch time in seconds.
	 *
	 * @param date The date. Must not be {@code null}.
	 *
	 * @return The Unix epoch time, in seconds.
	 */
	public static long toSecondsSinceEpoch(final Date date) {

		return date.getTime() / 1000L;
	}


	/**
	 * Converts the specified Unix epoch time in seconds to a date object.
	 *
	 * @param time The Unix epoch time, in seconds. Must not be negative.
	 *
	 * @return The date.
	 */
	public static Date fromSecondsSinceEpoch(final long time) {

		return new Date(time * 1000L);
	}


	/**
	 * Check if the specified date is after the specified reference, given
	 * the maximum accepted negative clock skew.
	 *
	 * 

Formula: * *

	 * return date + clock_skew > reference
	 * 
* * Example: Ensure a JWT expiration (exp) timestamp is after the * current time, with a minute of acceptable clock skew. * *
	 * boolean valid = DateUtils.isAfter(exp, new Date(), 60);
	 * 
* * @param date The date to check. Must not be * {@code null}. * @param reference The reference date (e.g. the current * time). Must not be {@code null}. * @param maxClockSkewSeconds The maximum acceptable negative clock * skew of the date value to check, in * seconds. * * @return {@code true} if the date is before the reference, plus the * maximum accepted clock skew, else {@code false}. */ public static boolean isAfter(final Date date, final Date reference, final long maxClockSkewSeconds) { return new Date(date.getTime() + maxClockSkewSeconds*1000L).after(reference); } /** * Checks if the specified date is before the specified reference, * given the maximum accepted positive clock skew. * *

Formula: * *

	 * return date - clock_skew < reference
	 * 
* * Example: Ensure a JWT issued-at (iat) timestamp is before the * current time, with a minute of acceptable clock skew. * *
	 * boolean valid = DateUtils.isBefore(iat, new Date(), 60);
	 * 
* * @param date The date to check. Must not be * {@code null}. * @param reference The reference date (e.g. the current * time). Must not be {@code null}. * @param maxClockSkewSeconds The maximum acceptable clock skew of the * date value to check, in seconds. * * @return {@code true} if the date is before the reference, minus the * maximum accepted clock skew, else {@code false}. */ public static boolean isBefore(final Date date, final Date reference, final long maxClockSkewSeconds) { return new Date(date.getTime() - maxClockSkewSeconds*1000L).before(reference); } /** * Prevents instantiation. */ private DateUtils() { } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy