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

org.jdiameter.api.ApplicationId Maven / Gradle / Ivy

/*
 * TeleStax, Open Source Cloud Communications
 * Copyright 2011-2016, TeleStax Inc. and individual contributors
 * by the @authors tag.
 *
 * This program is free software: you can redistribute it and/or modify
 * under the terms of the GNU Affero General Public License as
 * published by the Free Software Foundation; either version 3 of
 * the License, or (at your option) any later version.
 *
 * This program 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 Affero General Public License for more details.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with this program.  If not, see 
 *
 * This file incorporates work covered by the following copyright and
 * permission notice:
 *
 *   JBoss, Home of Professional Open Source
 *   Copyright 2007-2011, Red Hat, Inc. and individual contributors
 *   by the @authors tag. See the copyright.txt in the distribution for a
 *   full listing of individual contributors.
 *
 *   This is free software; you can redistribute it and/or modify it
 *   under the terms of the GNU Lesser General Public License as
 *   published by the Free Software Foundation; either version 2.1 of
 *   the License, or (at your option) any later version.
 *
 *   This software 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
 *   Lesser General Public License for more details.
 *
 *   You should have received a copy of the GNU Lesser General Public
 *   License along with this software; if not, write to the Free
 *   Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
 *   02110-1301 USA, or see the FSF site: http://www.fsf.org.
 */

package org.jdiameter.api;

import java.io.Serial;
import java.io.Serializable;

/**
 * The application Id is used to point out an application that is supported or used. It is a combination of
 * Authentication application id, Accounting application id and Vendor id.
 *
 * @author [email protected]
 * @version 1.5.1 Final
 */
public final class ApplicationId implements Serializable {

    @Serial
    private static final long serialVersionUID = 1L;

    /**
     * Undefined value of id for application identifier
     */
    public static final long UNDEFINED_VALUE = 0x0;

    /**
     * Standards-track application IDs are by Designated Expert with Specification Required [IANA]
     */
    @SuppressWarnings("all") //3rd party lib
    public interface Standard {

        long DIAMETER_COMMON_MESSAGE = 0x0;
        long NASREQ = 0x1;
        long MOBILE_IP = 0x2;
        long DIAMETER_BASE_ACCOUNTING = 0x3;
        long RELAY = 0xffffffff;

    }

    /**
     * IANA [IANA] has assigned the range 0x00000001 to 0x00ffffff for standards-track applications; and 0x01000000 -
     * 0xfffffffe for vendor specific applications, on a first-come, first-served basis. The following values are
     * allocated.
     */
    @SuppressWarnings("all") //3rd party lib
    public interface Ranges {

        long STANDARDS_TRACK_APPLICATIONS_MIN = 0x00000001;
        long STANDARDS_TRACK_APPLICATIONS_MAX = 0x00ffffff;

        long VENDOR_SPECIFIC_APPLICATIONS_MIN = 0x01000000;
        long VENDOR_SPECIFIC_APPLICATIONS_MAX = 0xfffffffe;
    }

    private long venId;
    private long authId;
    private long acctId;

    /**
     * Create instance of ApplicationId use Authentication-App-Id
     *
     * @param authAppId authentication application id
     * @return instance of class
     */
    public static ApplicationId createByAuthAppId(long authAppId) {
        return new ApplicationId(UNDEFINED_VALUE, authAppId, UNDEFINED_VALUE);
    }

    /**
     * Create instance of ApplicationId use Accounting-Applicaion-Id
     *
     * @param acchAppId accounting applicaion Id
     * @return instance of class
     */
    public static ApplicationId createByAccAppId(long acchAppId) {
        return new ApplicationId(UNDEFINED_VALUE, UNDEFINED_VALUE, acchAppId);
    }

    /**
     * Create instance of ApplicationId use Authentication-App-Id and Vendor-Id
     *
     * @param vendorId vendor specific id
     * @param authAppId authentication application id
     * @return instance of class
     */
    public static ApplicationId createByAuthAppId(long vendorId, long authAppId) {
        return new ApplicationId(vendorId, authAppId, UNDEFINED_VALUE);
    }

    /**
     * Create instance of ApplicationId use Accounting-Applicaion-Id and Vendor-Id
     *
     * @param vendorId vendor specific id
     * @param acchAppId accounting applicaion Id
     * @return instance of class
     */
    public static ApplicationId createByAccAppId(long vendorId, long acchAppId) {
        return new ApplicationId(vendorId, UNDEFINED_VALUE, acchAppId);
    }

    /**
     * Create instance
     *
     * @param vendorId vendor specific id
     * @param authAppId authentication application id
     * @param acctAppId accounting applicaion Id
     */
    private ApplicationId(long vendorId, long authAppId, long acctAppId) {
        this.authId = authAppId;
        this.acctId = acctAppId;
        this.venId = vendorId;
    }

    /**
     * @return Vendor-Isd
     */
    public long getVendorId() {
        return venId;
    }

    /**
     * @return Authentication-Application-Id
     */
    public long getAuthAppId() {
        return authId;
    }

    /**
     * @return Accounting-Application-Id
     */

    public long getAcctAppId() {
        return acctId;
    }

    /**
     * @param obj check object
     * @return true if check object equals current instance (all appId is equals)
     */

    @Override
    public boolean equals(Object obj) {
        if (obj instanceof ApplicationId) {
            ApplicationId appId = (ApplicationId) obj;
            return authId == appId.authId &&
                    acctId == appId.acctId &&
                    venId == appId.venId;
        } else {
            return false;
        }
    }

    /**
     * @return hash code of object
     */
    @Override
    public int hashCode() {
        int result;
        result = (int) (venId ^ (venId >>> 32));
        result = 31 * result + (int) (authId ^ (authId >>> 32));
        result = 31 * result + (int) (acctId ^ (acctId >>> 32));
        return result;
    }

    /**
     * @return String representation of object
     */
    @Override
    public String toString() {
        return new StringBuffer("AppId [").append("Vendor-Id:").append(venId).append("; Auth-Id:").append(authId)
                .append("; Acct-Id:").append(acctId).append("]").toString();
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy