package com.google.common.net; import com.google.common.base.CharMatcher; import com.google.common.base.MoreObjects; import com.google.common.base.Preconditions; import com.google.common.hash.Hashing; import com.google.common.io.ByteStreams; import com.google.common.primitives.Ints; import java.math.BigInteger; import java.net.Inet4Address; import java.net.Inet6Address; import java.net.InetAddress; import java.net.UnknownHostException; import java.nio.ByteBuffer; import java.util.Arrays; import java.util.Locale; import javax.annotation.CheckForNull; import kotlin.UShort; @ElementTypesAreNonnullByDefault /* loaded from: classes3.dex */ public final class InetAddresses { private static final int IPV4_PART_COUNT = 4; private static final int IPV6_PART_COUNT = 8; private static final char IPV4_DELIMITER = '.'; private static final CharMatcher IPV4_DELIMITER_MATCHER = CharMatcher.is(IPV4_DELIMITER); private static final char IPV6_DELIMITER = ':'; private static final CharMatcher IPV6_DELIMITER_MATCHER = CharMatcher.is(IPV6_DELIMITER); private static final Inet4Address LOOPBACK4 = (Inet4Address) forString("127.0.0.1"); private static final Inet4Address ANY4 = (Inet4Address) forString("0.0.0.0"); private InetAddresses() { } private static Inet4Address getInet4Address(byte[] bArr) { Preconditions.checkArgument(bArr.length == 4, "Byte array has invalid length for an IPv4 address: %s != 4.", bArr.length); return (Inet4Address) bytesToInetAddress(bArr); } public static InetAddress forString(String str) { byte[] ipStringToBytes = ipStringToBytes(str); if (ipStringToBytes == null) { throw formatIllegalArgumentException("'%s' is not an IP string literal.", str); } return bytesToInetAddress(ipStringToBytes); } public static boolean isInetAddress(String str) { return ipStringToBytes(str) != null; } /* JADX WARN: Code restructure failed: missing block: B:25:0x0032, code lost: if (r3 == false) goto L30; */ /* JADX WARN: Code restructure failed: missing block: B:26:0x0034, code lost: if (r2 == false) goto L26; */ /* JADX WARN: Code restructure failed: missing block: B:27:0x0036, code lost: r9 = convertDottedQuadToHex(r9); */ /* JADX WARN: Code restructure failed: missing block: B:28:0x003a, code lost: if (r9 != null) goto L26; */ /* JADX WARN: Code restructure failed: missing block: B:29:0x003c, code lost: return null; */ /* JADX WARN: Code restructure failed: missing block: B:30:0x003d, code lost: if (r1 == (-1)) goto L28; */ /* JADX WARN: Code restructure failed: missing block: B:31:0x003f, code lost: r9 = r9.substring(0, r1); */ /* JADX WARN: Code restructure failed: missing block: B:33:0x0047, code lost: return textToNumericFormatV6(r9); */ /* JADX WARN: Code restructure failed: missing block: B:34:0x0048, code lost: if (r2 == false) goto L35; */ /* JADX WARN: Code restructure failed: missing block: B:35:0x004a, code lost: if (r1 == (-1)) goto L33; */ /* JADX WARN: Code restructure failed: missing block: B:36:0x004c, code lost: return null; */ /* JADX WARN: Code restructure failed: missing block: B:38:0x0051, code lost: return textToNumericFormatV4(r9); */ /* JADX WARN: Code restructure failed: missing block: B:39:0x0052, code lost: return null; */ @javax.annotation.CheckForNull /* Code decompiled incorrectly, please refer to instructions dump. To view partially-correct add '--show-bad-code' argument */ private static byte[] ipStringToBytes(java.lang.String r9) { /* r0 = 0 r1 = r0 r2 = r1 r3 = r2 L4: int r4 = r9.length() r5 = 0 r6 = -1 if (r1 >= r4) goto L31 char r4 = r9.charAt(r1) r7 = 46 r8 = 1 if (r4 != r7) goto L17 r2 = r8 goto L2e L17: r7 = 58 if (r4 != r7) goto L20 if (r2 == 0) goto L1e return r5 L1e: r3 = r8 goto L2e L20: r7 = 37 if (r4 != r7) goto L25 goto L32 L25: r7 = 16 int r4 = java.lang.Character.digit(r4, r7) if (r4 != r6) goto L2e return r5 L2e: int r1 = r1 + 1 goto L4 L31: r1 = r6 L32: if (r3 == 0) goto L48 if (r2 == 0) goto L3d java.lang.String r9 = convertDottedQuadToHex(r9) if (r9 != 0) goto L3d return r5 L3d: if (r1 == r6) goto L43 java.lang.String r9 = r9.substring(r0, r1) L43: byte[] r9 = textToNumericFormatV6(r9) return r9 L48: if (r2 == 0) goto L52 if (r1 == r6) goto L4d return r5 L4d: byte[] r9 = textToNumericFormatV4(r9) return r9 L52: return r5 */ throw new UnsupportedOperationException("Method not decompiled: com.google.common.net.InetAddresses.ipStringToBytes(java.lang.String):byte[]"); } @CheckForNull private static byte[] textToNumericFormatV4(String str) { if (IPV4_DELIMITER_MATCHER.countIn(str) + 1 != 4) { return null; } byte[] bArr = new byte[4]; int i = 0; for (int i2 = 0; i2 < 4; i2++) { int indexOf = str.indexOf(46, i); if (indexOf == -1) { indexOf = str.length(); } try { bArr[i2] = parseOctet(str, i, indexOf); i = indexOf + 1; } catch (NumberFormatException unused) { return null; } } return bArr; } @CheckForNull private static byte[] textToNumericFormatV6(String str) { int countIn = IPV6_DELIMITER_MATCHER.countIn(str); if (countIn >= 2 && countIn <= 8) { int i = 1; int i2 = countIn + 1; int i3 = 8 - i2; boolean z = false; for (int i4 = 0; i4 < str.length() - 1; i4++) { if (str.charAt(i4) == ':' && str.charAt(i4 + 1) == ':') { if (z) { return null; } int i5 = i3 + 1; if (i4 == 0) { i5 = i3 + 2; } if (i4 == str.length() - 2) { i5++; } i3 = i5; z = true; } } if (str.charAt(0) == ':' && str.charAt(1) != ':') { return null; } if (str.charAt(str.length() - 1) == ':' && str.charAt(str.length() - 2) != ':') { return null; } if (z && i3 <= 0) { return null; } if (!z && i2 != 8) { return null; } ByteBuffer allocate = ByteBuffer.allocate(16); try { if (str.charAt(0) != ':') { i = 0; } while (i < str.length()) { int indexOf = str.indexOf(58, i); if (indexOf == -1) { indexOf = str.length(); } if (str.charAt(i) == ':') { for (int i6 = 0; i6 < i3; i6++) { allocate.putShort((short) 0); } } else { allocate.putShort(parseHextet(str, i, indexOf)); } i = indexOf + 1; } return allocate.array(); } catch (NumberFormatException unused) { } } return null; } @CheckForNull private static String convertDottedQuadToHex(String str) { int lastIndexOf = str.lastIndexOf(58) + 1; String substring = str.substring(0, lastIndexOf); byte[] textToNumericFormatV4 = textToNumericFormatV4(str.substring(lastIndexOf)); if (textToNumericFormatV4 == null) { return null; } String hexString = Integer.toHexString(((textToNumericFormatV4[0] & 255) << 8) | (textToNumericFormatV4[1] & 255)); String hexString2 = Integer.toHexString((textToNumericFormatV4[3] & 255) | ((textToNumericFormatV4[2] & 255) << 8)); return new StringBuilder(String.valueOf(substring).length() + 1 + String.valueOf(hexString).length() + String.valueOf(hexString2).length()).append(substring).append(hexString).append(":").append(hexString2).toString(); } private static byte parseOctet(String str, int i, int i2) { int i3 = i2 - i; if (i3 <= 0 || i3 > 3) { throw new NumberFormatException(); } if (i3 > 1 && str.charAt(i) == '0') { throw new NumberFormatException(); } int i4 = 0; while (i < i2) { int i5 = i4 * 10; int digit = Character.digit(str.charAt(i), 10); if (digit < 0) { throw new NumberFormatException(); } i4 = i5 + digit; i++; } if (i4 <= 255) { return (byte) i4; } throw new NumberFormatException(); } private static short parseHextet(String str, int i, int i2) { int i3 = i2 - i; if (i3 <= 0 || i3 > 4) { throw new NumberFormatException(); } int i4 = 0; while (i < i2) { i4 = (i4 << 4) | Character.digit(str.charAt(i), 16); i++; } return (short) i4; } private static InetAddress bytesToInetAddress(byte[] bArr) { try { return InetAddress.getByAddress(bArr); } catch (UnknownHostException e) { throw new AssertionError(e); } } public static String toAddrString(InetAddress inetAddress) { Preconditions.checkNotNull(inetAddress); if (inetAddress instanceof Inet4Address) { return inetAddress.getHostAddress(); } Preconditions.checkArgument(inetAddress instanceof Inet6Address); byte[] address = inetAddress.getAddress(); int[] iArr = new int[8]; for (int i = 0; i < 8; i++) { int i2 = i * 2; iArr[i] = Ints.fromBytes((byte) 0, (byte) 0, address[i2], address[i2 + 1]); } compressLongestRunOfZeroes(iArr); return hextetsToIPv6String(iArr); } private static void compressLongestRunOfZeroes(int[] iArr) { int i = -1; int i2 = -1; int i3 = -1; for (int i4 = 0; i4 < iArr.length + 1; i4++) { if (i4 >= iArr.length || iArr[i4] != 0) { if (i3 >= 0) { int i5 = i4 - i3; if (i5 > i) { i2 = i3; i = i5; } i3 = -1; } } else if (i3 < 0) { i3 = i4; } } if (i >= 2) { Arrays.fill(iArr, i2, i + i2, -1); } } private static String hextetsToIPv6String(int[] iArr) { StringBuilder sb = new StringBuilder(39); int i = 0; boolean z = false; while (i < iArr.length) { boolean z2 = iArr[i] >= 0; if (z2) { if (z) { sb.append(IPV6_DELIMITER); } sb.append(Integer.toHexString(iArr[i])); } else if (i == 0 || z) { sb.append("::"); } i++; z = z2; } return sb.toString(); } public static String toUriString(InetAddress inetAddress) { if (inetAddress instanceof Inet6Address) { String addrString = toAddrString(inetAddress); return new StringBuilder(String.valueOf(addrString).length() + 2).append("[").append(addrString).append("]").toString(); } return toAddrString(inetAddress); } public static InetAddress forUriString(String str) { InetAddress forUriStringNoThrow = forUriStringNoThrow(str); if (forUriStringNoThrow != null) { return forUriStringNoThrow; } throw formatIllegalArgumentException("Not a valid URI IP literal: '%s'", str); } @CheckForNull private static InetAddress forUriStringNoThrow(String str) { int i; Preconditions.checkNotNull(str); if (str.startsWith("[") && str.endsWith("]")) { str = str.substring(1, str.length() - 1); i = 16; } else { i = 4; } byte[] ipStringToBytes = ipStringToBytes(str); if (ipStringToBytes == null || ipStringToBytes.length != i) { return null; } return bytesToInetAddress(ipStringToBytes); } public static boolean isUriInetAddress(String str) { return forUriStringNoThrow(str) != null; } public static boolean isCompatIPv4Address(Inet6Address inet6Address) { byte b; if (!inet6Address.isIPv4CompatibleAddress()) { return false; } byte[] address = inet6Address.getAddress(); return (address[12] == 0 && address[13] == 0 && address[14] == 0 && ((b = address[15]) == 0 || b == 1)) ? false : true; } public static Inet4Address getCompatIPv4Address(Inet6Address inet6Address) { Preconditions.checkArgument(isCompatIPv4Address(inet6Address), "Address '%s' is not IPv4-compatible.", toAddrString(inet6Address)); return getInet4Address(Arrays.copyOfRange(inet6Address.getAddress(), 12, 16)); } public static boolean is6to4Address(Inet6Address inet6Address) { byte[] address = inet6Address.getAddress(); return address[0] == 32 && address[1] == 2; } public static Inet4Address get6to4IPv4Address(Inet6Address inet6Address) { Preconditions.checkArgument(is6to4Address(inet6Address), "Address '%s' is not a 6to4 address.", toAddrString(inet6Address)); return getInet4Address(Arrays.copyOfRange(inet6Address.getAddress(), 2, 6)); } /* loaded from: classes3.dex */ public static final class TeredoInfo { private final Inet4Address client; private final int flags; private final int port; private final Inet4Address server; public Inet4Address getClient() { return this.client; } public int getFlags() { return this.flags; } public int getPort() { return this.port; } public Inet4Address getServer() { return this.server; } public TeredoInfo(@CheckForNull Inet4Address inet4Address, @CheckForNull Inet4Address inet4Address2, int i, int i2) { Preconditions.checkArgument(i >= 0 && i <= 65535, "port '%s' is out of range (0 <= port <= 0xffff)", i); Preconditions.checkArgument(i2 >= 0 && i2 <= 65535, "flags '%s' is out of range (0 <= flags <= 0xffff)", i2); this.server = (Inet4Address) MoreObjects.firstNonNull(inet4Address, InetAddresses.ANY4); this.client = (Inet4Address) MoreObjects.firstNonNull(inet4Address2, InetAddresses.ANY4); this.port = i; this.flags = i2; } } public static boolean isTeredoAddress(Inet6Address inet6Address) { byte[] address = inet6Address.getAddress(); return address[0] == 32 && address[1] == 1 && address[2] == 0 && address[3] == 0; } public static TeredoInfo getTeredoInfo(Inet6Address inet6Address) { Preconditions.checkArgument(isTeredoAddress(inet6Address), "Address '%s' is not a Teredo address.", toAddrString(inet6Address)); byte[] address = inet6Address.getAddress(); Inet4Address inet4Address = getInet4Address(Arrays.copyOfRange(address, 4, 8)); int readShort = ByteStreams.newDataInput(address, 8).readShort() & UShort.MAX_VALUE; int i = 65535 & (~ByteStreams.newDataInput(address, 10).readShort()); byte[] copyOfRange = Arrays.copyOfRange(address, 12, 16); for (int i2 = 0; i2 < copyOfRange.length; i2++) { copyOfRange[i2] = (byte) (~copyOfRange[i2]); } return new TeredoInfo(inet4Address, getInet4Address(copyOfRange), i, readShort); } public static boolean isIsatapAddress(Inet6Address inet6Address) { if (isTeredoAddress(inet6Address)) { return false; } byte[] address = inet6Address.getAddress(); return (address[8] | 3) == 3 && address[9] == 0 && address[10] == 94 && address[11] == -2; } public static Inet4Address getIsatapIPv4Address(Inet6Address inet6Address) { Preconditions.checkArgument(isIsatapAddress(inet6Address), "Address '%s' is not an ISATAP address.", toAddrString(inet6Address)); return getInet4Address(Arrays.copyOfRange(inet6Address.getAddress(), 12, 16)); } public static boolean hasEmbeddedIPv4ClientAddress(Inet6Address inet6Address) { return isCompatIPv4Address(inet6Address) || is6to4Address(inet6Address) || isTeredoAddress(inet6Address); } public static Inet4Address getEmbeddedIPv4ClientAddress(Inet6Address inet6Address) { if (isCompatIPv4Address(inet6Address)) { return getCompatIPv4Address(inet6Address); } if (is6to4Address(inet6Address)) { return get6to4IPv4Address(inet6Address); } if (isTeredoAddress(inet6Address)) { return getTeredoInfo(inet6Address).getClient(); } throw formatIllegalArgumentException("'%s' has no embedded IPv4 address.", toAddrString(inet6Address)); } public static boolean isMappedIPv4Address(String str) { byte[] ipStringToBytes = ipStringToBytes(str); if (ipStringToBytes == null || ipStringToBytes.length != 16) { return false; } int i = 0; while (true) { if (i >= 10) { for (int i2 = 10; i2 < 12; i2++) { if (ipStringToBytes[i2] != -1) { return false; } } return true; } if (ipStringToBytes[i] != 0) { return false; } i++; } } public static Inet4Address getCoercedIPv4Address(InetAddress inetAddress) { boolean z; long j; if (inetAddress instanceof Inet4Address) { return (Inet4Address) inetAddress; } byte[] address = inetAddress.getAddress(); int i = 0; while (true) { if (i >= 15) { z = true; break; } if (address[i] != 0) { z = false; break; } i++; } if (z && address[15] == 1) { return LOOPBACK4; } if (z && address[15] == 0) { return ANY4; } Inet6Address inet6Address = (Inet6Address) inetAddress; if (hasEmbeddedIPv4ClientAddress(inet6Address)) { j = getEmbeddedIPv4ClientAddress(inet6Address).hashCode(); } else { j = ByteBuffer.wrap(inet6Address.getAddress(), 0, 8).getLong(); } int asInt = Hashing.murmur3_32_fixed().hashLong(j).asInt() | (-536870912); if (asInt == -1) { asInt = -2; } return getInet4Address(Ints.toByteArray(asInt)); } public static int coerceToInteger(InetAddress inetAddress) { return ByteStreams.newDataInput(getCoercedIPv4Address(inetAddress).getAddress()).readInt(); } public static BigInteger toBigInteger(InetAddress inetAddress) { return new BigInteger(1, inetAddress.getAddress()); } public static Inet4Address fromInteger(int i) { return getInet4Address(Ints.toByteArray(i)); } public static Inet4Address fromIPv4BigInteger(BigInteger bigInteger) { return (Inet4Address) fromBigInteger(bigInteger, false); } public static Inet6Address fromIPv6BigInteger(BigInteger bigInteger) { return (Inet6Address) fromBigInteger(bigInteger, true); } private static InetAddress fromBigInteger(BigInteger bigInteger, boolean z) { Preconditions.checkArgument(bigInteger.signum() >= 0, "BigInteger must be greater than or equal to 0"); int i = z ? 16 : 4; byte[] byteArray = bigInteger.toByteArray(); byte[] bArr = new byte[i]; int max = Math.max(0, byteArray.length - i); int length = byteArray.length - max; int i2 = i - length; for (int i3 = 0; i3 < max; i3++) { if (byteArray[i3] != 0) { throw formatIllegalArgumentException("BigInteger cannot be converted to InetAddress because it has more than %d bytes: %s", Integer.valueOf(i), bigInteger); } } System.arraycopy(byteArray, max, bArr, i2, length); try { return InetAddress.getByAddress(bArr); } catch (UnknownHostException e) { throw new AssertionError(e); } } public static InetAddress fromLittleEndianByteArray(byte[] bArr) throws UnknownHostException { byte[] bArr2 = new byte[bArr.length]; for (int i = 0; i < bArr.length; i++) { bArr2[i] = bArr[(bArr.length - i) - 1]; } return InetAddress.getByAddress(bArr2); } public static InetAddress decrement(InetAddress inetAddress) { byte[] address = inetAddress.getAddress(); int length = address.length - 1; while (length >= 0 && address[length] == 0) { address[length] = -1; length--; } Preconditions.checkArgument(length >= 0, "Decrementing %s would wrap.", inetAddress); address[length] = (byte) (address[length] - 1); return bytesToInetAddress(address); } public static InetAddress increment(InetAddress inetAddress) { byte[] address = inetAddress.getAddress(); int length = address.length - 1; while (true) { if (length < 0 || address[length] != -1) { break; } address[length] = 0; length--; } Preconditions.checkArgument(length >= 0, "Incrementing %s would wrap.", inetAddress); address[length] = (byte) (address[length] + 1); return bytesToInetAddress(address); } public static boolean isMaximum(InetAddress inetAddress) { for (byte b : inetAddress.getAddress()) { if (b != -1) { return false; } } return true; } private static IllegalArgumentException formatIllegalArgumentException(String str, Object... objArr) { return new IllegalArgumentException(String.format(Locale.ROOT, str, objArr)); } }