AudioHomePresenterImpl.kt 9.93 KB
Newer Older
洪国微 committed
1 2
package com.ydl.audioim.presenter

严久程 committed
3
import android.annotation.SuppressLint
洪国微 committed
4 5
import com.ydl.audioim.BuildConfig
import com.ydl.audioim.contract.IAudioHomeActivityContract
6 7
import com.ydl.audioim.http.command.ConnectCommand
import com.ydl.audioim.http.command.NoticePushCommand
洪国微 committed
8
import com.ydl.audioim.model.AudioHomeModelImpl
YKai committed
9
import com.ydl.audioim.utils.AudioLogUtils
10
import com.ydl.ydl_av.chat.config.YDLChatParam
洪国微 committed
11 12
import com.ydl.ydlcommon.mvp.base.BasePresenter
import com.ydl.ydlcommon.router.YdlCommonRouterManager
13
import com.ydl.ydlcommon.utils.LogUtil
14 15
import com.ydl.ydlcommon.utils.log.AliYunLogConfig
import com.ydl.ydlcommon.utils.log.AliYunRichLogsHelper
YKai committed
16
import com.ydl.ydlcommon.utils.log.LogHelper
洪国微 committed
17 18 19
import com.ydl.ydlcommon.utils.remind.ToastHelper
import io.reactivex.android.schedulers.AndroidSchedulers
import io.reactivex.schedulers.Schedulers
YKai committed
20
import java.util.*
洪国微 committed
21 22 23 24 25 26 27 28

/**
 * @author jiucheng
 * @描述:
 * @Copyright Copyright (c) 2018
 * @Company 壹点灵
 * @date 2018/10/30
 */
YKai committed
29 30 31
class AudioHomePresenterImpl :
    BasePresenter<IAudioHomeActivityContract.View, IAudioHomeActivityContract.Model>(),
    IAudioHomeActivityContract.Presenter {
32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50
//    override fun connectStart(param: ConnectStartCommand) {
//        mModel.connectStart(param)
//                .subscribeOn(Schedulers.io())
//                .observeOn(AndroidSchedulers.mainThread())
//                .doOnSubscribe {
//
//                }
//                .doAfterTerminate {
////                    view.dismissProgressView()
//                }
//                .subscribe({
////                    if (isSwitchAxb) {
////                        //切换axb:跳到拨号界面
////                        view.dialPhone()
////                    }
//                }, { e ->
//                    LogUtil.e(e.message)
//                })
//    }
洪国微 committed
51

52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
//    override fun connectFinish(param: ConnectFinishCommand) {
//        mModel.connectFinish(param)
//                .subscribeOn(Schedulers.io())
//                .observeOn(AndroidSchedulers.mainThread())
//                .doOnSubscribe {
//                    //通知服务端专家已经接通时,此时用户已在界面通话中,不需要弹进度条
//                    mView.showProgressView()
//                }
//                .doAfterTerminate {
//                    mView.dismissProgressView()
//                }
//                .subscribe({
////                    if (isSwitchAxb) {
////                        //切换axb:跳到拨号界面
////                        view.dialPhone()
////                    }
//                    //挂断逻辑:不管接口调用成功与否,都关闭界面
//                    mView.finishActivity()
//                }, { e ->
//                    LogUtil.e(e.message)
//                    //挂断逻辑:不管接口调用成功与否,都关闭界面
//                    mView.finishActivity()
//                })
//    }
洪国微 committed
76

77

洪国微 committed
78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104
    /**
     * 登录声网
     */
    override fun loginChatNet(signalingToken: String) {
        mView.showProgressView()
        // appId:应用id
        // account:uid
        // token :由 App ID 和 App Certificate 生成的 SignalingToken (如果不使用token可以设为字符串 _no_need_token)
        // uid:固定填 0
        // deviceID:暂时无用,设置为空
        // retry_time_in_s:登录重试时间,默认为 30 秒
        // retry_count:登录重试次数,默认为 3 次
        val ydlChtat = YDLChatParam()
        ydlChtat.appId = BuildConfig.AGORA_APPID
        ydlChtat.account = YdlCommonRouterManager.getYdlCommonRoute().getUid().toString()
        ydlChtat.token = signalingToken
        ydlChtat.uid = 0
        ydlChtat.deviceID = ""
        ydlChtat.retry_time_in_s = 30
        ydlChtat.retry_count = 3

//        YDLChartManager.instance!!.getChatApi().login(ydlChtat)
    }

    /**
     * 获取axb电话
     */
严久程 committed
105
    @SuppressLint("CheckResult")
洪国微 committed
106 107
    override fun getAXBPhone(cmd: ConnectCommand) {
        mModel.getAXBPhone(cmd)
YKai committed
108 109 110 111 112 113 114 115 116 117 118
            .subscribeOn(Schedulers.io())
            .observeOn(AndroidSchedulers.mainThread())
            .doOnSubscribe { mView.showProgressView() }
            .doAfterTerminate { mView.dismissProgressView() }
            .subscribe({
                if ("200" == it.code) {
                    if (0 == it.data?.dialDetail?.dialStatus ?: -1) {
                        //连接成功
                        if (it.data?.dialDetail?.callConnectType ?: -1 == 1) {
                            //axb
                            mView.switchAXBResponse(it.data?.dialDetail?.phoneNu ?: "")
119 120 121 122 123 124 125
                            AudioLogUtils.writeAgoraLog(
                                "连接成功,连接状态:${it.data?.dialDetail?.dialStatus}-------Time:${
                                    AudioLogUtils.format.format(
                                        Calendar.getInstance().time
                                    )
                                }", "confide.log", true
                            )
YKai committed
126 127
                        } else {
                            ToastHelper.show(it.data?.dialDetail?.dialReason ?: "连接失败")
128 129 130 131 132 133 134
                            AudioLogUtils.writeAgoraLog(
                                "连接状态:${it.data?.dialDetail?.dialStatus}失败原因:${it.data?.dialDetail?.dialReason}-------Time:${
                                    AudioLogUtils.format.format(
                                        Calendar.getInstance().time
                                    )
                                }", "confide.log", true
                            )
YKai committed
135
                            LogHelper.getInstance().uploadLog(false)
洪国微 committed
136
                        }
YKai committed
137 138
                    } else {
                        ToastHelper.show(it.data?.dialDetail?.dialReason ?: "连接失败")
139 140 141 142 143 144 145
                        AudioLogUtils.writeAgoraLog(
                            "连接状态:${it.data?.dialDetail?.dialStatus}失败原因:${it.data?.dialDetail?.dialReason}-------Time:${
                                AudioLogUtils.format.format(
                                    Calendar.getInstance().time
                                )
                            }", "confide.log", true
                        )
YKai committed
146
                        LogHelper.getInstance().uploadLog(false)
洪国微 committed
147
                    }
YKai committed
148 149
                } else {
                    ToastHelper.show(it.data?.dialDetail?.dialReason ?: "连接失败")
150 151 152 153 154 155 156
                    AudioLogUtils.writeAgoraLog(
                        "连接状态:${it.data?.dialDetail?.dialStatus}失败原因:${it.data?.dialDetail?.dialReason}-------Time:${
                            AudioLogUtils.format.format(
                                Calendar.getInstance().time
                            )
                        }", "confide.log", true
                    )
YKai committed
157
                    LogHelper.getInstance().uploadLog(false)
YKai committed
158 159 160
                }
            }, { e ->
                LogUtil.d(e.message)
161 162 163 164 165 166 167
                AudioLogUtils.writeAgoraLog(
                    "连接状态:${e.message}-------Time:${
                        AudioLogUtils.format.format(
                            Calendar.getInstance().time
                        )
                    }", "confide.log", true
                )
