SafeObjectInputStream.smali
.class Lcom/vungle/warren/utility/SafeObjectInputStream;
.super Ljava/io/ObjectInputStream;
.source "SafeObjectInputStream.java"
# instance fields
.field private final allowed:Ljava/util/List;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/List<",
"Ljava/lang/Class<",
"*>;>;"
}
.end annotation
.end field
# direct methods
.method constructor <init>(Ljava/io/InputStream;Ljava/util/List;)V
.registers 3
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/io/InputStream;",
"Ljava/util/List<",
"Ljava/lang/Class<",
"*>;>;)V"
}
.end annotation
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 1
invoke-direct {p0, p1}, Ljava/io/ObjectInputStream;-><init>(Ljava/io/InputStream;)V
.line 2
iput-object p2, p0, Lcom/vungle/warren/utility/SafeObjectInputStream;->allowed:Ljava/util/List;
return-void
.end method
# virtual methods
.method protected resolveClass(Ljava/io/ObjectStreamClass;)Ljava/lang/Class;
.registers 5
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/io/ObjectStreamClass;",
")",
"Ljava/lang/Class<",
"*>;"
}
.end annotation
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/lang/ClassNotFoundException;,
Ljava/io/IOException;
}
.end annotation
.line 1
invoke-super {p0, p1}, Ljava/io/ObjectInputStream;->resolveClass(Ljava/io/ObjectStreamClass;)Ljava/lang/Class;
move-result-object v0
.line 2
iget-object v1, p0, Lcom/vungle/warren/utility/SafeObjectInputStream;->allowed:Ljava/util/List;
if-eqz v1, :cond_42
const-class v1, Ljava/lang/Number;
invoke-virtual {v1, v0}, Ljava/lang/Class;->isAssignableFrom(Ljava/lang/Class;)Z
move-result v1
if-nez v1, :cond_42
const-class v1, Ljava/lang/String;
invoke-virtual {v1, v0}, Ljava/lang/Object;->equals(Ljava/lang/Object;)Z
move-result v1
if-nez v1, :cond_42
invoke-virtual {v0}, Ljava/lang/Class;->isArray()Z
move-result v1
if-nez v1, :cond_42
iget-object v1, p0, Lcom/vungle/warren/utility/SafeObjectInputStream;->allowed:Ljava/util/List;
.line 3
invoke-interface {v1, v0}, Ljava/util/List;->contains(Ljava/lang/Object;)Z
move-result v1
if-eqz v1, :cond_27
goto :goto_42
.line 4
:cond_27
new-instance v0, Ljava/io/IOException;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Deserialization is not allowed for "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/io/ObjectStreamClass;->getName()Ljava/lang/String;
move-result-object p1
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-direct {v0, p1}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
throw v0
:cond_42
:goto_42
return-object v0
.end method