diff --git a/uni_modules/uni-push/changelog.md b/uni_modules/uni-push/changelog.md
deleted file mode 100644
index e69de29bb2d1d6434b8b29ae775ad8c2e48c5391..0000000000000000000000000000000000000000
diff --git a/uni_modules/uni-push/package.json b/uni_modules/uni-push/package.json
deleted file mode 100644
index 7674d4c16b2f4a8e848dafab5f70dddf0f1e2cf3..0000000000000000000000000000000000000000
--- a/uni_modules/uni-push/package.json
+++ /dev/null
@@ -1,125 +0,0 @@
-{
- "id": "uni-push",
- "displayName": "uni-push",
- "version": "1.0.0",
- "description": "uni-push",
- "keywords": [
- "uni-push"
- ],
- "repository": "",
- "engines": {
- "HBuilderX": "^3.6.8"
- },
- "dcloudext": {
- "type": "uts",
- "sale": {
- "regular": {
- "price": "0.00"
- },
- "sourcecode": {
- "price": "0.00"
- }
- },
- "contact": {
- "qq": ""
- },
- "declaration": {
- "ads": "",
- "data": "",
- "permissions": ""
- },
- "npmurl": ""
- },
- "uni_modules": {
- "dependencies": [],
- "uni-ext-api": {
- "uni": {
- "getPushClientId": {
- "name": "getPushClientId",
- "app": {
- "js": false,
- "kotlin": true,
- "swift": false
- }
- },
- "onPushMessage": {
- "name": "onPushMessage",
- "app": {
- "js": false,
- "kotlin": true,
- "swift": false
- }
- },
- "offPushMessage": {
- "name": "offPushMessage",
- "app": {
- "js": false,
- "kotlin": true,
- "swift": false
- }
- },
- "getChannelManager": {
- "name": "getChannelManager",
- "app": {
- "js": false,
- "kotlin": true,
- "swift": false
- }
- },
- "createPushMessage": {
- "name": "createPushMessage",
- "app": {
- "js": false,
- "kotlin": true,
- "swift": false
- }
- }
- }
- },
- "encrypt": [],
- "platforms": {
- "cloud": {
- "tcb": "u",
- "aliyun": "u"
- },
- "client": {
- "Vue": {
- "vue2": "u",
- "vue3": "u"
- },
- "App": {
- "app-android": "u",
- "app-ios": "u"
- },
- "H5-mobile": {
- "Safari": "u",
- "Android Browser": "u",
- "微信浏览器(Android)": "u",
- "QQ浏览器(Android)": "u"
- },
- "H5-pc": {
- "Chrome": "u",
- "IE": "u",
- "Edge": "u",
- "Firefox": "u",
- "Safari": "u"
- },
- "小程序": {
- "微信": "u",
- "阿里": "u",
- "百度": "u",
- "字节跳动": "u",
- "QQ": "u",
- "钉钉": "u",
- "快手": "u",
- "飞书": "u",
- "京东": "u"
- },
- "快应用": {
- "华为": "u",
- "联盟": "u"
- }
- }
- }
- }
-}
\ No newline at end of file
diff --git a/uni_modules/uni-push/readme.md b/uni_modules/uni-push/readme.md
deleted file mode 100644
index c5dde5d47b0ebff0c34cf361d7140765c1893b44..0000000000000000000000000000000000000000
--- a/uni_modules/uni-push/readme.md
+++ /dev/null
@@ -1,142 +0,0 @@
-# uni-push
-
-`uni-push` 工程,是基于 DCloud-UTS 架构之上的封装个推消息推送 `SDK` 的插件工程,使用此模块可轻松实现服务端向客户端推送通知和透传消息的功能。
-
-### 插件使用说明
-
-#### 导入插件
-```uts
-import * as GTPlugin from "../../uni_modules/uni-push"
-```
-
-#### 初始化
-
-```typescript
-//初始化个推推送
-GTPlugin.initPush();
-```
-
-#### 推送消息事件
-
-> 添加透传消息回调,对应的GTPlugin.offPushMessage()可移除对应监听callback(传入null,可移除所有监听callback)
-
-```typescript
-GTPlugin.onPushMessage((res) => {
- console.log("onPushMessage => " + JSON.stringify(res))
-})
-```
-
-| 名称 | 类型 | 描述 |
-| ---- | ------------- | ----------------------------------------------------------- |
-| type | String | 事件类型,"click"-从系统推送服务点击消息启动应用事件;"receive"-应用从推送服务器接收到推送消息事件。 |
-| data | String、Object | 消息内容 |
-
-
-
-#### 日志
-
-开发阶段,需要使用到日志辅助。
-
-```typescript
-//设置日志回调,可以在控制台看到[GT-PUSH]的日志
-GTPlugin.setDebugLogger(function(res) {
- console.log(res)
-});
-```
-
-当插件正常初始化会出现以下日志:
-
-```uts
-16:47:53.254 [GT-PUSH] [LogController] Sdk version = 3.3.0.0 at pages/index/index.vue:25
-16:47:54.052 [GT-PUSH] [ServiceManager] ServiceManager start from initialize... at pages/index/index.vue:25
-16:47:54.073 [GT-PUSH] PushCore started at pages/index/index.vue:25
-16:47:54.274 [GT-PUSH] onHandleIntent() = get sdk service pid at pages/index/index.vue:25
-16:47:54.292 [GT-PUSH] onHandleIntent() areNotificationsEnabled at pages/index/index.vue:25
-16:47:54.353 [GT-PUSH] [LoginInteractor] Start login appid = nU*******wzf at pages/index/index.vue:25
-16:47:54.571 收到 cid onReceiveClientId : 3061f********ce7578eb24 at pages/index/index.vue:29
-16:47:54.592 [GT-PUSH] onHandleIntent() = received client id at pages/index/index.vue:25
-16:47:54.593 [GT-PUSH] [LoginResult] Login successed with cid = 3061f********ce7578eb24 at pages/index/index.vue:25
-```
-
-#### 推送相关动作
-
-> 设置推送相关动作回调,更多可查看`app-android/index.uts`下面的 `UserPushAction`类
-
-```typescript
-GTPlugin.setPushAction({
- onReceiveClientId: function(cid) {
- console.log("收到 cid onReceiveClientId : " + cid)
- }
-});
-```
-
-
-
-#### 唯一的推送标识
-
-获取客户端唯一的推送标识
-
-```typescript
-GTPlugin.getPushClientId({
- success: (res) => {
- console.log("getPushClientId success => " + JSON.stringify(res));
- },
- fail: (res) => {
- console.log("getPushClientId fail => " + JSON.stringify(res));
- },
- complete: (res) => {
- console.log("getPushClientId complete => " + JSON.stringify(res));
- }
-});
-```
-
-**OBJECT 参数说明**
-
-| 参数名 | 类型 | 必填 | 说明 |
-| -------- | -------- | --- | ------------------------ |
-| success | Function | 是 | 接口调用的回调函数,详见返回参数说明 |
-| fail | Function | 否 | 接口调用失败的回调函数 |
-| complete | Function | 否 | 接口调用结束的回调函数(调用成功、失败都会执行) |
-
-**success 返回参数说明**
-
-| 参数 | 类型 | 说明 |
-| ------ | ------ | ---------------------------------------- |
-| cid | String | 个推客户端推送id,对应uni-id-device表的push_clientid |
-| errMsg | String | 错误描述 |
-
-**fail 返回参数说明**
-
-| 参数 | 类型 | 说明 |
-| ------ | ------ | ---- |
-| errMsg | String | 错误描述 |
-
-
-
-### APP_ID申请
-
-可登录[个推官网](https://dev.getui.com/)注册申请应用,获取APP相关信息。
-
-
-
-### 多厂商
-
-多厂商渠道可以参考[[厂商应用开通指南-个推文档中心](https://docs.getui.com/getui/mobile/vendor/vendor_open/) 和 [厂商 SDK 集成指南-个推文档中心](https://docs.getui.com/getui/mobile/vendor/androidstudio/)
-
-> 注意:华为厂商需要把`agconnect-services.json` 放到${工程根目录}/nativeResources/android/ 目录下
-
-### 开发文档
-
-[个推推送SDK](https://docs.getui.com/getui/start/accessGuide/)
-[多厂商接入](https://docs.getui.com/getui/mobile/vendor/vendor_open/)
-
-
-
-### 注意事项
-
-在`AndroidManifest.xml`中,必须声明插件`flag`
-
-```xml
-
-
-```
diff --git a/uni_modules/uni-push/utssdk/app-android/AndroidManifest.xml b/uni_modules/uni-push/utssdk/app-android/AndroidManifest.xml
deleted file mode 100644
index 0272d5637496aceebc0a71a2908eb3d5eb81cfaf..0000000000000000000000000000000000000000
--- a/uni_modules/uni-push/utssdk/app-android/AndroidManifest.xml
+++ /dev/null
@@ -1,34 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/uni_modules/uni-push/utssdk/app-android/config.json b/uni_modules/uni-push/utssdk/app-android/config.json
deleted file mode 100644
index 82b9613f2c85c6060d2af8bb064882b2b5003711..0000000000000000000000000000000000000000
--- a/uni_modules/uni-push/utssdk/app-android/config.json
+++ /dev/null
@@ -1,42 +0,0 @@
-{
- "parameters": {
- "appid": {
- "placeholder": "GETUI_APPID"
- },
- "mipush_appid": {
- "placeholder": "MIPUSH_APPID"
- },
- "mipush_appkey": {
- "placeholder": "MIPUSH_APPKEY"
- },
- "meizupush_appid": {
- "placeholder": "MEIZUPUSH_APPID"
- },
- "meizupush_appkey": {
- "placeholder": "MEIZUPUSH_APPKEY"
- },
- "oppopush_appkey": {
- "placeholder": "OPPOPUSH_APPKEY"
- },
- "oppopush_appsecret": {
- "placeholder": "OPPOPUSH_APPSECRET"
- },
- "huaweipush_appid": {
- "placeholder": "com.huawei.hms.client.appid"
- },
- "vivopush_appid": {
- "placeholder": "com.vivo.push.app_id"
- },
- "vivopush_appkey": {
- "placeholder": "com.vivo.push.api_key"
- },
- "dcloud_unipush_auto_notification": {
- "placeholder": "dcloud_unipush_auto_notification"
- }
- },
- "files": [{
- "source": "push_unipush_huaweipush_agconnect-services.json",
- "target": "agconnect-services.json",
- "des": "HMS配置文件"
- }]
-}
\ No newline at end of file
diff --git a/uni_modules/uni-push/utssdk/app-android/gt-sdk/GTPush.uts b/uni_modules/uni-push/utssdk/app-android/gt-sdk/GTPush.uts
deleted file mode 100644
index 0ebb25a3c9b0bf9ddb234557ce6e4f506ff2db3c..0000000000000000000000000000000000000000
--- a/uni_modules/uni-push/utssdk/app-android/gt-sdk/GTPush.uts
+++ /dev/null
@@ -1,144 +0,0 @@
-import Context from "android.content.Context";
-import GTPlugin from "com.getui.sdk.GTPlugin";
-import IPushAction from "com.getui.sdk.IPushAction";
-import GTCmdMessage from "com.igexin.sdk.message.GTCmdMessage";
-import GTNotificationMessage from "com.igexin.sdk.message.GTNotificationMessage";
-import GTTransmitMessage from "com.igexin.sdk.message.GTTransmitMessage";
-import IUserLoggerInterface from "com.igexin.sdk.IUserLoggerInterface";
-
-export function gtInit(context : Context) : void {
- GTPlugin.initialize(context);
-}
-
-export function getClientId(context : Context) : string {
- return GTPlugin.getClientId(context);
-}
-
-export function setPushAction(action : UserPushAction) : void {
- GTPlugin.setPushAction(action);
-}
-
-
-export type GTPushActionOptions = {
-
- onReceiveServicePid ?: (res : number) => void
-
- /**
- * 接收clientId(cid)
- */
- onReceiveClientId ?: (res : string) => void
-
- /**
- * 此方法用于接收和处理透传消息。透传消息个推只传递数据,不做任何处理,客户端接收到透传消息后需要自己去做后续动作处理,如通知栏展示、弹框等。
- * 如果开发者在客户端将透传消息创建了通知栏展示,建议将展示和点击回执上报给个推。
- */
- onReceiveMessageData ?: (res : string) => void
-
- /**
- * cid 离线上线通知
- */
- onReceiveOnlineState ?: (res : boolean) => void
-
- /**
- * 各种事件处理回执
- */
- onReceiveCommandResult ?: (res : GTCmdMessage) => void
-
- /**
- * 通知点击,只有个推通道下发的通知会回调此方法
- */
- onNotificationMessageClicked ?: (res : string) => void
-
- /**
- * 通知到达,只有个推通道下发的通知会回调此方法
- */
- onNotificationMessageArrived ?: (res : GTNotificationMessage) => void
-}
-
-
-
-export class UserPushAction implements IPushAction {
-
- constructor(
- private options : GTPushActionOptions) {
- }
-
- override onReceiveServicePid(ctx : Context, pid : Int) {
- this.options.onReceiveServicePid?.(pid)
- }
-
- /**
- * 接收clientId(cid)
- */
- override onReceiveClientId(ctx : Context, cid : string) {
- this.options.onReceiveClientId?.(cid)
- }
-
- /**
- * 此方法用于接收和处理透传消息。透传消息个推只传递数据,不做任何处理,客户端接收到透传消息后需要自己去做后续动作处理,如通知栏展示、弹框等。
- * 如果开发者在客户端将透传消息创建了通知栏展示,建议将展示和点击回执上报给个推。
- *
- * class GTTransmitMessage {
- * private String taskId;
- * private String messageId;
- * private String payloadId;
- * private byte[] payload;
- * }
- */
- override onReceiveMessageData(ctx : Context, message : GTTransmitMessage) {
- this.options.onReceiveMessageData?.(new String(message.getPayload()))
- }
-
- /**
- * cid 离线/上线通知
- */
- override onReceiveOnlineState(ctx : Context, state : boolean) {
- this.options.onReceiveOnlineState?.(state)
- }
-
- /**
- * 各种事件处理回执
- */
- override onReceiveCommandResult(ctx : Context, message : GTCmdMessage) {
- this.options.onReceiveCommandResult?.(message)
- }
-
- /**
- * 通知点击,只有个推通道下发的通知会回调此方法
- */
- override onNotificationMessageClicked(ctx : Context, message : GTNotificationMessage) {
- const params = {
- "title": message.getTitle(),
- "content": message.getContent()
- };
- this.options.onNotificationMessageClicked?.(JSON.stringify(params))
- }
-
- /**
- * 通知到达,只有个推通道下发的通知会回调此方法
- */
- override onNotificationMessageArrived(ctx : Context, message : GTNotificationMessage) {
- this.options.onNotificationMessageArrived?.(message)
- }
-}
-
-
-class UserLoggerInterface implements IUserLoggerInterface {
- constructor(private callback : (log : string) => void) {
- }
-
- override log(s : string) {
- this.callback?.(s)
- }
-}
-
-/**
- * 个推推送sdk调试日志信息
- * setDebugLogger 接口仅限调试的时候使用,切勿发布到线上版本,重复调用仅以第一次为准。
- */
-export function setDebugLogger(callback : (log : string) => void) {
- const ctx = UTSAndroid.getAppContext();
- if (ctx != null) {
- GTPlugin.setDebugLogger(ctx, new UserLoggerInterface(callback))
- }
-}
\ No newline at end of file
diff --git a/uni_modules/uni-push/utssdk/app-android/index.uts b/uni_modules/uni-push/utssdk/app-android/index.uts
deleted file mode 100644
index 34379f2b9c0c8aaba15f09e095b767966c947f8c..0000000000000000000000000000000000000000
--- a/uni_modules/uni-push/utssdk/app-android/index.uts
+++ /dev/null
@@ -1,364 +0,0 @@
-
-import { GetPushClientIdOptions, GetPushClientIdSuccess, GetPushClientIdFail, OnPushMessageCallback, OnPushMessageCallbackResult, OnPushMessageType, CreatePushMessageOptions, ChannelManager } from '../interface.uts'
-
-import { gtInit, GTPushActionOptions, UserPushAction, setPushAction } from './gt-sdk/GTPush.uts'
-import Context from 'android.content.Context';
-import { PushMessage } from './push/PushMessage.uts';
-import PackageManager from 'android.content.pm.PackageManager';
-import ApplicationInfo from 'android.content.pm.ApplicationInfo';
-import Activity from 'android.app.Activity';
-import TextUtils from 'android.text.TextUtils';
-import { PushState } from './push/PushState.uts';
-import { PushManager } from './push/PushManager.uts';
-import { StringUtil } from './push/utils/StringUtil.uts';
-import SharedPreferences from 'android.content.SharedPreferences';
-import Handler from 'android.os.Handler';
-import { PushChannelManager } from './push/PushChannelManager.uts';
-import Bundle from 'android.os.Bundle';
-import Intent from 'android.content.Intent';
-import Uri from 'android.net.Uri';
-import { globalPushMessageCallbacks, sendEvent } from './push/PushManager.uts'
-export { PushActionService } from './push/PushActionService.uts';
-
-const SP_NAME = "clientid_unipush";
-const SP_KEY_CLIENT_ID = "clientid";
-
-
-let gtCallBack : UserPushAction | null = null;
-let gtPushInitialize = false
-
-/**
- * 个推推送sdk初始化
- */
-function initPush() {
- const ctx = UTSAndroid.getAppContext();
- if (ctx != null && !gtPushInitialize) {
- gtPushInitialize = true;
- gtInit(ctx);
- setPushAction(getGTCallBack());
- }
-}
-
-/**
- * 获取客户端唯一的推送标识(注意:这是一个异步的方法)
- */
-export function getPushClientId(options : GetPushClientIdOptions) {
- initPush()
- const ctx = UTSAndroid.getAppContext() as Context;
- const sp = ctx.getSharedPreferences(SP_NAME, Context.MODE_PRIVATE) as SharedPreferences;
- const clientId = sp.getString(SP_KEY_CLIENT_ID, "")
- if (TextUtils.isEmpty(clientId)) {
- const handler = new Handler()
- const changeListener = new (class implements SharedPreferences.OnSharedPreferenceChangeListener {
- override onSharedPreferenceChanged(sharedPreferences : SharedPreferences, key : string) : void {
- if (key != SP_KEY_CLIENT_ID) {
- return
- }
- handler.removeCallbacksAndMessages(null)
- sharedPreferences.unregisterOnSharedPreferenceChangeListener(this)
- const cid = sharedPreferences.getString(SP_KEY_CLIENT_ID, "")
- const res : GetPushClientIdSuccess = { errMsg: "success", cid: cid!! }
- options.success?.(res)
- options.complete?.(res)
- }
- })
- sp.registerOnSharedPreferenceChangeListener(changeListener)
-
- const runnable = new (class implements Runnable {
- override run() {
- const clientId = sp.getString(SP_KEY_CLIENT_ID, "")
- if (!TextUtils.isEmpty(clientId)) {
- const res : GetPushClientIdSuccess = { errMsg: "success", cid: clientId!! }
- options.success?.(res)
- options.complete?.(res)
- } else {
- const res : GetPushClientIdFail = {
- errSubject: "uni-push",
- errCode: -1,
- errMsg: "failed,check appkey or appid",
- }
- options.fail?.(res)
- options.complete?.(res)
- }
- }
- })
- handler.postDelayed(runnable, 15000)
- } else {
- const res : GetPushClientIdSuccess = { errMsg: "success", cid: clientId!! }
- options.success?.(res)
- options.complete?.(res)
- }
-}
-
-/**
- * 增加监听推送消息事件(应用在线的时候没有通知栏消息,全部是透传。), 注意: 使用时,开发者需要注册写到第一个activity的周期内 , 即首页.
- */
-export function onPushMessage(callback : OnPushMessageCallback | null) {
- initPush()
- if (callback == null) {
- return;
- }
- if (globalPushMessageCallbacks.indexOf(callback) == -1) {
- globalPushMessageCallbacks.push(callback)
- }
-
- processOfflineMessage()
- // 处理没有注册监听时,已经接到的消息,此时从缓存里取
- PushManager.getInstance().comsumeMessages("click", (msgs : PushMessage[]) => {
- msgs.forEach((msg) => {
- sendEvent("click", msg)
- })
- })
- PushManager.getInstance().comsumeMessages("receive", (msgs : PushMessage[]) => {
- msgs.forEach((msg) => {
- sendEvent("receive", msg)
- })
- })
-}
-
-/**
- * 移除推送消息监听事件(没有传入参数,则移除App级别的所有事件监听器。)
- */
-export function offPushMessage(callback : OnPushMessageCallback | null) {
- if (callback == null) {
- const len = globalPushMessageCallbacks.length;
- globalPushMessageCallbacks.splice(0, len)
- return;
- }
-
- let index = globalPushMessageCallbacks.indexOf(callback)
- if (index == -1) {
- return;
- }
- globalPushMessageCallbacks.splice(index, 1)
-}
-
-export function getChannelManager() : ChannelManager {
- return PushChannelManager.getInstance()
-}
-
-export function createPushMessage(options : CreatePushMessageOptions) : void {
- const context = UTSAndroid.getAppContext() as Context
- const appId = UTSAndroid.getAppId()
- const pushMessage = new PushMessage(JSON.stringify(options), getApplicationName(), false)
-
- const min = 0
- if (pushMessage.mDelay == min.toLong()) {
- PushManager.getInstance().addPushMessage(appId, pushMessage)
- PushManager.getInstance().createNotification(context, pushMessage)
- } else {
- new Handler().postDelayed(new (class implements Runnable {
- override run() {
- PushManager.getInstance().addPushMessage(appId, pushMessage)
- PushManager.getInstance().createNotification(context, pushMessage)
- }
- }), pushMessage.mDelay * 1000)
- }
-}
-
-
-function getGTCallBack() : UserPushAction {
- if (gtCallBack == null) {
- const options = {
- onReceiveClientId(cid : string) {
- const context = UTSAndroid.getAppContext() as Context;
- const sp = context.getSharedPreferences(SP_NAME, Context.MODE_PRIVATE);
- const editor = sp.edit();
- editor.putString(SP_KEY_CLIENT_ID, cid);
- editor.commit();
- },
- onNotificationMessageClicked(res : string) {
- const pushMessage = new PushMessage(res, getApplicationName(), false)
- if (!sendEvent("click", pushMessage)) {
- PushManager.getInstance().addNeedExecClickMessage(pushMessage)
- }
- },
- onReceiveMessageData(res : string) {
- if (!TextUtils.isEmpty(res)) {
- let isUniPush2 = false
- const jsonObject = JSON.parseObject(res)
- const unipushVersionStr = jsonObject?.getString("unipush_version")
- if (!TextUtils.isEmpty(unipushVersionStr)) {
- const unipushVersion = parseFloat(unipushVersionStr!!)
- if (unipushVersion == 2.0) {
- isUniPush2 = true;
- }
- }
- if (isUniPush2) {
- processForUniPush2(res);
- } else {
- processForUniPush(res);
- }
- }
- },
- } as GTPushActionOptions;
- gtCallBack = new UserPushAction(options);
- }
-
- return gtCallBack!!;
-}
-
-/**
- * 处理离线消息
- */
-function processOfflineMessage() {
- const activity = UTSAndroid.getUniActivity() as Activity
- const intent = activity.getIntent()
-
- // const testStr = "intent://io.dcloud.unipush/?#Intent;scheme=unipush;launchFlags=0x4000000;package=uni.UNI8CD4C4C;component=uni.UNI8CD4C4C/io.dcloud.uniapp.UniAppActivity;S.UP-OL-SU=true;S.unipush_version=2.0;S.payload={\"cccccforceNotification\":\"xxx\",\"path\":\"XXX\"};S.title=xxx;S.content=xxx;S.unipush_data={\"forceNotification\":\"xxx\",\"path\":\"XXX\"};end"
- // const intent = Intent.parseUri(testStr , 0)
-
- if (intent.hasExtra("UP-OL-SU")) {
- let isUniPush2 = false;
- const unipushVersionStr = intent.getStringExtra("unipush_version");
- if (!TextUtils.isEmpty(unipushVersionStr)) {
- const unipushVersion = parseFloat(unipushVersionStr!!)
- if (unipushVersion == 2.0) {
- isUniPush2 = true;
- }
- }
-
- const params = {}
-
- if (isUniPush2) {
- try {
- params["title"] = intent.getStringExtra("title")
- params["content"] = intent.getStringExtra("content")
- params["unipush_version"] = intent.getStringExtra("unipush_version")
-
- const channelId = intent.getStringExtra("channelId");
- const category = intent.getStringExtra("category");
- if (!TextUtils.isEmpty(channelId)) {
- params["channelId"] = channelId
- }
- if (!TextUtils.isEmpty(category)) {
- params["category"] = category
- }
-
- let payload = intent.getStringExtra("payload");
- const payloadJsonObject = JSON.parseObject(payload ?? "")
- if (payloadJsonObject == null) {
- if (payload != null) {
- //如果后端传的不是json,而是纯字符串,就需要单独处理,去掉多余的引号,并且枚举一下类型.
- //双引号套双引号,就说明是传的字符串.
- if (payload.startsWith("\"")) {
- payload = StringUtil.trimString(payload, '"');
- params["payload"] = payload
- } else {
- const payloadInt = StringUtil.getInt(payload);
- const payloadDouble = StringUtil.getDouble(payload);
- if (payloadInt != null) {
- params["payload"] = payloadInt
- } else if (payloadDouble != null) {
- params["payload"] = payloadDouble
- } else if (payload == "true" || payload == "false") {
- params["payload"] = payload.toBoolean()
- } else {
- params["payload"] = payload
- }
- }
- }
- } else {
- params["payload"] = payloadJsonObject
- }
-
- const unipush_data = intent.getStringExtra("unipush_data");
- const unipushDataJsonObject = JSON.parseObject(unipush_data ?? "");
- if (unipushDataJsonObject != null) {
- unipushDataJsonObject.toMap().forEach((value, key) => {
- params[key] = value
- })
- }
-
- intent.removeExtra("UP-OL-SU");
- intent.removeExtra("title");
- intent.removeExtra("content");
- intent.removeExtra("payload");
- intent.removeExtra("unipush_version");
- intent.removeExtra("unipush_data");
- intent.removeExtra("channelId");
- intent.removeExtra("category");
-
- const data = JSON.stringify(params)
- const pushMessage = new PushMessage(data, getApplicationName(), true);
- if (!sendEvent("click", pushMessage)) {
- PushManager.getInstance().addNeedExecClickMessage(pushMessage)
- }
- } catch (e : Exception) {
- e.printStackTrace();
- }
- } else {
- try {
- params["title"] = intent.getStringExtra("title")
- params["content"] = intent.getStringExtra("content")
- params["payload"] = intent.getStringExtra("payload")
- const channelId = intent.getStringExtra("channelId");
- const category = intent.getStringExtra("category");
- if (!TextUtils.isEmpty(channelId)) {
- params["channelId"] = channelId
- }
- if (!TextUtils.isEmpty(category)) {
- params["category"] = category
- }
- intent.removeExtra("UP-OL-SU");
- intent.removeExtra("title");
- intent.removeExtra("content");
- intent.removeExtra("payload");
- intent.removeExtra("channelId");
- intent.removeExtra("category");
- const data = JSON.stringify(params)
- const pushMessage = new PushMessage(data, getApplicationName(), true);
- if (!sendEvent("click", pushMessage)) {
- PushManager.getInstance().addNeedExecClickMessage(pushMessage)
- }
- } catch (e : Exception) {
- e.printStackTrace();
- }
- }
- }
-}
-
-
-function processForUniPush(data : string) : void {
- const context = UTSAndroid.getAppContext() as Context
- const pushMessage = new PushMessage(data, getApplicationName(), false)
- const needPush = PushState.getAutoNotification()
- if (needPush && pushMessage.getNeedCreateNotification()) {
- PushManager.getInstance().createNotification(context, pushMessage)
- } else if (!sendEvent("receive", pushMessage)) {
- PushManager.getInstance().addNeedExecReceiveMessage(pushMessage);
-
- }
- PushManager.getInstance().addPushMessage(UTSAndroid.getAppId(), pushMessage);
-}
-
-function processForUniPush2(data : string) : void {
- const context = UTSAndroid.getAppContext() as Context
- const jsonObject = JSON.parseObject(data)
- if (jsonObject != null) {
- const forceNotification = jsonObject.getBoolean("force_notification")
- const pushMessage = new PushMessage(data, getApplicationName(), true)
- if (forceNotification != null && forceNotification) {
- PushManager.getInstance().createNotification(context, pushMessage)
- } else if (!sendEvent("receive", pushMessage)) {
- PushManager.getInstance().addNeedExecReceiveMessage(pushMessage);
- }
- PushManager.getInstance().addPushMessage(UTSAndroid.getAppId(), pushMessage);
- }
-}
-
-function getApplicationName() : string {
- let packageManager : PackageManager | null = null
- let applicationInfo : ApplicationInfo | null = null
- const context = UTSAndroid.getAppContext() as Context;
- try {
- packageManager = context.getApplicationContext().getPackageManager()
- applicationInfo = packageManager.getApplicationInfo(context.getPackageName(), 0)
- } catch (_ : Exception) {
- }
- if (applicationInfo == null) {
- return ""
- }
-
- return packageManager?.getApplicationLabel(applicationInfo).toString() ?? ""
-}
\ No newline at end of file
diff --git a/uni_modules/uni-push/utssdk/app-android/libs/getui-uts-android-release-20230928135005.aar b/uni_modules/uni-push/utssdk/app-android/libs/getui-uts-android-release-20230928135005.aar
deleted file mode 100644
index 93354738c7fef06d3cd9a7d1d48aecd68204616a..0000000000000000000000000000000000000000
Binary files a/uni_modules/uni-push/utssdk/app-android/libs/getui-uts-android-release-20230928135005.aar and /dev/null differ
diff --git a/uni_modules/uni-push/utssdk/app-android/push/PushActionService.uts b/uni_modules/uni-push/utssdk/app-android/push/PushActionService.uts
deleted file mode 100644
index 886709c8f29ca335d70fff3c7ad886df655d2790..0000000000000000000000000000000000000000
--- a/uni_modules/uni-push/utssdk/app-android/push/PushActionService.uts
+++ /dev/null
@@ -1,21 +0,0 @@
-import Service from 'android.app.Service';
-import Intent from 'android.content.Intent';
-import IBinder from 'android.os.IBinder';
-import { PushManager } from './PushManager.uts';
-export class PushActionService extends Service {
-
- constructor(){
- super();
- }
-
- override onBind(intent : Intent) : IBinder | null {
- return null
- }
-
- override onStartCommand(intent : Intent | null, flag : Int, startId : Int) : Int {
- if (intent != null) {
- PushManager.getInstance().processAction(this.getBaseContext(), intent)
- }
- return super.onStartCommand(intent, flag, startId)
- }
-}
\ No newline at end of file
diff --git a/uni_modules/uni-push/utssdk/app-android/push/PushChannelManager.uts b/uni_modules/uni-push/utssdk/app-android/push/PushChannelManager.uts
deleted file mode 100644
index 07f55431709507f1a2b50c6d6ffe946b8266bf3c..0000000000000000000000000000000000000000
--- a/uni_modules/uni-push/utssdk/app-android/push/PushChannelManager.uts
+++ /dev/null
@@ -1,98 +0,0 @@
-import { ChannelManager, SetPushChannelOptions } from "../../interface.uts";
-import Context from 'android.content.Context';
-import Build from 'android.os.Build';
-import NotificationManager from 'android.app.NotificationManager';
-import NotificationChannelGroup from 'android.app.NotificationChannelGroup';
-import NotificationChannel from 'android.app.NotificationChannel';
-import TextUtils from 'android.text.TextUtils';
-import ContentResolver from 'android.content.ContentResolver';
-import Uri from 'android.net.Uri';
-import RingtoneManager from 'android.media.RingtoneManager';
-
-export class PushChannelManager implements ChannelManager {
-
- static LOCAL_PUSH_CHANNEL_ID = "DcloudChannelID";
- static LOCAL_PUSH_GROUP_ID = "DcloudGroupID";
-
- private static INSTANCE : PushChannelManager | null = null
-
- static getInstance() : PushChannelManager {
- if (this.INSTANCE == null) {
- this.INSTANCE = new PushChannelManager()
- }
- return this.INSTANCE!!
- }
-
- createDefaultChannel(context : Context) {
- if (Build.VERSION.SDK_INT >= 26) {
- const notificationManager = context.getSystemService(Context.NOTIFICATION_SERVICE) as NotificationManager
- const pChannelId = PushChannelManager.LOCAL_PUSH_CHANNEL_ID
- const pChannelName = context.getResources().getString(R.string.dcloud_feature_aps_notification_channel)
- if (notificationManager.getNotificationChannel(pChannelId) == null) {
- notificationManager.createNotificationChannelGroup(new NotificationChannelGroup(PushChannelManager.LOCAL_PUSH_GROUP_ID, context.getResources().getString(R.string.dcloud_feature_aps_notification_group)))
- const channel = new NotificationChannel(pChannelId, pChannelName, NotificationManager.IMPORTANCE_DEFAULT)
- channel.enableLights(true)
- channel.setShowBadge(true)
- notificationManager.createNotificationChannel(channel)
- }
- }
- }
-
- /**
- * 设置推送渠道
- */
- setPushChannel(options : SetPushChannelOptions) : void {
- if (Build.VERSION.SDK_INT >= 26) {
- const context = UTSAndroid.getAppContext() as Context
- const notificationManager = context.getSystemService(Context.NOTIFICATION_SERVICE) as NotificationManager;
- if (notificationManager.getNotificationChannel(options.channelId) == null) {
- const notificationChannel = new NotificationChannel(options.channelId, options.channelDesc, NotificationManager.IMPORTANCE_DEFAULT);
- notificationChannel.setShowBadge(true);
- let sound = 0;
- if (!TextUtils.isEmpty(options.soundName)) {
- const packName = context.getApplicationInfo().packageName
- sound = context.getResources().getIdentifier(options.soundName!!, "raw", packName)
- }
- let uriStr = "";
- if (sound != 0) {
- uriStr = ContentResolver.SCHEME_ANDROID_RESOURCE + "://" + context.getPackageName() + "/raw/" + sound;
- }
-
- if (!TextUtils.isEmpty(uriStr)) {
- notificationChannel.setSound(Uri.parse(uriStr), null);
- } else {
- const uri = RingtoneManager.getDefaultUri(RingtoneManager.TYPE_NOTIFICATION);//默认铃音
- notificationChannel.setSound(uri, null);
- }
-
- if (options.importance != null) {
- notificationChannel.setImportance(options.importance!!.toInt());
- }
- if (options.lockscreenVisibility != null) {
- notificationChannel.setLockscreenVisibility(options.lockscreenVisibility!!.toInt());
- }
- notificationChannel.enableLights(options.enableLights ?? false);
- notificationChannel.enableVibration(options.enableVibration ?? false);
- notificationManager.createNotificationChannel(notificationChannel);
- }
- }
- }
- /**
- * 获取当前应用注册的所有的通知渠道。
- */
- getAllChannels() : string[] {
- if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
- const context = UTSAndroid.getAppContext() as Context
- const nm = context.getSystemService(Context.NOTIFICATION_SERVICE) as NotificationManager
- const channels : string[] = []
- const list = nm.getNotificationChannels()
- for (let i:Int = 0; i < list.size; i++) {
- channels.push(list.get(i).toString())
- }
- return channels
- }else{
- return [] as string[]
- }
- }
-
-}
\ No newline at end of file
diff --git a/uni_modules/uni-push/utssdk/app-android/push/PushManager.uts b/uni_modules/uni-push/utssdk/app-android/push/PushManager.uts
deleted file mode 100644
index bbc8b88effc02986f81d65de0df74742033baff3..0000000000000000000000000000000000000000
--- a/uni_modules/uni-push/utssdk/app-android/push/PushManager.uts
+++ /dev/null
@@ -1,320 +0,0 @@
-import Context from 'android.content.Context';
-import Intent from 'android.content.Intent';
-import { PushChannelManager } from './PushChannelManager.uts';
-import { PushMessage } from './PushMessage.uts';
-import NotificationManager from 'android.app.NotificationManager';
-import ComponentName from 'android.content.ComponentName';
-import PendingIntent from 'android.app.PendingIntent';
-import Build from 'android.os.Build';
-import TextUtils from 'android.text.TextUtils';
-import Notification from 'android.app.Notification';
-import Bitmap from 'android.graphics.Bitmap';
-import BitmapFactory from 'android.graphics.BitmapFactory';
-import File from 'java.io.File';
-import { OnPushMessageCallback, OnPushMessageType, OnPushMessageCallbackResult } from '../../interface.uts'
-
-export const globalPushMessageCallbacks : OnPushMessageCallback[] = []
-
-export function sendEvent(type : OnPushMessageType, pushMessage : PushMessage) : boolean {
- const data = pushMessage.getJsonObject()
- const result : OnPushMessageCallbackResult = {
- type: type,
- data: data
- }
- if (globalPushMessageCallbacks.length == 0) {
- return false
- } else {
- globalPushMessageCallbacks.forEach((cb : OnPushMessageCallback) => {
- cb(result)
- })
- return true
- }
-}
-
-export class PushManager {
- private static INSTANCE : PushManager | null = null
-
- private ACTION_TYPE_CREATE = "ACTION_TYPE_CREATE"
- private ACTION_TYPE_REMOVE = "ACTION_TYPE_REMOVE"
- private ACTION_TYPE_CLEAR = "ACTION_TYPE_CLEAR"
- private ACTION_TYPE_CLICK = "ACTION_TYPE_CLICK"
-
- private mAppMessages : Map> = new Map()
- private mNeedExecClickMessages : PushMessage[] = []
- private mNeedExecReceiveMessages : PushMessage[] = []
-
- static getInstance() : PushManager {
- if (this.INSTANCE == null) {
- this.INSTANCE = new PushManager()
- }
- return this.INSTANCE!!
- }
-
-
-
-
-
- createNotification(context : Context, message : PushMessage) {
- PushChannelManager.getInstance().createDefaultChannel(context)
- const intent = new Intent(this.ACTION_TYPE_CREATE)
- intent.putExtras(message.toBundle())
- this.processAction(context, intent)
- }
-
- addPushMessage(pAppid : string, pMsg : PushMessage) {
- let _arr = this.mAppMessages.get(pAppid);
- if (_arr == null) {
- _arr = new Array();
- this.mAppMessages.set(pAppid, _arr);
- }
- _arr.push(pMsg);
- }
-
-
- addNeedExecClickMessage(pushMessage : PushMessage) {
- if (this.mNeedExecClickMessages.length > 0) {
- this.mNeedExecClickMessages = []
- }
- this.mNeedExecClickMessages.push(pushMessage)
- }
-
- addNeedExecReceiveMessage(pushMessage : PushMessage) {
- this.mNeedExecReceiveMessages.push(pushMessage)
- }
-
- removePushMessage(pAppid : String, pPushMsg : PushMessage) {
- const _arr = this.mAppMessages.get(pAppid);
- if (_arr != null && _arr.indexOf(pPushMsg) > 0) {
- _arr.splice(_arr.indexOf(pPushMsg), 1);
- }
- }
-
- /**
- * 消费缓存的消息
- */
- comsumeMessages(type : string, cb : (msgs : PushMessage[]) => void) {
- if (type == "click") {
- cb(this.mNeedExecClickMessages)
- this.mNeedExecClickMessages.splice(0)
- } else if (type == "receive") {
- cb(this.mNeedExecReceiveMessages)
- this.mNeedExecReceiveMessages.splice(0)
- }
- }
-
-
- processAction(context : Context, intent : Intent) {
- const notificationManager = context.getSystemService(Context.NOTIFICATION_SERVICE) as NotificationManager
- const action = intent.getAction()
- switch (action) {
- case this.ACTION_TYPE_CREATE:
- {
- const title = intent.getStringExtra("title");
- const message = intent.getStringExtra("content");
- const nId = intent.getIntExtra("nId", 0);
- const when = intent.getLongExtra("when", 0);
- const appid = intent.getStringExtra("appid");
- const icon = intent.getStringExtra("icon");
- const sound = intent.getStringExtra("sound");
- const category = intent.getStringExtra("category");
- let channelId = intent.getStringExtra("channelId");
- const i = new Intent(this.ACTION_TYPE_CLICK);
- i.setComponent(new ComponentName(context.getPackageName(), "uts.sdk.modules.DCloudUniPush.PushActionService"));
- i.putExtras(intent.getExtras()!!);
- let flags = PendingIntent.FLAG_ONE_SHOT;
- if (Build.VERSION.SDK_INT >= 23) {
- flags = PendingIntent.FLAG_ONE_SHOT | PendingIntent.FLAG_IMMUTABLE;
- }
- const contentIntent = PendingIntent.getService(context, nId, i, flags);
-
- let builder : Notification.Builder | null = null;
- if (Build.VERSION.SDK_INT >= 26) {
- if (TextUtils.isEmpty(channelId)) {
- channelId = PushChannelManager.LOCAL_PUSH_CHANNEL_ID;
- }
- builder = new Notification.Builder(context, channelId);
- } else {
- builder = new Notification.Builder(context);
- }
-
- let bitmap : Bitmap | null = null;
- try {
- if (!TextUtils.isEmpty(icon) && this.fileIsExist(icon!!)) {
- bitmap = BitmapFactory.decodeFile(icon!!);
- }
- } catch (e : Exception) {
- e.printStackTrace();
- }
- if (bitmap != null) {
- builder.setLargeIcon(bitmap);
- }
-
- const id_small = context.getResources().getIdentifier("push_small", "drawable", context.getPackageName())
- if (id_small <= 0) {
- builder.setSmallIcon(context.getApplicationInfo().icon); //设置图标
- } else {
- builder.setSmallIcon(id_small); //设置图标
- }
-
- const id = context.getResources().getIdentifier("push", "drawable", context.getPackageName())
- if (bitmap == null) {
- let largeBitmap : Bitmap | null = null;
- if (id <= 0) {
- largeBitmap = BitmapFactory.decodeResource(context.getResources(), context.getApplicationInfo().icon);
- } else {
- largeBitmap = BitmapFactory.decodeResource(context.getResources(), id);
- }
- if (null != largeBitmap) {
- builder.setLargeIcon(largeBitmap);
- }
- }
- builder.setContentTitle(title); //设置标题
- builder.setContentText(message); //消息内容
- if (Build.VERSION.SDK_INT >= 24) {
- builder.setShowWhen(true);
- }
- builder.setWhen(when); //发送时间
-
- // 添加声音提示
- if ("system" == sound) {
- builder.setDefaults(Notification.DEFAULT_SOUND); //设置默认的提示音,振动方式,灯光
- }
- builder.setAutoCancel(true);//打开程序后图标消失
- builder.setContentIntent(contentIntent);
- builder.setCategory(category);
- const notification = builder.build();
- try {
- notificationManager.notify(nId, notification);
- } catch (e : Exception) {
- e.printStackTrace();
- }
- }
-
- break;
- case this.ACTION_TYPE_REMOVE:
- {
- const _id = intent.getIntExtra("id", 0);
- if (_id != null) {
- notificationManager.cancel(_id);
- }
- }
- break;
- case this.ACTION_TYPE_CLEAR:
- {
- notificationManager.cancelAll();
- const _appid = intent.getStringExtra("_appId");
- if (_appid != null) {
- const appMsg = PushManager.getInstance().mAppMessages;
- appMsg.delete(_appid);
- }
- }
- break;
- case this.ACTION_TYPE_CLICK:
- {
- this.clickHandle(intent, notificationManager);
- const packagename = context.getPackageName();// 启动类所在包名
- const pm = context.getPackageManager();
- const _intent = pm.getLaunchIntentForPackage(packagename);
- const appid = intent.getStringExtra("appid");
- _intent?.putExtra("appid", appid);
- const isStartWeb = intent?.getBooleanExtra("__start_first_web__", false) ?? false;
- if (isStartWeb) {
- _intent?.putExtra("__start_first_web__", isStartWeb);
- _intent?.putExtra("__first_web_url__", intent?.getStringExtra("__first_web_url__"));
- }
- _intent?.putExtra("__start_from__", 3);
- _intent?.putExtra("__payload__", intent?.getStringExtra("payload"));
- _intent?.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP | Intent.FLAG_ACTIVITY_NEW_TASK);
- context.startActivity(_intent);
- }
- break;
- }
-
- }
-
- clickHandle(intent : Intent, _notificationManager : NotificationManager) {
- const _bundle = intent.getExtras()!!;
- const appid = _bundle.getString("appid");
- const uuid = _bundle.getString("uuid");
- if (_notificationManager != null) {//作为插件时,手助负责创建通知栏消息
- const _id = intent.getIntExtra("id", 0);
- _notificationManager.cancel(_id);
- }
- let _pushMessage : PushMessage | null = null
- if (appid != null && uuid != null) {
- _pushMessage = this.findPushMessage(appid!!, uuid!!);
- }
- if (_pushMessage != null) {
- let isStartWeb = false;
- if (!TextUtils.isEmpty(_pushMessage.mPayload)) {
- try {
- const payLoadJson = JSON.parseObject(_pushMessage.mPayload ?? "")
- const url = payLoadJson?.getString("__adurl")
- if (!TextUtils.isEmpty(url)) {
- intent.putExtra("__start_first_web__", true);
- intent.putExtra("__first_web_url__", url);
- isStartWeb = true;
- }
- } catch (e : Exception) {
- e.printStackTrace();
- }
- }
-
- if (!isStartWeb && !sendEvent("click", _pushMessage)) {
- this.addNeedExecClickMessage(_pushMessage);
- }
- // 点击后的消息,需要移除消息记录,避免getAllMessage时不正确
- if (appid != null) {
- this.removePushMessage(appid, _pushMessage);
- }
- } else {
- _pushMessage = new PushMessage(_bundle);
- if (!TextUtils.isEmpty(_pushMessage.mPayload)) {
- try {
- const payLoadJson = JSON.parseObject(_pushMessage.mPayload!!)
- const url = payLoadJson?.getString("__adurl")
- if (!TextUtils.isEmpty(url)) {
- intent.putExtra("__start_first_web__", true);
- intent.putExtra("__first_web_url__", url);
- }
- } catch (e : Exception) {
- e.printStackTrace();
- }
- }
- this.addNeedExecClickMessage(_pushMessage);
- }
- _bundle.clear();
- }
-
-
-
- findPushMessage(pAppid : String, pUuid : String) : PushMessage | null {
- let _ret : PushMessage | null = null;
- const _arr = this.mAppMessages.get(pAppid);
- if (_arr == null) {//若没有通过appid获取到消息集合,则通过uuid遍历所有消息
- this.mAppMessages.forEach((value : PushMessage[], key : string) => {
- if (value != null) {
- value.forEach((value : PushMessage) => {
- if (pUuid == value.getMessageUUID()) {
- _ret = value
- }
- })
- }
- })
- } else if (_arr != null) {
- _arr.forEach((value : PushMessage) => {
- if (pUuid == value.getMessageUUID()) {
- _ret = value
- }
- })
- }
- return _ret;
- }
-
-
- fileIsExist(path : string) : boolean {
- const realPath = UTSAndroid.convert2AbsFullPath(path)
- const file = new File(realPath)
- return file.exists()
- }
-}
\ No newline at end of file
diff --git a/uni_modules/uni-push/utssdk/app-android/push/PushMessage.uts b/uni_modules/uni-push/utssdk/app-android/push/PushMessage.uts
deleted file mode 100644
index ef84878939440a73a869e785081e1ea50f74b66c..0000000000000000000000000000000000000000
--- a/uni_modules/uni-push/utssdk/app-android/push/PushMessage.uts
+++ /dev/null
@@ -1,275 +0,0 @@
-import TextUtils from 'android.text.TextUtils'
-import Bundle from 'android.os.Bundle';
-
-export class PushMessage {
- private mTitle : string | null = null
- private contentJson : string | null = null
- private mContent : string | null = null
-
- mPayloadJSON : UTSJSONObject | null = null
- mPayload : string | null = null
-
- private mWhen : Long = 0
- mDelay : Long = 0
- private mPath : string | null = null
- private mForceNotification : string | null = null
- private channelId = ""
- private category = ""
- private mMessageAppid : string | null = null
- private mIconPath : string | null = null
-
- private mUUID : string | null = null
- private nID : number = 0
- private isCover = false
- private sound = "system"
- private static mNotificationId = 1
- private needCreateNotification = true
-
- private pushVersion : Float = 1.0.toFloat()
- private extJSON : UTSJSONObject | null = null
-
- constructor(data : string, defaultTitle : string, isUniPush2 : boolean) {
- if (!isUniPush2) {
- this.contentJson = data
- this.parseJson(data, UTSAndroid.getAppId(), defaultTitle)
- } else {
- this.extJSON = JSON.parseObject(data)
- this.mMessageAppid = UTSAndroid.getAppId()
- this.pushVersion = 2.0.toFloat()
- if (this.extJSON != null) {
- this.channelId = this.extJSON!!.getString("channelId") ?? ""
- this.category = this.extJSON!!.getString("category") ?? ""
- }
- }
- this.setMessageUUID()
- this.setNotificationID()
- }
-
- $constructor(b : Bundle) {
- this.mTitle = b.getString("title");
- this.mContent = b.getString("content");
- this.nID = b.getInt("nId");
- this.mWhen = b.getLong("when");
- this.sound = b.getString("sound") ?? "system";
- this.mMessageAppid = b.getString("appid");
- this.mUUID = b.getString("uuid");
- this.mPayload = b.getString("payload");
- this.mIconPath = b.getString("icon");
- this.channelId = b.getString("channelId", "");
- this.category = b.getString("category", "");
- }
-
-
-
- getNeedCreateNotification() : boolean {
- return this.needCreateNotification;//payload为空串时需要创建
- }
-
- getMessageUUID() : string | null {
- return this.mUUID
- }
-
- getJsonObject() : UTSJSONObject {
- if (this.extJSON != null) {
- if (this.pushVersion == (2.0.toFloat())) {
- try {
- this.extJSON!!["__UUID__"] = this.mUUID
- this.extJSON!!["appid"] = this.mMessageAppid
- } catch (e : Exception) {
- e.printStackTrace()
- return {};
- }
- }
- return this.extJSON!!
- } else {
- const result = {} as UTSJSONObject;
- result["__UUID__"] = this.mUUID
- result["title"] = this.mTitle
- result["appid"] = this.mMessageAppid
- result["content"] = this.mContent
- if (this.mPayloadJSON != null) {
- result["payload"] = this.cleanNullValue(this.mPayloadJSON!!)
- } else {
- let payLoadObj : UTSJSONObject | null = null
- if (this.mPayload != null) {
- payLoadObj = JSON.parseObject(this.mPayload!!)
- }
-
- if (payLoadObj != null) {
- result["payload"] = this.cleanNullValue(payLoadObj)
- } else {
- result["payload"] = this.mPayload
- }
- }
- if (!TextUtils.isEmpty(this.mPath)) {
- result["path"] = this.mPath
- }
- if (!TextUtils.isEmpty(this.mForceNotification)) {
- result["force_notification"] = this.mForceNotification
- }
- if (!TextUtils.isEmpty(this.channelId)) {
- result["channelId"] = this.channelId
- }
- if (!TextUtils.isEmpty(this.category)) {
- result["category"] = this.category
- }
- return result
- }
- }
-
- cleanNullValue(json : UTSJSONObject) : UTSJSONObject {
- const result = {}
- json.toMap().forEach((value, key) => {
- if (value != null) {
- result[key] = value
- }
- })
- return result
- }
-
-
- toBundle() : Bundle {
- const bundle = new Bundle()
- if (this.extJSON != null && this.pushVersion == (2.0.toFloat())) {
- bundle.putInt("nId", this.nID.toInt());
- bundle.putLong("when", this.mWhen);
- bundle.putString("sound", this.sound);
- bundle.putString("appid", this.mMessageAppid);
- bundle.putString("uuid", this.mUUID);
- bundle.putString("icon", this.mIconPath);
-
- const map = this.extJSON!!.toMap()
- map.forEach((value, key) => {
- if (value != null) {
- if (typeof value == 'string') {
- bundle.putString(key, value as string);
- } else if (value instanceof Integer) {
- bundle.putInt(key, value as Int);
- } else if (value instanceof Double) {
- bundle.putDouble(key, value);
- } else if (typeof value == 'boolean') {
- bundle.putBoolean(key, value as boolean);
- } else if (value instanceof UTSJSONObject) {
- bundle.putString(key, (value as UTSJSONObject).toJSONString());
- }
- }
- })
- return bundle
- }
-
- bundle.putString("title", this.mTitle);
- bundle.putString("content", this.mContent);
- bundle.putInt("nId", this.nID.toInt());
- bundle.putLong("when", this.mWhen);
- bundle.putString("sound", this.sound);
- bundle.putString("appid", this.mMessageAppid);
- bundle.putString("uuid", this.mUUID);
- if (this.mPayloadJSON != null) {
- bundle.putString("payload", this.mPayloadJSON!!.toJSONString());
- } else {
- bundle.putString("payload", this.mPayload);
- }
- bundle.putString("icon", this.mIconPath);
- bundle.putString("channelId", this.channelId);
- bundle.putString("category", this.category);
-
- return bundle
- }
-
-
-
- private setMessageUUID() : void {
- this.mUUID = "androidPushMsg" + this.hashCode()
- }
-
- private setNotificationID() : void {
- if (!this.isCover) {
- PushMessage.mNotificationId++
- }
- this.nID = PushMessage.mNotificationId
- }
-
-
- /**
- * 解析消息的数据
- * @param defaultAppid 通过appid 查询到icon资源 , 1.0强需求, 2.0 不需求
- */
- private parseJson(data : string, defaultAppid : string, defaultTitle : string) : void {
- const json = JSON.parseObject(data)
- if (json != null) {
- let t_appid = json.getString("appid")
- const content = json.getString("content")
- if (content != null) {
- this.mContent = content
- } else {
- const message = json.getString("message")
- if (message != null) {
- this.mContent = message
- } else {
- this.needCreateNotification = true
- this.mContent = data
- }
- }
-
- if (this.hasOwnProperty(json, "payload")) {
- const payloadJson = json.getJSON("payload")
- if (payloadJson != null) {
- this.mPayloadJSON = payloadJson
- } else {
- this.mPayload = json.getString("payload")
- }
- } else {
- if (this.hasOwnProperty(json, "Payload")) {
- const payloadJson = json.getJSON("Payload")
- if (payloadJson != null) {
- this.mPayloadJSON = payloadJson
- } else {
- this.mPayload = json.getString("Payload")
- }
- } else {
- this.needCreateNotification = false
- this.mPayload = data
- }
- }
-
- if (this.hasOwnProperty(json, "title")) {
- this.mTitle = json.getString("title")
- } else {
- this.needCreateNotification = false
- this.mTitle = defaultTitle
- }
-
- this.isCover = json.getBoolean("cover") ?? false
- if ("none" == json.getString("sound")) {
- this.sound = "none"
- }
- this.mWhen = (json.getNumber("when") ?? 0).toLong()
- this.mDelay = (json.getNumber("delay") ?? 0).toLong()
-
- this.mPath = json.getString("path")
- this.mForceNotification = json.getString("force_notification")
- this.channelId = json.getString("channelId") ?? ""
- this.category = json.getString("category") ?? ""
-
- if (TextUtils.isEmpty(t_appid)) {
- t_appid = defaultAppid
- }
- this.mMessageAppid = t_appid
- const iconPath = json.getString("icon") ?? ""
- this.mIconPath = UTSAndroid.convert2AbsFullPath(iconPath)
- } else {
- this.needCreateNotification = false
- this.mContent = data
- this.mPayload = data
- this.mTitle = defaultTitle
- }
- }
-
-
- private hasOwnProperty(jsonObject : UTSJSONObject, key : string) : boolean {
- return jsonObject.getAny(key) != null
- }
-
-
-
-}
\ No newline at end of file
diff --git a/uni_modules/uni-push/utssdk/app-android/push/PushState.uts b/uni_modules/uni-push/utssdk/app-android/push/PushState.uts
deleted file mode 100644
index c80852d5c975a9af825366fe6c71a6d723f0adf1..0000000000000000000000000000000000000000
--- a/uni_modules/uni-push/utssdk/app-android/push/PushState.uts
+++ /dev/null
@@ -1,42 +0,0 @@
-import Context from 'android.content.Context';
-import PackageManager from 'android.content.pm.PackageManager';
-import Bundle from 'android.os.Bundle';
-import TextUtils from 'android.text.TextUtils';
-export class PushState {
-
- private static sMetaDatas : Bundle | null = null
-
-
- static getAutoNotification() : boolean {
- const context = UTSAndroid.getAppContext() as Context
- const sp = context.getSharedPreferences("push_db_name", Context.MODE_PRIVATE)
- const autoNotification = this.getMetaValue(context, "dcloud_unipush_auto_notification")
- let needPush = true
- if (autoNotification != null) {
- if (!autoNotification.equals("ture", true)) {
- needPush = false;
- }
- }
- needPush = sp.getBoolean("auto_notification", needPush);
- return needPush
- }
-
-
- private static getMetaValue(context : Context, metaKey : string) : string | null {
- if (this.sMetaDatas == null) {
- try {
- this.sMetaDatas = context.getPackageManager().getApplicationInfo(context.getPackageName(), PackageManager.GET_META_DATA).metaData;
- } catch (e : Exception) {
- e.printStackTrace();
- return null;
- }
- }
- if (this.sMetaDatas != null) {
- const value = this.sMetaDatas!!.get(metaKey)
- if (value != null && !TextUtils.isEmpty(value as string)) {
- return value as string;
- }
- }
- return null;
- }
-}
\ No newline at end of file
diff --git a/uni_modules/uni-push/utssdk/app-android/push/utils/StringUtil.uts b/uni_modules/uni-push/utssdk/app-android/push/utils/StringUtil.uts
deleted file mode 100644
index 97bc29a1408d4a5be16314cd31c4e18751147513..0000000000000000000000000000000000000000
--- a/uni_modules/uni-push/utssdk/app-android/push/utils/StringUtil.uts
+++ /dev/null
@@ -1,31 +0,0 @@
-export class StringUtil {
- static trimString(pSrc : string, removed : string) : string {
- const pTrimChar = removed.charAt(0)
- let _ret = pSrc;
- if (_ret != null && _ret != "") {
- const _startPosi = _ret.charAt(0) == pTrimChar ? 1 : 0;
- const _count = _ret.length;
- const _endPosi = _ret.charAt(_count - 1) == pTrimChar ? _count - 1 : _count;
- _ret = _ret.substring(_startPosi, _endPosi);
- }
- return _ret;
- }
-
- static getInt(content : string) : number | null {
- try {
- return content.toInt();
- } catch (e : Exception) {
- return null;
- }
- }
-
-
- static getDouble(content : string) : number | null {
- try {
- return content.toDouble()
- } catch (e : Exception) {
- return null;
- }
- }
-
-}
\ No newline at end of file
diff --git a/uni_modules/uni-push/utssdk/app-android/res/drawable-xxhdpi/push.png b/uni_modules/uni-push/utssdk/app-android/res/drawable-xxhdpi/push.png
deleted file mode 100755
index ed3d29bd26d2b611a328fba26aac73b44e916a10..0000000000000000000000000000000000000000
Binary files a/uni_modules/uni-push/utssdk/app-android/res/drawable-xxhdpi/push.png and /dev/null differ
diff --git a/uni_modules/uni-push/utssdk/app-android/res/drawable-xxhdpi/push_small.png b/uni_modules/uni-push/utssdk/app-android/res/drawable-xxhdpi/push_small.png
deleted file mode 100755
index 800dbd4a677f3c838095d7f31a4bc60ef85e75ed..0000000000000000000000000000000000000000
Binary files a/uni_modules/uni-push/utssdk/app-android/res/drawable-xxhdpi/push_small.png and /dev/null differ
diff --git a/uni_modules/uni-push/utssdk/app-android/res/raw/keep.xml b/uni_modules/uni-push/utssdk/app-android/res/raw/keep.xml
deleted file mode 100644
index 35edb41154a913b6042713dad4b709968f2b9970..0000000000000000000000000000000000000000
--- a/uni_modules/uni-push/utssdk/app-android/res/raw/keep.xml
+++ /dev/null
@@ -1,7 +0,0 @@
-
-
-
- 消息推送
- 推送消息
-
-
\ No newline at end of file
diff --git a/uni_modules/uni-push/utssdk/app-android/res/values/values.xml b/uni_modules/uni-push/utssdk/app-android/res/values/values.xml
deleted file mode 100644
index 012adb5e607f5fee15fbdd8653591adaedf7a808..0000000000000000000000000000000000000000
--- a/uni_modules/uni-push/utssdk/app-android/res/values/values.xml
+++ /dev/null
@@ -1,6 +0,0 @@
-
-
- unipush
- message push
-
-
\ No newline at end of file
diff --git a/uni_modules/uni-push/utssdk/app-ios/index.uts b/uni_modules/uni-push/utssdk/app-ios/index.uts
deleted file mode 100644
index e69de29bb2d1d6434b8b29ae775ad8c2e48c5391..0000000000000000000000000000000000000000
diff --git a/uni_modules/uni-push/utssdk/interface.uts b/uni_modules/uni-push/utssdk/interface.uts
deleted file mode 100644
index 84490f8ac43178f6aa5003271af83a36dff8e0d6..0000000000000000000000000000000000000000
--- a/uni_modules/uni-push/utssdk/interface.uts
+++ /dev/null
@@ -1,396 +0,0 @@
-export interface Uni {
- /**
- * getPushClientId()
- * @description
- * 获取客户端唯一的推送标识
- * @param {GetPushClientIdOptions}
- * @return {void}
- * @tutorial http://uniapp.dcloud.io/api/plugins/push.html#getpushclientid
- * @uniPlatform {
- * "app": {
- * "android": {
- * "osVer": "4.4",
- * "uniVer": "√",
- * "unixVer": "3.97"
- * },
- * "ios": {
- * "osVer": "9.0",
- * "uniVer": "x",
- * "unixVer": "x"
- * }
- * }
- * }
- * @example
- ```typescript
- uni.getPushClientId({
- complete: (res: any) => {
- console.log("getPushClientId complete => " + JSON.stringify(res));
- }
- });
- ```
- */
- getPushClientId(options : GetPushClientIdOptions) : void;
- /**
- * onPushMessage()
- * @description
- * 启动监听推送消息事件
- * @param {OnPushMessageCallback}
- * @return {void}
- * @tutorial http://uniapp.dcloud.io/api/plugins/push.html#onpushmessage
- * @uniPlatform {
- * "app": {
- * "android": {
- * "osVer": "4.4",
- * "uniVer": "√",
- * "unixVer": "3.97"
- * },
- * "ios": {
- * "osVer": "9.0",
- * "uniVer": "x",
- * "unixVer": "x"
- * }
- * }
- * }
- * @example
- ```typescript
- uni.onPushMessage((res : OnPushMessageCallbackResult) => {
- console.log("onPushMessage => " + JSON.stringify(res))
- });
- ```
- */
- onPushMessage(callback : OnPushMessageCallback) : void;
- /**
- * offPushMessage()
- * @description
- * 关闭推送消息监听事件
- * @param {OnPushMessageCallback}
- * @return {void}
- * @tutorial http://uniapp.dcloud.io/api/plugins/push.html#offpushmessage
- * @uniPlatform {
- * "app": {
- * "android": {
- * "osVer": "4.4",
- * "uniVer": "√",
- * "unixVer": "3.97"
- * },
- * "ios": {
- * "osVer": "9.0",
- * "uniVer": "x",
- * "unixVer": "x"
- * }
- * }
- * }
- * @example
- ```typescript
- const cb = (res : OnPushMessageCallbackResult) => {
- console.log("onPushMessage => " + JSON.stringify(res))
- }
- uni.offPushMessage(cb);
- ```
- */
- offPushMessage(callback : OnPushMessageCallback) : void;
- /**
- * getChannelManager()
- * @description
- * 获取通知渠道管理器,Android 8系统以上才可以设置通知渠道,Android 8系统以下返回null。
- * @param {void}
- * @return {ChannelManager}
- * @uniPlatform {
- * "app": {
- * "android": {
- * "osVer": "4.4",
- * "uniVer": "3.97",
- * "unixVer": "3.97"
- * },
- * "ios": {
- * "osVer": "9.0",
- * "uniVer": "x",
- * "unixVer": "x"
- * }
- * }
- * }
- * @example
- ```typescript
- const channelManager = uni.getChannelManager();
- channelManager.setPushChannel({
- channelId: "test1",
- channelDesc: "test1 desc",
- soundName: "pushsound"
- })
- const channels = channelManager.getAllChannels() as string[]
- console.log("channels : " + channels);
- ```
- */
- getChannelManager() : ChannelManager;
-
- /**
- * createPushMessage()
- * @description
- * 创建本地通知栏消息
- * @param {CreatePushMessageOptions}
- * @return {void}
- * @tutorial http://uniapp.dcloud.io/api/plugins/push.html#createpushmessage
- * @uniPlatform {
- * "app": {
- * "android": {
- * "osVer": "4.4",
- * "uniVer": "√",
- * "unixVer": "3.97"
- * },
- * "ios": {
- * "osVer": "9.0",
- * "uniVer": "x",
- * "unixVer": "x"
- * }
- * }
- * }
- * @example
- ```typescript
- uni.createPushMessage({
- title:"hello",
- content: "content"
- });
- ```
- */
- createPushMessage(options : CreatePushMessageOptions) : void;
-}
-
-export type GetPushClientId = (options : GetPushClientIdOptions) => void;
-export type GetPushClientIdSuccess = {
- /**
- * 个推客户端推送id,对应uni-id-device表的push_clientid
- */
- cid : string,
- /**
- * 错误描述
- */
- errMsg : string
-};
-export type GetPushClientIdSuccessCallback = (result : GetPushClientIdSuccess) => void;
-export type GetPushClientIdFail = UniError;
-export type GetPushClientIdFailCallback = (result : GetPushClientIdFail) => void;
-export type GetPushClientIdComplete = any;
-export type GetPushClientIdCompleteCallback = (result : GetPushClientIdComplete) => void;
-export type GetPushClientIdOptions = {
- /**
- * 接口调用成功的回调函数
- * @defaultValue null
- */
- success : GetPushClientIdSuccessCallback | null,
- /**
- * 接口调用失败的回调函数
- * @defaultValue null
- */
- fail : GetPushClientIdFailCallback | null,
- /**
- * 接口调用结束的回调函数(调用成功、失败都会执行)
- * @defaultValue null
- */
- complete : GetPushClientIdCompleteCallback | null
-};
-/**
- * 事件类型
- * - click 从系统推送服务点击消息启动应用事件
- * - receive 应用从推送服务器接收到推送消息事件
- */
-export type OnPushMessageType = "click" | "receive";
-
-export type OnPushMessageCallbackResult = {
- /**
- * 事件类型
- * @type{OnPushMessageType}
- */
- type : OnPushMessageType,
- /**
- * 消息内容
- */
- data : UTSJSONObject
-};
-
-export type OnPushMessageCallback = (result : OnPushMessageCallbackResult) => void;
-export type OnPushMessage = (callback : OnPushMessageCallback) => void;
-export type OffPushMessage = (callback : OnPushMessageCallback) => void;
-
-
-export type GetChannelManager = () => ChannelManager;
-export type SetPushChannelOptions = {
- /**
- * 添加的声音文件,注意raw目录下必须要有 ,不传此字段将使用默认铃音。
- * @defaultValue null
- */
- soundName? : string | null,
- /**
- * 通知渠道id
- */
- channelId : string,
- /**
- * 通知渠道描述
- */
- channelDesc : string,
- /**
- * 呼吸灯闪烁
- * @defaultValue false
- */
- enableLights? : boolean | null,
- /**
- * 震动
- * @defaultValue false
- */
- enableVibration? : boolean | null,
- /**
- * 通知的重要性级别,可选范围IMPORTANCE_LOW:2、IMPORTANCE_DEFAULT:3、IMPORTANCE_HIGH:4 。
- * @defaultValue 3
- */
- importance? : number | null,
- /**
- * 锁屏可见性,可选范围VISIBILITY_PRIVATE:0、VISIBILITY_PUBLIC:1、VISIBILITY_SECRET:-1、VISIBILITY_NO_OVERRIDE:-1000。
- * @defaultValue -1000
- */
- lockscreenVisibility? : number | null
-}
-export interface ChannelManager {
- /**
- * 设置推送渠道
- *
- * @uniPlatform {
- * "app": {
- * "android": {
- * "osVer": "4.4",
- * "uniVer": "√",
- * "unixVer": "3.97"
- * },
- * "ios": {
- * "osVer": "9.0",
- * "uniVer": "x",
- * "unixVer": "x"
- * }
- * }
- * }
- */
- setPushChannel(options : SetPushChannelOptions) : void;
- /**
- * 获取当前应用注册的所有的通知渠道。
- *
- * @uniPlatform {
- * "app": {
- * "android": {
- * "osVer": "4.4",
- * "uniVer": "√",
- * "unixVer": "3.97"
- * },
- * "ios": {
- * "osVer": "9.0",
- * "uniVer": "x",
- * "unixVer": "x"
- * }
- * }
- * }
- */
- getAllChannels() : Array;
-}
-
-export type CreatePushMessage = (options : CreatePushMessageOptions) => void;
-export type CreatePushMessageSuccess = {};
-export type CreatePushMessageSuccessCallback = (result : CreatePushMessageSuccess) => void;
-export type CreatePushMessageFail = UniError;
-export type CreatePushMessageFailCallback = (result : CreatePushMessageFail) => void;
-export type CreatePushMessageComplete = any;
-export type CreatePushMessageCompleteCallback = (result : CreatePushMessageComplete) => void;
-export type CreatePushMessageOptions = {
- /**
- * 是否覆盖上一次提示的消息
- * @type boolean
- * @defaultValue false
- */
- cover? : boolean | null,
- /**
- * 提示消息延迟显示的时间,单位为s
- * @defaultValue 0
- */
- delay? : number | null,
- /**
- * 推送消息的图标
- * @defaultValue null
- */
- icon? : string | null,
- /**
- * 推送消息的提示音
- * - system: 使用系统通知提示音(默认值)
- * - none: 不使用提示音
- * @type 'system' | 'none'
- * @defaultValue "system"
- */
- sound? : string | null,
- /**
- * 推送消息的标题
- * @defaultValue ""
- */
- title? : string | null,
- /**
- * 消息显示的内容,在系统通知中心中显示的文本内容
- */
- content : string,
- /**
- * 消息承载的数据,可根据业务逻辑自定义数据格式
- * @defaultValue null
- */
- payload? : any | null,
- /**
- * 消息上显示的提示时间
- * @defaultValue 当前时间
- */
- when? : number | null,
- /**
- * 渠道id
- * @defaultValue "DcloudChannelID"
- * @uniPlatform {
- * "app": {
- * "android": {
- * "osVer": "4.4",
- * "uniVer": "√",
- * "unixVer": "3.97"
- * },
- * "ios": {
- * "osVer": "9.0",
- * "uniVer": "x",
- * "unixVer": "x"
- * }
- * }
- * }
- */
- channelId? : string | null,
- /**
- * 通知类别
- * @defaultValue null
- * @uniPlatform {
- * "app": {
- * "android": {
- * "osVer": "4.4",
- * "uniVer": "√",
- * "unixVer": "3.97"
- * },
- * "ios": {
- * "osVer": "9.0",
- * "uniVer": "x",
- * "unixVer": "x"
- * }
- * }
- * }
- */
- category? : string | null,
- /**
- * 接口调用成功的回调函数
- * @defaultValue null
- */
- success : CreatePushMessageSuccessCallback | null,
- /**
- * 接口调用失败的回调函数
- * @defaultValue null
- */
- fail : CreatePushMessageFailCallback | null,
- /**
- * 接口调用结束的回调函数(调用成功、失败都会执行)
- * @defaultValue null
- */
- complete : CreatePushMessageCompleteCallback | null
-};