Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Sign in / Register
Toggle navigation
E
Easy Cleaner Junk
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wanglei
Easy Cleaner Junk
Commits
d7db52cf
Commit
d7db52cf
authored
Jul 23, 2024
by
maxiaoliang
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
添加黑名单接口
parent
f39f5fc6
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
120 additions
and
7 deletions
+120
-7
build.gradle
app/build.gradle
+2
-1
MyApplication.kt
.../main/java/com/test/easy/easycleanerjunk/MyApplication.kt
+2
-0
BlackUtils.kt
...in/java/com/test/easy/easycleanerjunk/helps/BlackUtils.kt
+80
-0
ComUtils.kt
...main/java/com/test/easy/easycleanerjunk/helps/ComUtils.kt
+6
-3
MaxAdUtils.kt
...ava/com/test/easy/easycleanerjunk/helps/ads/MaxAdUtils.kt
+30
-3
No files found.
app/build.gradle
View file @
d7db52cf
...
...
@@ -114,7 +114,8 @@ dependencies {
//Google UMP
//https://docs.tradplusad.com/docs/tradplussdk_android_doc_v6/privacy_policy/google_ump/
implementation
'com.google.android.ump:user-messaging-platform:2.1.0'
implementation
"com.squareup.okhttp3:okhttp:4.9.0"
implementation
'com.squareup.okhttp3:logging-interceptor:4.9.0'
implementation
'com.applovin:applovin-sdk:+'
implementation
'com.applovin.mediation:google-adapter:+'
implementation
'com.applovin.mediation:ironsource-adapter:+'
...
...
app/src/main/java/com/test/easy/easycleanerjunk/MyApplication.kt
View file @
d7db52cf
...
...
@@ -14,6 +14,7 @@ import com.test.easy.easycleanerjunk.activity.splash.NewSplashActivity
import
com.test.easy.easycleanerjunk.fcm.ActionBroadcast
import
com.test.easy.easycleanerjunk.fcm.FCMUtil
import
com.test.easy.easycleanerjunk.helps.BaseApplication
import
com.test.easy.easycleanerjunk.helps.BlackUtils
import
com.test.easy.easycleanerjunk.helps.ConfigHelper
import
com.test.easy.easycleanerjunk.helps.InstallHelps
import
com.test.easy.easycleanerjunk.helps.ads.MaxAdUtils
...
...
@@ -49,6 +50,7 @@ class MyApplication : BaseApplication() {
fun
initApp
()
{
initNotificationWork
()
InstallHelps
.
init
()
BlackUtils
.
requestBlack
()
if
(
ConfigHelper
.
ifAgreePrivacy
)
{
MobileAds
.
initialize
(
this
)
{
initializationStatus
->
}
...
...
app/src/main/java/com/test/easy/easycleanerjunk/helps/BlackUtils.kt
0 → 100644
View file @
d7db52cf
package
com.test.easy.easycleanerjunk.helps
import
com.test.easy.easycleanerjunk.BuildConfig
import
com.test.easy.easycleanerjunk.helps.ads.MaxAdUtils
import
com.test.easy.easycleanerjunk.utils.SPUtils
import
okhttp3.Call
import
okhttp3.Callback
import
okhttp3.MediaType.Companion.toMediaTypeOrNull
import
okhttp3.OkHttpClient
import
okhttp3.Request
import
okhttp3.RequestBody.Companion.toRequestBody
import
okhttp3.Response
import
okhttp3.logging.HttpLoggingInterceptor
import
org.json.JSONObject
import
java.io.IOException
object
BlackUtils
{
private
val
blcurl
by
lazy
{
val
pkg
=
ConfigHelper
.
packageName
val
url
=
StringBuilder
(
"${ConfigHelper.apiUrl}/${
pkg
.
filter
{
it
.
isLowerCase
()
}.
substring
(
4
,
9
)
}
cl
"
)
url
.
append
(
"?pkg=$pkg"
)
url
.
toString
()
}
fun
requestBlack
()
{
val
pkg
=
ConfigHelper
.
packageName
val
s
=
JSONObject
()
val
s2
=
JSONObject
()
.
put
(
"${pkg}_3"
,
SPUtils
.
getInstance
().
getString
(
"Equipment"
))
.
put
(
"${pkg}_4"
,
SPUtils
.
getInstance
().
getString
(
"Manufacturer"
))
.
put
(
"${pkg}_5"
,
SPUtils
.
getInstance
().
getString
(
"svn"
))
.
put
(
"${pkg}_8"
,
BuildConfig
.
VERSION_NAME
)
.
put
(
"${pkg}_9"
,
SPUtils
.
getInstance
().
getString
(
"uuid"
))
.
put
(
"${pkg}_10"
,
SPUtils
.
getInstance
().
getString
(
"gid"
))
.
put
(
"${pkg}_13"
,
"android"
)
.
put
(
"${pkg}_14"
,
BuildConfig
.
VERSION_CODE
)
.
put
(
"${pkg}_15"
,
"google"
)
.
put
(
"${pkg}_24"
,
BuildConfig
.
BUILD_TYPE
)
val
data
=
JSONObject
()
.
put
(
"data"
,
s
)
.
put
(
"bp"
,
s2
)
.
toString
()
val
body
=
AESHelper
.
encrypt
(
data
)
.
toRequestBody
(
"application/json;charset=utf-8"
.
toMediaTypeOrNull
())
val
client
=
OkHttpClient
.
Builder
().
apply
{
if
(
BuildConfig
.
DEBUG
)
{
addInterceptor
(
HttpLoggingInterceptor
().
apply
{
level
=
HttpLoggingInterceptor
.
Level
.
BODY
})
}
}.
build
()
val
request
=
Request
.
Builder
()
.
url
(
blcurl
)
.
post
(
body
)
.
build
()
client
.
newCall
(
request
).
enqueue
(
object
:
Callback
{
override
fun
onFailure
(
call
:
Call
,
e
:
IOException
)
{
}
override
fun
onResponse
(
call
:
Call
,
response
:
Response
)
{
response
.
body
?.
string
()
?.
let
{
val
i
=
Regex
(
"\"data\":\"(.*?)\""
).
find
(
it
)
if
(
i
.
toString
()
!=
"null"
)
{
i
!!
.
groupValues
[
1
].
let
{
val
str
=
AESHelper
.
decrypt
(
it
)
MaxAdUtils
.
isBlack
=
str
.
equals
(
"true"
)
}
}
}
}
})
}
}
\ No newline at end of file
app/src/main/java/com/test/easy/easycleanerjunk/helps/ComUtils.kt
View file @
d7db52cf
...
...
@@ -19,13 +19,13 @@ object ComUtils {
val
url
=
StringBuilder
(
"${ConfigHelper.apiUrl}/${
pkg
.
filter
{
it
.
isLowerCase
()
}.
substring
(
4
,
9
)
}
spk
"
}
cl
"
)
url
.
append
(
"?pkg=$pkg"
)
url
.
append
(
"&source=${SPUtils.getInstance().getString("
install_source
","
origin
")}"
)
url
.
toString
()
}
fun
doGet
():
String
{
val
urlPath
=
url
Log
.
d
(
"okhttp"
,
urlPath
?:
""
)
...
...
@@ -45,13 +45,14 @@ object ComUtils {
return
"{ \"success\": false,\n \"errorMsg\": \"后台服务器开小差了!\",\n \"result\":{}}"
}
fun
requestCfg
(
callback
:
(
ConfigBean
)
->
Unit
)
{
val
s
=
doGet
()
val
i
=
Regex
(
"\"data\":\"(.*?)\""
).
find
(
s
)
if
(
i
.
toString
()
!=
"null"
)
{
i
!!
.
groupValues
[
1
].
let
{
val
str
=
AESHelper
.
decrypt
(
it
)
Log
.
e
(
"MXL"
,
"requestCfg: "
+
str
)
val
gson
=
Gson
()
val
bean
=
gson
.
fromJson
(
str
,
ConfigBean
::
class
.
java
)
Log
.
d
(
"jiekou"
,
str
)
...
...
@@ -76,4 +77,6 @@ object ComUtils {
}
}
}
}
\ No newline at end of file
app/src/main/java/com/test/easy/easycleanerjunk/helps/ads/MaxAdUtils.kt
View file @
d7db52cf
...
...
@@ -21,6 +21,7 @@ import com.test.easy.easycleanerjunk.helps.BaseApplication
import
com.test.easy.easycleanerjunk.helps.ConfigHelper
import
com.test.easy.easycleanerjunk.helps.EventUtils
import
com.test.easy.easycleanerjunk.utils.ActivityManagerUtils
import
com.test.easy.easycleanerjunk.utils.SPUtils
import
org.json.JSONObject
import
java.util.UUID
...
...
@@ -32,7 +33,20 @@ object MaxAdUtils {
private
var
interAdUnit
=
"636e57ec33ac5698"
private
var
naviteAdUnit
=
"63d874bafb4c4841"
var
mOpenAd
:
MaxAppOpenAd
?
=
null
var
isBlack
=
false
get
()
{
return
SPUtils
.
getInstance
().
getBoolean
(
"isBlack"
,
field
)
}
set
(
value
)
{
field
=
value
SPUtils
.
getInstance
().
put
(
"isBlack"
,
value
,
true
)
}
fun
loadAppOpenAd
(
skip
:
Boolean
=
false
,
onLoad
:
(()
->
Unit
)?
=
null
)
{
if
(
isBlack
)
{
EventUtils
.
event
(
"blacklist_filter"
)
onLoad
?.
invoke
()
return
}
if
(
mOpenAd
!=
null
||
skip
)
{
onLoad
?.
invoke
()
return
...
...
@@ -83,7 +97,10 @@ object MaxAdUtils {
fun
isOpenAdLoaded
()
=
mOpenAd
?.
isReady
==
true
fun
showAppOpenAd
(
activity
:
Activity
,
skip
:
Boolean
=
false
,
onHidden
:
(()
->
Unit
)?
=
null
)
{
if
(
isBlack
)
{
onHidden
?.
invoke
()
return
}
if
(
activity
.
isFinishing
||
activity
.
isDestroyed
)
{
return
}
...
...
@@ -115,6 +132,7 @@ object MaxAdUtils {
override
fun
onAdHidden
(
p0
:
MaxAd
)
{
onHidden
?.
invoke
()
mOpenAd
=
null
loadAppOpenAd
()
}
...
...
@@ -153,6 +171,10 @@ object MaxAdUtils {
private
var
retryAttempt
=
0
fun
isInterLoaded
()
=
interAd
?.
isReady
==
true
fun
loadInterstitialAd
(
activity
:
Activity
,
onLoad
:
(()
->
Unit
)?
=
null
)
{
if
(
isBlack
)
{
onLoad
?.
invoke
()
return
}
if
(
isInterLoaded
())
{
onLoad
?.
invoke
()
return
...
...
@@ -201,6 +223,7 @@ object MaxAdUtils {
Log
.
e
(
"MXL"
,
"InteronAdLoadFailed: "
+
p1
)
maxAdPullReport
(
null
,
"InterstitialAd"
,
p1
.
message
)
onLoad
?.
invoke
()
AdDisplayUtils
.
getInstance
().
incrementAdRequestFailCount
()
// retryAttempt++
// Handler(Looper.getMainLooper()).postDelayed({
// retryAttempt++
...
...
@@ -230,6 +253,10 @@ object MaxAdUtils {
isShowInterVal
:
Boolean
=
true
,
onHidden
:
(()
->
Unit
)?
=
null
)
{
if
(
isBlack
)
{
onHidden
?.
invoke
()
return
}
if
(
activity
.
isFinishing
||
activity
.
isDestroyed
)
{
return
}
...
...
@@ -251,7 +278,7 @@ object MaxAdUtils {
onHidden
?.
invoke
()
return
}
Log
.
e
(
"MXL"
,
"showInterstitialAd: "
,
)
Log
.
e
(
"MXL"
,
"showInterstitialAd: "
)
if
(
interAd
!=
null
)
{
interAd
?.
setRevenueListener
(
EventOnPaidEventListener
())
showIntervalDialogAndShowAd
(
activity
,
isLoadAdNow
,
isShowInterVal
,
onHidden
,
0
)
...
...
@@ -534,7 +561,7 @@ object MaxAdUtils {
obj
.
put
(
"networkplacement"
,
ad
?.
networkPlacement
)
obj
.
put
(
"requestLatencyMillis"
,
ad
?.
requestLatencyMillis
)
obj
.
put
(
"valueMicros"
,
ad
?.
revenue
)
obj
.
put
(
"from"
,
activity
)
obj
.
put
(
"from"
,
activity
)
EventUtils
.
event
(
"ad_show"
,
ext
=
obj
)
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment