Files
rr3-apk/smali_classes2/com/firemonkeys/cloudcellapi/CloudcellTrustManager.smali
Daniel Elliott f3960ee359 Add Discord APKTool decompilation (Smali source for modding)
- Imported from https://github.com/supermegamestre/Project-Real-Resurrection-3
- APKTool decompilation (Smali bytecode) for modding and rebuilding APK
- Supports both 32-bit (armeabi-v7a) and 64-bit (arm64-v8a) architectures
- Includes full Smali source, resources, and native libraries
- Ready to rebuild APK after modifications with apktool b command
- Added comprehensive README-apktool.md with modding guide

This branch complements the JADX branches:
- Use JADX (main/discord-community) to UNDERSTAND code (readable Java)
- Use APKTool (this branch) to MODIFY and REBUILD APK (editable Smali)

Total: 44,417 files, 538.51 MB Smali source code
2026-02-18 16:13:44 -08:00

259 lines
6.0 KiB
Smali

.class Lcom/firemonkeys/cloudcellapi/CloudcellTrustManager;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Ljavax/net/ssl/X509TrustManager;
# static fields
.field private static final CLASSNAME:Ljava/lang/String; = "CloudcellTrustManager"
# instance fields
.field private m_httpRequest:Lcom/firemonkeys/cloudcellapi/HttpRequest;
# direct methods
.method public constructor <init>(Lcom/firemonkeys/cloudcellapi/HttpRequest;)V
.locals 0
.line 184
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
iput-object p1, p0, Lcom/firemonkeys/cloudcellapi/CloudcellTrustManager;->m_httpRequest:Lcom/firemonkeys/cloudcellapi/HttpRequest;
return-void
.end method
# virtual methods
.method public checkClientTrusted([Ljava/security/cert/X509Certificate;Ljava/lang/String;)V
.locals 0
return-void
.end method
.method public checkServerTrusted([Ljava/security/cert/X509Certificate;Ljava/lang/String;)V
.locals 5
const-string p2, "CloudcellTrustManager"
.line 229
invoke-virtual {p0}, Lcom/firemonkeys/cloudcellapi/CloudcellTrustManager;->getSSLCheck()Z
move-result v0
if-eqz v0, :cond_2
.line 233
:try_start_0
invoke-virtual {p0}, Lcom/firemonkeys/cloudcellapi/CloudcellTrustManager;->getServerTime()D
move-result-wide v0
invoke-static {v0, v1}, Ljava/lang/Double;->valueOf(D)Ljava/lang/Double;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/Double;->longValue()J
move-result-wide v0
.line 234
new-instance v2, Ljava/util/Date;
const-wide/16 v3, 0x0
cmp-long v3, v0, v3
if-lez v3, :cond_0
const-wide/16 v3, 0x3e8
mul-long/2addr v0, v3
goto :goto_0
:cond_0
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v0
:goto_0
invoke-direct {v2, v0, v1}, Ljava/util/Date;-><init>(J)V
if-eqz p1, :cond_2
const/4 v0, 0x0
.line 238
:goto_1
array-length v1, p1
if-ge v0, v1, :cond_2
.line 240
aget-object v1, p1, v0
invoke-virtual {v1}, Ljava/security/cert/X509Certificate;->getNotAfter()Ljava/util/Date;
move-result-object v1
.line 241
invoke-virtual {v1, v2}, Ljava/util/Date;->before(Ljava/util/Date;)Z
move-result v3
if-eqz v3, :cond_1
const/4 v3, 0x1
.line 243
invoke-virtual {p0, v3}, Lcom/firemonkeys/cloudcellapi/CloudcellTrustManager;->setClosedBySSLCheck(Z)V
.line 244
invoke-virtual {p0}, Lcom/firemonkeys/cloudcellapi/CloudcellTrustManager;->closeThread()V
.line 245
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "SSL Certificate expired! notAfter = "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/util/Date;->toString()Ljava/lang/String;
move-result-object v1
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {p2, v1}, Lcom/firemonkeys/cloudcellapi/Logging;->CC_ERROR(Ljava/lang/Object;Ljava/lang/String;)V
:try_end_0
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0
goto :goto_2
:catch_0
move-exception p1
goto :goto_3
:cond_1
:goto_2
add-int/lit8 v0, v0, 0x1
goto :goto_1
.line 252
:goto_3
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "The certificate chain can\'t be validated, message:"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object p1
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-static {p2, p1}, Lcom/firemonkeys/cloudcellapi/Logging;->CC_WARNING(Ljava/lang/Object;Ljava/lang/String;)V
:cond_2
const/4 p1, 0x0
iput-object p1, p0, Lcom/firemonkeys/cloudcellapi/CloudcellTrustManager;->m_httpRequest:Lcom/firemonkeys/cloudcellapi/HttpRequest;
return-void
.end method
.method public closeThread()V
.locals 1
iget-object v0, p0, Lcom/firemonkeys/cloudcellapi/CloudcellTrustManager;->m_httpRequest:Lcom/firemonkeys/cloudcellapi/HttpRequest;
if-eqz v0, :cond_0
.line 202
invoke-virtual {v0}, Lcom/firemonkeys/cloudcellapi/HttpRequest;->shutdown()V
:cond_0
return-void
.end method
.method public getAcceptedIssuers()[Ljava/security/cert/X509Certificate;
.locals 1
const/4 v0, 0x0
return-object v0
.end method
.method public getSSLCheck()Z
.locals 1
iget-object v0, p0, Lcom/firemonkeys/cloudcellapi/CloudcellTrustManager;->m_httpRequest:Lcom/firemonkeys/cloudcellapi/HttpRequest;
if-eqz v0, :cond_0
.line 210
invoke-virtual {v0}, Lcom/firemonkeys/cloudcellapi/HttpRequest;->getSSLCheck()Z
move-result v0
return v0
:cond_0
const/4 v0, 0x0
return v0
.end method
.method public getServerTime()D
.locals 2
iget-object v0, p0, Lcom/firemonkeys/cloudcellapi/CloudcellTrustManager;->m_httpRequest:Lcom/firemonkeys/cloudcellapi/HttpRequest;
if-eqz v0, :cond_0
.line 192
invoke-virtual {v0}, Lcom/firemonkeys/cloudcellapi/HttpRequest;->getServerTime()D
move-result-wide v0
return-wide v0
:cond_0
const-wide/16 v0, 0x0
return-wide v0
.end method
.method public setClosedBySSLCheck(Z)V
.locals 1
iget-object v0, p0, Lcom/firemonkeys/cloudcellapi/CloudcellTrustManager;->m_httpRequest:Lcom/firemonkeys/cloudcellapi/HttpRequest;
if-eqz v0, :cond_0
.line 219
invoke-virtual {v0, p1}, Lcom/firemonkeys/cloudcellapi/HttpRequest;->setClosedBySSLCheck(Z)V
:cond_0
return-void
.end method