OkHostnameVerifier.smali 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571
  1. .class public final Lokhttp3/internal/tls/OkHostnameVerifier;
  2. .super Ljava/lang/Object;
  3. .source ""
  4. # interfaces
  5. .implements Ljavax/net/ssl/HostnameVerifier;
  6. # static fields
  7. .field private static final ALT_DNS_NAME:I = 0x2
  8. .field private static final ALT_IPA_NAME:I = 0x7
  9. .field public static final INSTANCE:Lokhttp3/internal/tls/OkHostnameVerifier;
  10. # direct methods
  11. .method static constructor <clinit>()V
  12. .locals 1
  13. new-instance v0, Lokhttp3/internal/tls/OkHostnameVerifier;
  14. invoke-direct {v0}, Lokhttp3/internal/tls/OkHostnameVerifier;-><init>()V
  15. sput-object v0, Lokhttp3/internal/tls/OkHostnameVerifier;->INSTANCE:Lokhttp3/internal/tls/OkHostnameVerifier;
  16. return-void
  17. .end method
  18. .method private constructor <init>()V
  19. .locals 0
  20. invoke-direct {p0}, Ljava/lang/Object;-><init>()V
  21. return-void
  22. .end method
  23. .method public static allSubjectAltNames(Ljava/security/cert/X509Certificate;)Ljava/util/List;
  24. .locals 4
  25. .annotation system Ldalvik/annotation/Signature;
  26. value = {
  27. "(",
  28. "Ljava/security/cert/X509Certificate;",
  29. ")",
  30. "Ljava/util/List<",
  31. "Ljava/lang/String;",
  32. ">;"
  33. }
  34. .end annotation
  35. const/4 v0, 0x7
  36. invoke-static {p0, v0}, Lokhttp3/internal/tls/OkHostnameVerifier;->getSubjectAltNames(Ljava/security/cert/X509Certificate;I)Ljava/util/List;
  37. move-result-object v0
  38. const/4 v1, 0x2
  39. invoke-static {p0, v1}, Lokhttp3/internal/tls/OkHostnameVerifier;->getSubjectAltNames(Ljava/security/cert/X509Certificate;I)Ljava/util/List;
  40. move-result-object p0
  41. new-instance v1, Ljava/util/ArrayList;
  42. invoke-interface {v0}, Ljava/util/List;->size()I
  43. move-result v2
  44. invoke-interface {p0}, Ljava/util/List;->size()I
  45. move-result v3
  46. add-int/2addr v2, v3
  47. invoke-direct {v1, v2}, Ljava/util/ArrayList;-><init>(I)V
  48. invoke-interface {v1, v0}, Ljava/util/List;->addAll(Ljava/util/Collection;)Z
  49. invoke-interface {v1, p0}, Ljava/util/List;->addAll(Ljava/util/Collection;)Z
  50. return-object v1
  51. .end method
  52. .method private static getSubjectAltNames(Ljava/security/cert/X509Certificate;I)Ljava/util/List;
  53. .locals 4
  54. .annotation system Ldalvik/annotation/Signature;
  55. value = {
  56. "(",
  57. "Ljava/security/cert/X509Certificate;",
  58. "I)",
  59. "Ljava/util/List<",
  60. "Ljava/lang/String;",
  61. ">;"
  62. }
  63. .end annotation
  64. new-instance v0, Ljava/util/ArrayList;
  65. invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
  66. :try_start_0
  67. invoke-virtual {p0}, Ljava/security/cert/X509Certificate;->getSubjectAlternativeNames()Ljava/util/Collection;
  68. move-result-object p0
  69. if-nez p0, :cond_0
  70. invoke-static {}, Ljava/util/Collections;->emptyList()Ljava/util/List;
  71. move-result-object p0
  72. return-object p0
  73. :cond_0
  74. invoke-interface {p0}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;
  75. move-result-object p0
  76. :cond_1
  77. :goto_0
  78. invoke-interface {p0}, Ljava/util/Iterator;->hasNext()Z
  79. move-result v1
  80. if-eqz v1, :cond_4
  81. invoke-interface {p0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
  82. move-result-object v1
  83. check-cast v1, Ljava/util/List;
  84. if-eqz v1, :cond_1
  85. invoke-interface {v1}, Ljava/util/List;->size()I
  86. move-result v2
  87. const/4 v3, 0x2
  88. if-ge v2, v3, :cond_2
  89. goto :goto_0
  90. :cond_2
  91. const/4 v2, 0x0
  92. invoke-interface {v1, v2}, Ljava/util/List;->get(I)Ljava/lang/Object;
  93. move-result-object v2
  94. check-cast v2, Ljava/lang/Integer;
  95. if-nez v2, :cond_3
  96. goto :goto_0
  97. :cond_3
  98. invoke-virtual {v2}, Ljava/lang/Integer;->intValue()I
  99. move-result v2
  100. if-ne v2, p1, :cond_1
  101. const/4 v2, 0x1
  102. invoke-interface {v1, v2}, Ljava/util/List;->get(I)Ljava/lang/Object;
  103. move-result-object v1
  104. check-cast v1, Ljava/lang/String;
  105. if-eqz v1, :cond_1
  106. invoke-interface {v0, v1}, Ljava/util/List;->add(Ljava/lang/Object;)Z
  107. :try_end_0
  108. .catch Ljava/security/cert/CertificateParsingException; {:try_start_0 .. :try_end_0} :catch_0
  109. goto :goto_0
  110. :cond_4
  111. return-object v0
  112. :catch_0
  113. invoke-static {}, Ljava/util/Collections;->emptyList()Ljava/util/List;
  114. move-result-object p0
  115. return-object p0
  116. .end method
  117. .method private verifyHostname(Ljava/lang/String;Ljava/security/cert/X509Certificate;)Z
  118. .locals 6
  119. sget-object v0, Ljava/util/Locale;->US:Ljava/util/Locale;
  120. invoke-virtual {p1, v0}, Ljava/lang/String;->toLowerCase(Ljava/util/Locale;)Ljava/lang/String;
  121. move-result-object p1
  122. const/4 v0, 0x2
  123. invoke-static {p2, v0}, Lokhttp3/internal/tls/OkHostnameVerifier;->getSubjectAltNames(Ljava/security/cert/X509Certificate;I)Ljava/util/List;
  124. move-result-object v0
  125. invoke-interface {v0}, Ljava/util/List;->size()I
  126. move-result v1
  127. const/4 v2, 0x1
  128. const/4 v3, 0x0
  129. const/4 v4, 0x0
  130. const/4 v5, 0x0
  131. :goto_0
  132. if-ge v4, v1, :cond_1
  133. invoke-interface {v0, v4}, Ljava/util/List;->get(I)Ljava/lang/Object;
  134. move-result-object v5
  135. check-cast v5, Ljava/lang/String;
  136. invoke-virtual {p0, p1, v5}, Lokhttp3/internal/tls/OkHostnameVerifier;->verifyHostname(Ljava/lang/String;Ljava/lang/String;)Z
  137. move-result v5
  138. if-eqz v5, :cond_0
  139. return v2
  140. :cond_0
  141. add-int/lit8 v4, v4, 0x1
  142. const/4 v5, 0x1
  143. goto :goto_0
  144. :cond_1
  145. if-nez v5, :cond_2
  146. invoke-virtual {p2}, Ljava/security/cert/X509Certificate;->getSubjectX500Principal()Ljavax/security/auth/x500/X500Principal;
  147. move-result-object p2
  148. new-instance v0, Lokhttp3/internal/tls/DistinguishedNameParser;
  149. invoke-direct {v0, p2}, Lokhttp3/internal/tls/DistinguishedNameParser;-><init>(Ljavax/security/auth/x500/X500Principal;)V
  150. const-string p2, "cn"
  151. invoke-virtual {v0, p2}, Lokhttp3/internal/tls/DistinguishedNameParser;->findMostSpecific(Ljava/lang/String;)Ljava/lang/String;
  152. move-result-object p2
  153. if-eqz p2, :cond_2
  154. invoke-virtual {p0, p1, p2}, Lokhttp3/internal/tls/OkHostnameVerifier;->verifyHostname(Ljava/lang/String;Ljava/lang/String;)Z
  155. move-result p1
  156. return p1
  157. :cond_2
  158. return v3
  159. .end method
  160. .method private verifyIpAddress(Ljava/lang/String;Ljava/security/cert/X509Certificate;)Z
  161. .locals 4
  162. const/4 v0, 0x7
  163. invoke-static {p2, v0}, Lokhttp3/internal/tls/OkHostnameVerifier;->getSubjectAltNames(Ljava/security/cert/X509Certificate;I)Ljava/util/List;
  164. move-result-object p2
  165. invoke-interface {p2}, Ljava/util/List;->size()I
  166. move-result v0
  167. const/4 v1, 0x0
  168. const/4 v2, 0x0
  169. :goto_0
  170. if-ge v2, v0, :cond_1
  171. invoke-interface {p2, v2}, Ljava/util/List;->get(I)Ljava/lang/Object;
  172. move-result-object v3
  173. check-cast v3, Ljava/lang/String;
  174. invoke-virtual {p1, v3}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
  175. move-result v3
  176. if-eqz v3, :cond_0
  177. const/4 p1, 0x1
  178. return p1
  179. :cond_0
  180. add-int/lit8 v2, v2, 0x1
  181. goto :goto_0
  182. :cond_1
  183. return v1
  184. .end method
  185. # virtual methods
  186. .method public verify(Ljava/lang/String;Ljava/security/cert/X509Certificate;)Z
  187. .locals 1
  188. invoke-static {p1}, Lokhttp3/internal/Util;->verifyAsIpAddress(Ljava/lang/String;)Z
  189. move-result v0
  190. if-eqz v0, :cond_0
  191. invoke-direct {p0, p1, p2}, Lokhttp3/internal/tls/OkHostnameVerifier;->verifyIpAddress(Ljava/lang/String;Ljava/security/cert/X509Certificate;)Z
  192. move-result p1
  193. goto :goto_0
  194. :cond_0
  195. invoke-direct {p0, p1, p2}, Lokhttp3/internal/tls/OkHostnameVerifier;->verifyHostname(Ljava/lang/String;Ljava/security/cert/X509Certificate;)Z
  196. move-result p1
  197. :goto_0
  198. return p1
  199. .end method
  200. .method public verify(Ljava/lang/String;Ljavax/net/ssl/SSLSession;)Z
  201. .locals 1
  202. const/4 v0, 0x0
  203. :try_start_0
  204. invoke-interface {p2}, Ljavax/net/ssl/SSLSession;->getPeerCertificates()[Ljava/security/cert/Certificate;
  205. move-result-object p2
  206. aget-object p2, p2, v0
  207. check-cast p2, Ljava/security/cert/X509Certificate;
  208. invoke-virtual {p0, p1, p2}, Lokhttp3/internal/tls/OkHostnameVerifier;->verify(Ljava/lang/String;Ljava/security/cert/X509Certificate;)Z
  209. move-result p1
  210. :try_end_0
  211. .catch Ljavax/net/ssl/SSLException; {:try_start_0 .. :try_end_0} :catch_0
  212. return p1
  213. :catch_0
  214. return v0
  215. .end method
  216. .method public verifyHostname(Ljava/lang/String;Ljava/lang/String;)Z
  217. .locals 7
  218. const/4 v0, 0x0
  219. if-eqz p1, :cond_a
  220. invoke-virtual {p1}, Ljava/lang/String;->length()I
  221. move-result v1
  222. if-eqz v1, :cond_a
  223. const-string v1, "."
  224. invoke-virtual {p1, v1}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
  225. move-result v2
  226. if-nez v2, :cond_a
  227. const-string v2, ".."
  228. invoke-virtual {p1, v2}, Ljava/lang/String;->endsWith(Ljava/lang/String;)Z
  229. move-result v3
  230. if-eqz v3, :cond_0
  231. goto/16 :goto_0
  232. :cond_0
  233. if-eqz p2, :cond_a
  234. invoke-virtual {p2}, Ljava/lang/String;->length()I
  235. move-result v3
  236. if-eqz v3, :cond_a
  237. invoke-virtual {p2, v1}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
  238. move-result v3
  239. if-nez v3, :cond_a
  240. invoke-virtual {p2, v2}, Ljava/lang/String;->endsWith(Ljava/lang/String;)Z
  241. move-result v2
  242. if-eqz v2, :cond_1
  243. goto/16 :goto_0
  244. :cond_1
  245. invoke-virtual {p1, v1}, Ljava/lang/String;->endsWith(Ljava/lang/String;)Z
  246. move-result v2
  247. const/16 v3, 0x2e
  248. if-nez v2, :cond_2
  249. new-instance v2, Ljava/lang/StringBuilder;
  250. invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
  251. invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
  252. invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
  253. invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
  254. move-result-object p1
  255. :cond_2
  256. invoke-virtual {p2, v1}, Ljava/lang/String;->endsWith(Ljava/lang/String;)Z
  257. move-result v1
  258. if-nez v1, :cond_3
  259. new-instance v1, Ljava/lang/StringBuilder;
  260. invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
  261. invoke-virtual {v1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
  262. invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
  263. invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
  264. move-result-object p2
  265. :cond_3
  266. sget-object v1, Ljava/util/Locale;->US:Ljava/util/Locale;
  267. invoke-virtual {p2, v1}, Ljava/lang/String;->toLowerCase(Ljava/util/Locale;)Ljava/lang/String;
  268. move-result-object p2
  269. const-string v1, "*"
  270. invoke-virtual {p2, v1}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
  271. move-result v1
  272. if-nez v1, :cond_4
  273. invoke-virtual {p1, p2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
  274. move-result p1
  275. return p1
  276. :cond_4
  277. const-string v1, "*."
  278. invoke-virtual {p2, v1}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
  279. move-result v2
  280. if-eqz v2, :cond_a
  281. const/16 v2, 0x2a
  282. const/4 v4, 0x1
  283. invoke-virtual {p2, v2, v4}, Ljava/lang/String;->indexOf(II)I
  284. move-result v2
  285. const/4 v5, -0x1
  286. if-eq v2, v5, :cond_5
  287. goto :goto_0
  288. :cond_5
  289. invoke-virtual {p1}, Ljava/lang/String;->length()I
  290. move-result v2
  291. invoke-virtual {p2}, Ljava/lang/String;->length()I
  292. move-result v6
  293. if-ge v2, v6, :cond_6
  294. return v0
  295. :cond_6
  296. invoke-virtual {v1, p2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
  297. move-result v1
  298. if-eqz v1, :cond_7
  299. return v0
  300. :cond_7
  301. invoke-virtual {p2, v4}, Ljava/lang/String;->substring(I)Ljava/lang/String;
  302. move-result-object p2
  303. invoke-virtual {p1, p2}, Ljava/lang/String;->endsWith(Ljava/lang/String;)Z
  304. move-result v1
  305. if-nez v1, :cond_8
  306. return v0
  307. :cond_8
  308. invoke-virtual {p1}, Ljava/lang/String;->length()I
  309. move-result v1
  310. invoke-virtual {p2}, Ljava/lang/String;->length()I
  311. move-result p2
  312. sub-int/2addr v1, p2
  313. if-lez v1, :cond_9
  314. sub-int/2addr v1, v4
  315. invoke-virtual {p1, v3, v1}, Ljava/lang/String;->lastIndexOf(II)I
  316. move-result p1
  317. if-eq p1, v5, :cond_9
  318. return v0
  319. :cond_9
  320. return v4
  321. :cond_a
  322. :goto_0
  323. return v0
  324. .end method