/* * Copyright (C) 2020 The Android Open Source Project * * 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 android.net.ipsec.ike.ike3gpp; import android.annotation.NonNull; import android.annotation.Nullable; import android.annotation.SuppressLint; import android.annotation.SystemApi; import android.net.ipsec.ike.IkeManager; import com.android.internal.net.ipsec.ike.ike3gpp.Ike3gppDeviceIdentityUtils; import java.util.Objects; /** * Ike3gppParams is used to configure 3GPP-specific parameters to be used during an IKE Session. * * @see 3GPP ETSI TS 24.302: Access to the 3GPP Evolved Packet Core (EPC) via non-3GPP access * networks * @hide */ @SystemApi public final class Ike3gppParams { /** If the PDU Session ID is not set, it will be reported as 0. */ // NoByteOrShort: using byte to be consistent with the PDU Session ID specification @SuppressLint("NoByteOrShort") public static final byte PDU_SESSION_ID_UNSET = 0; private final byte mPduSessionId; private final String mDeviceIdentity; private Ike3gppParams(byte pduSessionId, @Nullable String deviceIdentity) { mPduSessionId = pduSessionId; mDeviceIdentity = deviceIdentity; } /** * Retrieves the PDU Session ID for this Ike3gppParams. * *
If the PDU Session ID was not set and this method is called, {@link PDU_SESSION_ID_UNSET} * will be returned. */ // NoByteOrShort: using byte to be consistent with the PDU Session ID specification @SuppressLint("NoByteOrShort") public byte getPduSessionId() { return mPduSessionId; } /** * Returns true if the PDU Session ID is set for this instance. * * @hide */ public boolean hasPduSessionId() { return mPduSessionId != PDU_SESSION_ID_UNSET; } /** * Retrieves the Device Identity for this Ike3gppParams. * *
If the Device Identity was not set and this method is called, null is returned */ public @Nullable String getMobileDeviceIdentity() { return mDeviceIdentity; } @Override public int hashCode() { return Objects.hash(mPduSessionId, mDeviceIdentity); } @Override public boolean equals(Object o) { if (this == o) return true; if (!(o instanceof Ike3gppParams)) return false; Ike3gppParams that = (Ike3gppParams) o; return ((mPduSessionId == that.mPduSessionId) && Objects.equals(mDeviceIdentity, that.mDeviceIdentity)); } @Override public String toString() { return new StringBuilder() .append("Ike3gppParams={ ") .append("mPduSessionId=") .append(String.format("%02X ", mPduSessionId)) .append("mDeviceIdentity=") .append(IkeManager.getIkeLog().pii(String.format("%16s ", mDeviceIdentity))) .append(" }") .toString(); } /** This class can be used to incrementally construct an {@link Ike3gppParams}. */ public static final class Builder { private byte mPduSessionId = PDU_SESSION_ID_UNSET; private String mDeviceIdentity; /** * Sets the PDU Session ID to be used for the 3GPP N1_MODE_CAPABILITY payload. * *
Setting the PDU Session ID will configure the IKE Session to notify the server that it * supports N1_MODE. * *
{@link PDU_SESSION_ID_UNSET} will clear the previously-set PDU Session ID. * * @see TS 24.007 Section 11.2.3.1b for the definition of PDU Session ID encoding * @see TS 24.302 Section 7.2.2 for context on PDU Session ID usage * @see TS 24.302 Section 8.2.9.15 for a description of the N1_MODE_CAPABILITY payload * @param pduSessionId the PDU Session ID value to be used in this IKE Session * @return Builder this, to facilitate chaining */ // NoByteOrShort: using byte to be consistent with the PDU Session ID specification @NonNull public Builder setPduSessionId(@SuppressLint("NoByteOrShort") byte pduSessionId) { mPduSessionId = pduSessionId; return this; } /** * Setting the device identity (IMEI or IMEISV) will enable Mobile Device Identity * Signalling support. * * @see 3GPP 24.302 Section 7.2.6 for details of signaling exchange * @param deviceIdentity String representing decimal digits of IMEI(SV). IMEI is 15 digits * and IMEISV is 16 digits long as per spec 3GPP TS 23.300. The implementation infers * the Identity Type (IMEI or IMEISV) based on the length of the deviceIdentity passed * in. A string of invalid length will result in an exception during build(). If the * device identity is set, EAP-AKA MUST be configured to be an acceptable auth method. * Device identity can be unset by passing null. * @return Builder this, to facilitate chaining */ @NonNull public Builder setMobileDeviceIdentity(@Nullable String deviceIdentity) { mDeviceIdentity = deviceIdentity; return this; } /** * Validates and builds the {@link Ike3gppParams}. * * @return Ike3gppParams the validated Ike3gppParams */ @NonNull public Ike3gppParams build() { if (mDeviceIdentity != null) { if (!Ike3gppDeviceIdentityUtils.isValidDeviceIdentity(mDeviceIdentity)) { throw new IllegalArgumentException( "valid device identity should be 15 or 16 digits or set to null"); } } return new Ike3gppParams(mPduSessionId, mDeviceIdentity); } } }