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

com.codename1.io.AccessToken Maven / Gradle / Ivy

/*
 * Copyright (c) 2008, 2010, Oracle and/or its affiliates. All rights reserved.
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
 * This code is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License version 2 only, as
 * published by the Free Software Foundation.  Oracle designates this
 * particular file as subject to the "Classpath" exception as provided
 * by Oracle in the LICENSE file that accompanied this code.
 *
 * This code is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
 * version 2 for more details (a copy is included in the LICENSE file that
 * accompanied this code).
 *
 * You should have received a copy of the GNU General Public License version
 * 2 along with this work; if not, write to the Free Software Foundation,
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 *
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores
 * CA 94065 USA or visit www.oracle.com if you need additional information or
 * have any questions.
 */
package com.codename1.io;

import java.io.DataInputStream;
import java.io.DataOutputStream;
import java.io.IOException;
import java.util.Date;
import com.codename1.compat.java.util.Objects;
import com.codename1.util.DateUtil;

/**
 * This class represent an access token.
 * 
 * @author Chen
 */
public class AccessToken implements Externalizable{

   
    
    private String token;
    
    /**
     * When the token expires.  Generally this is a numeric string obtained
     * from the "expires" token of an oauth2 request, signifying the number of seconds
     * from the time of issue that the token is valid for.
     */
    private String expires;
    
    /**
     * The expiry date of the token.  Prefer this value over the {@link #expires} value
     * since the expires value may just be the number of seconds that the access token is good 
     * for since it was generated - and we may not have that information stored.
     * @since 7.0
     */
    private Date expiryDate;
    
    private String refreshToken;
    
    private String identityToken;

    /**
     * Constructor with parameters
     * 
     * @param token the token string
     * @param expires the access token expires date
     */ 
    public AccessToken(String token, String expires) {
        this(token, expires, null);
    }
    
    /**
     * Constructor with parameters
     * 
     * @param token the token string
     * @param expires the access token expires date
     * @param refreshToken The refresh token.
     * @ince 7.0
     */ 
    public AccessToken(String token, String expires, String refreshToken) {
        this(token, expires, refreshToken, null);
    }
    
    /**
     * Constructor with parameters
     * 
     * @param token the token string
     * @param expires the access token expires date
     * @param refreshToken The refresh token.
     * @param identityToken The identity token
     * @ince 7.0
     */ 
    public AccessToken(String token, String expires, String refreshToken, String identityToken) {
        this.token = token;
        this.expires = expires;
        this.expiryDate = parseDate(expires);
        this.refreshToken = refreshToken;
        this.identityToken = identityToken;
    }
    
    /**
     * 
     * @param Token The token.
     * @param expiryDate The expiry date.
     * @since 7.0
     */
    public static AccessToken createWithExpiryDate(String token, Date expiryDate) {
        AccessToken out = new AccessToken(token, null);
        
        out.expiryDate = expiryDate;
        return out;
    }
    
    /**
     * @since 7.0
     */
    public AccessToken() {
        
    }

    /**
     * Simple getter
     * @return the token string
     */ 
    public String getToken() {
        return token;
    }

    /**
     * Simple getter
     * @return the expires date
     */ 
    public String getExpires() {
        return expires;
    }

    @Override
    public int getVersion() {
        return 4;
    }

    @Override
    public void externalize(DataOutputStream out) throws IOException {
        Util.writeUTF(token, out);
        Util.writeUTF(expires, out);
        Util.writeObject(expiryDate, out);
        Util.writeUTF(refreshToken, out);
        Util.writeUTF(identityToken, out);
    }

    @Override
    public void internalize(int version, DataInputStream in) throws IOException {
        token = Util.readUTF(in);
        expires = Util.readUTF(in);
        if (version >= 2) {
            expiryDate = (Date)Util.readObject(in);
        }
        if (version >= 3) {
            refreshToken = Util.readUTF(in);
        }
        if (version >= 4) {
            identityToken = Util.readUTF(in);
        }
    }

    /**
     * Gets refresh token.
     * @return Refresh token.
     * @since 7.0
     */
    public String getRefreshToken() {
        return refreshToken;
    }
    
    /**
     * Sets refresh token.
     * 
     * @param refreshToken The refresh token.
     * @since 7.0
     */
    public void setRefreshToken(String refreshToken) {
        this.refreshToken = refreshToken;
    }
    
    @Override
    public String getObjectId() {
        return "AccessToken";
    }

    @Override
    public boolean equals(Object obj) {
        if (obj instanceof AccessToken) {
            AccessToken tok = (AccessToken)obj;
            return Objects.equals(token, tok.token) && Objects.equals(expiryDate, tok.expiryDate) ;
        }
        return super.equals(obj);
    }

    @Override
    public int hashCode() {
        int hash = 3;
        hash = 53 * hash + (this.token != null ? this.token.hashCode() : 0);
        hash = 53 * hash + (this.expiryDate != null ? this.expiryDate.hashCode() : 0);
        return hash;
    }

    @Override
    public String toString() {
        return "AccessToken {"+token+", expires="+expiryDate+"}";
    }
    
    
    
    /**
     * Parses an integer value as a string.  Automatically truncates at first
     * decimal place.  
     * @param str A numeric string
     * @return The Long value of the string, or null if it couldn't be parsed.
     */
    private static Long parseLong(String str) {
        if (str == null) {
            return null;
        }
        int decimalPos = str.indexOf('.');
        if (decimalPos >= 0) {
            str = str.substring(0, decimalPos);
        }
        
        char[] chars = str.toCharArray();
        int len = chars.length;
        
        for (int i=0; i




© 2015 - 2025 Weber Informatics LLC | Privacy Policy