YKai committed
168
                LogHelper.getInstance().uploadLog(false)
YKai committed
169
            })
洪国微 committed
170 171 172 173 174
    }

    /**
     * 通知服务端发送推送
     */
YKai committed
175
    @SuppressLint("CheckResult")
洪国微 committed
176 177
    override fun noticeServerPush(param: NoticePushCommand) {
        mModel.noticeServerPush(param)
YKai committed
178 179 180 181 182
            .subscribeOn(Schedulers.io())
            .observeOn(AndroidSchedulers.mainThread())
            .subscribe({
                if (it.code == 200) {
                    AudioLogUtils.writeAgoraLog(
183 184 185 186 187
                        "通知服务端发送推送成功-------Time:${
                            AudioLogUtils.format.format(
                                Calendar.getInstance().time
                            )
                        }", "confide.log", true
YKai committed
188
                    )
189 190 191
                    AliYunRichLogsHelper.getInstance()
                        .sendRichLog(
                            AliYunLogConfig.AGORA,
刘鹏 committed
192
                            "通知服务端发送推送成功----接口:push/notify/doctor ---Time:${AudioLogUtils.format.format(Calendar.getInstance().time)}"
193
                        )
YKai committed
194 195 196
                } else {
                    LogUtil.e(it.msg)
                    AudioLogUtils.writeAgoraLog(
197 198 199 200 201
                        "通知服务端发送推送失败${it.msg}-------Time:${
                            AudioLogUtils.format.format(
                                Calendar.getInstance().time
                            )
                        }", "confide.log", true
YKai committed
202
                    )
203 204 205
                    AliYunRichLogsHelper.getInstance()
                        .sendRichLog(
                            AliYunLogConfig.AGORA,
刘鹏 committed
206
                            "通知服务端发送推送失败${it.msg}--接口:push/notify/doctor -----Time:${AudioLogUtils.format.format(Calendar.getInstance().time)}"
207
                        )
YKai committed
208
                    LogHelper.getInstance().uploadLog(false)
YKai committed
209 210 211
                }
            }, { e ->
                AudioLogUtils.writeAgoraLog(
212 213 214 215 216
                    "通知服务端发送推送失败${e.message}-------Time:${
                        AudioLogUtils.format.format(
                            Calendar.getInstance().time
                        )
                    }", "confide.log", true
YKai committed
217
                )
218 219 220
                AliYunRichLogsHelper.getInstance()
                    .sendRichLog(
                        AliYunLogConfig.AGORA,
刘鹏 committed
221
                        "通知服务端发送推送失败${e.message}--接口:push/notify/doctor -----Time:${AudioLogUtils.format.format(Calendar.getInstance().time)}"
222
                    )
YKai committed
223
                LogHelper.getInstance().uploadLog(false)
YKai committed
224 225
                LogUtil.e(e.message)
            })
洪国微 committed
226 227 228 229 230 231 232
    }


    override fun createModel(): IAudioHomeActivityContract.Model {
        return AudioHomeModelImpl()
    }
}