O2MainController.swift 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295
  1. //
  2. // O2MainController.swift
  3. // O2Platform
  4. //
  5. // Created by FancyLou on 2019/1/25.
  6. // Copyright © 2019 zoneland. All rights reserved.
  7. //
  8. import UIKit
  9. import CocoaLumberjack
  10. import O2OA_Auth_SDK
  11. import Starscream
  12. class O2MainController: UITabBarController, UITabBarControllerDelegate {
  13. static var tabBarVC: O2MainController!
  14. static func genernateVC() -> O2MainController {
  15. // guard let vc = tabBarVC else {
  16. // tabBarVC = O2MainController()
  17. // return tabBarVC
  18. // }
  19. // return vc
  20. return O2MainController()
  21. }
  22. private var currentIndex: Int = 0
  23. // demo服务器弹出公告
  24. private var demoAlertView = O2DemoAlertView()
  25. private let viewModel: OOLoginViewModel = {
  26. return OOLoginViewModel()
  27. }()
  28. override func viewDidLoad() {
  29. super.viewDidLoad()
  30. if UIDevice.deviceModelReadable() != "Simulator" {
  31. self.checkAppVersion()
  32. }
  33. self.delegate = self
  34. _initControllers()
  35. selectedIndex = 2
  36. currentIndex = 2
  37. _loginIM()
  38. if O2IsConnect2Collect == false {
  39. //处理内部直连的时候推送的设备绑定
  40. O2JPushManager.shared.o2JPushBind()
  41. }
  42. //连接websocket
  43. self._startWebsocket()
  44. }
  45. deinit {
  46. //关闭websocket
  47. self._stopWebsocket()
  48. }
  49. override func viewDidAppear(_ animated: Bool) {
  50. // 判断是否 第一次安装 是否是连接的demo服务器
  51. if let unit = O2AuthSDK.shared.bindUnit() {
  52. if "demo.o2oa.net" == unit.centerHost || "demo.o2oa.io" == unit.centerHost || "demo.o2server.io" == unit.centerHost || "sample.o2oa.net" == unit.centerHost {
  53. let tag = AppConfigSettings.shared.demoAlertTag
  54. if !tag {
  55. demoAlertView.showFallDown()
  56. AppConfigSettings.shared.demoAlertTag = true
  57. }
  58. }
  59. }
  60. }
  61. //MARK: -- delegate
  62. func tabBarController(_ tabBarController: UITabBarController, didSelect viewController: UIViewController) {
  63. // if currentIndex == 2 && tabBarController.selectedIndex == 2 {
  64. // if tabBarController.selectedViewController is ZLNavigationController {
  65. // (tabBarController.selectedViewController as! ZLNavigationController).viewControllers.forEach { (vc) in
  66. // if vc is MailViewController {
  67. // DDLogDebug("点击了首页 portal")
  68. // (vc as! MailViewController).loadDetailSubject()
  69. // }
  70. // if vc is MainTaskSecondViewController {
  71. // DDLogDebug("点击了首页index")
  72. // }
  73. // }
  74. // }
  75. // }
  76. self.currentIndex = tabBarController.selectedIndex
  77. }
  78. private func _initControllers() {
  79. //消息
  80. // let conversationVC = JCConversationListViewController()
  81. let conversationVC = IMConversationListViewController()
  82. conversationVC.title = "消息"
  83. let messages = ZLNavigationController(rootViewController: conversationVC)
  84. messages.tabBarItem = UITabBarItem(title: "消息", image: UIImage(named: "icon_news_nor"), selectedImage: O2ThemeManager.image(for: "Icon.icon_news_pre"))
  85. //通讯录
  86. let addressVC = OOTabBarHelper.getVC(storyboardName: "contacts", vcName: nil)
  87. let address = ZLNavigationController(rootViewController: addressVC)
  88. address.tabBarItem = UITabBarItem(title: "通讯录", image: UIImage(named: "icon_address_g"), selectedImage: O2ThemeManager.image(for: "Icon.icon_address_list_pro"))
  89. // main
  90. let mainVC = mainController()
  91. mainVC.tabBarItem = UITabBarItem(title: nil, image: UIImage(named: "icon_zhuye_nor"), selectedImage: O2ThemeManager.image(for: "Icon.icon_zhuye_pre"))
  92. mainVC.tabBarItem.imageInsets = UIEdgeInsets(top: 6, left: 0, bottom: -6, right: 0)
  93. let blurImage = OOCustomImageManager.default.loadImage(.index_bottom_menu_logo_blur)
  94. let newBlurImage = blurImage?.withRenderingMode(.alwaysOriginal)
  95. mainVC.tabBarItem.image = newBlurImage
  96. let focusImage = OOCustomImageManager.default.loadImage(.index_bottom_menu_logo_focus)
  97. let newFocusImage = focusImage?.withRenderingMode(.alwaysOriginal)
  98. mainVC.tabBarItem.selectedImage = newFocusImage
  99. //应用
  100. let appsVC = OOTabBarHelper.getVC(storyboardName: "apps", vcName: nil)
  101. let apps = ZLNavigationController(rootViewController: appsVC)
  102. apps.tabBarItem = UITabBarItem(title: "应用", image: UIImage(named: "icon_yingyong"), selectedImage: O2ThemeManager.image(for: "Icon.icon_yingyong_pro"))
  103. //设置
  104. let settingsVC = OOTabBarHelper.getVC(storyboardName: "setting", vcName: nil)
  105. let settings = ZLNavigationController(rootViewController: settingsVC)
  106. settings.tabBarItem = UITabBarItem(title: "设置", image: UIImage(named: "setting_normal"), selectedImage: O2ThemeManager.image(for: "Icon.setting_selected"))
  107. self.viewControllers = [messages, address, mainVC, apps, settings]
  108. }
  109. private func mainController() -> UIViewController {
  110. let appid = O2AuthSDK.shared.customStyle()?.indexPortal
  111. let indexType = O2AuthSDK.shared.customStyle()?.indexType ?? "default"
  112. if indexType == "portal" {
  113. let app = DBManager.shared.queryData(appid!)
  114. let destVC = OOTabBarHelper.getVC(storyboardName: "apps", vcName: "OOMainWebVC")
  115. if let mail = destVC as? MailViewController {
  116. mail.app = app
  117. mail.isIndexShow = true
  118. let nav = ZLNavigationController(rootViewController: mail)
  119. return nav
  120. } else {
  121. let nav = ZLNavigationController(rootViewController: destVC)
  122. return nav
  123. }
  124. } else {
  125. let destVC = OOTabBarHelper.getVC(storyboardName: "task", vcName: nil)
  126. let nav = ZLNavigationController(rootViewController: destVC)
  127. return nav
  128. }
  129. }
  130. private func _loginIM() {
  131. viewModel.registerIM().then { (result) in
  132. self.viewModel.loginIM().then({ (result) in
  133. Log.debug(message: "IM登陆完成")
  134. })
  135. }.catch { (imError) in
  136. let error = imError as! OOLoginError
  137. switch error {
  138. case .imRegisterFail(let myErr):
  139. Log.debug(message: myErr.errorDescription!)
  140. self.viewModel.loginIM().then({ (result) in
  141. Log.debug(message: "IM登陆完成")
  142. }).catch({ (loginError) in
  143. Log.error(message: "im Login Error \(loginError)")
  144. })
  145. break
  146. default:
  147. break
  148. }
  149. }
  150. }
  151. private func checkAppVersion() {
  152. O2VersionManager.shared.checkAppUpdate { (info, error) in
  153. if let iosInfo = info {
  154. DDLogDebug(iosInfo.toJSONString() ?? "")
  155. let alertController = UIAlertController(title: "版本更新", message: "更新内容:\(iosInfo.content ?? "")", preferredStyle: .alert)
  156. let okAction = UIAlertAction(title: "确定", style: .default, handler: { ok in
  157. O2VersionManager.shared.updateAppVersion(info?.downloadUrl)
  158. })
  159. let cancelAction = UIAlertAction(title: "取消", style: .cancel, handler: { c in
  160. //
  161. })
  162. alertController.addAction(cancelAction)
  163. alertController.addAction(okAction)
  164. UIApplication.shared.keyWindow?.rootViewController?.present(alertController, animated: true, completion: nil)
  165. } else {
  166. DDLogInfo("没有版本更新:\(error ?? "")")
  167. }
  168. }
  169. }
  170. // MARK: - websocket
  171. private var timer: Timer?
  172. private var isWsOpen = false
  173. private func _startWebsocket() {
  174. DDLogDebug("启动websocket连接。。。。。。")
  175. let url = AppDelegate.o2Collect.generateWebsocketURL()
  176. DDLogDebug("这个是wsurl :\(url)")
  177. O2WebsocketManager.instance.startConnect(wsUrl: url, delegate: self)
  178. }
  179. private func _stopWebsocket() {
  180. DDLogDebug("关闭websocket连接。。。。。。")
  181. self.stopTiming()
  182. O2WebsocketManager.instance.closeConnect()
  183. }
  184. private func startTiming() {
  185. DDLogDebug("开启定时器 。。。。。。")
  186. if timer != nil {
  187. timer?.invalidate()
  188. timer = nil
  189. }
  190. timer = Timer.scheduledTimer(timeInterval: 30, target: self, selector: #selector(sendHeartbeatMsg), userInfo: nil, repeats: true)
  191. timer?.fire()
  192. }
  193. private func stopTiming() {
  194. DDLogDebug("关闭定时器 。。。。。。")
  195. if timer != nil {
  196. timer?.invalidate()
  197. timer = nil
  198. }
  199. }
  200. //发送心跳
  201. @objc private func sendHeartbeatMsg() {
  202. if isWsOpen {
  203. O2WebsocketManager.instance.send(msg: o2_im_ws_heartbeat)
  204. } else { //重新启动
  205. _startWebsocket()
  206. }
  207. }
  208. }
  209. extension O2MainController: WebSocketDelegate {
  210. func didReceive(event: WebSocketEvent, client: WebSocket) {
  211. switch event {
  212. case .text(let text):
  213. if text != o2_im_ws_heartbeat { //忽略心跳消息
  214. DDLogDebug("接收的ws消息:\(text)")
  215. //判断type im消息就发送通知
  216. do {
  217. if let dicArr = try JSONSerialization.jsonObject(with: String(text).data(using: .utf8)!, options: .allowFragments) as? [String: AnyObject] {
  218. if let type = dicArr["type"] as? String, type == "im_create" {
  219. if let messageInfo = WsMessage.deserialize(from: text) {
  220. DDLogDebug("接收到im消息 发送通知。。")
  221. NotificationCenter.post(customeNotification: OONotification.websocket, object: messageInfo.body)
  222. }
  223. }
  224. }
  225. } catch { }
  226. }
  227. break
  228. case .connected(let headers):
  229. DDLogDebug("websocket is connected: \(headers)")
  230. isWsOpen = true
  231. self.startTiming()
  232. break
  233. case .disconnected(let reason, let code):
  234. DDLogDebug("websocket is disconnected: \(reason) with code: \(code)")
  235. isWsOpen = false
  236. break
  237. case .binary(let data):
  238. DDLogDebug("Received binary data: \(data.count)")
  239. break
  240. case .ping(_):
  241. break
  242. case .pong(_):
  243. break
  244. case .viablityChanged(_):
  245. DDLogDebug("websocket viablityChanged")
  246. break
  247. case .reconnectSuggested(_):
  248. DDLogDebug("websocket reconnectSuggested")
  249. break
  250. case .cancelled:
  251. DDLogDebug("websocket is canceled")
  252. isWsOpen = false
  253. break
  254. case .error(let error):
  255. DDLogError("websocket is error, \(String(describing: error?.localizedDescription))")
  256. isWsOpen = false
  257. break
  258. }
  259. }
  260. }