KMMemberCenterManager.swift 90 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867
  1. //
  2. // KMMemberCenterManager.swift
  3. // PDF Reader Pro
  4. //
  5. // Created by wanjun on 2024/10/21.
  6. //
  7. import Cocoa
  8. enum KMMemberCenterErrorCodeType: Int, CaseIterable {
  9. case UNKNOWN = 0 //未知
  10. case SUCCESS = 200 //正确
  11. case EXCEPTION_MSG_TOKEN_IS_INVALID = 304 // 无效的token或者token已过期
  12. case EXCEPTION_MSG_DEVICE_NUM_MAX = 305 // 您的登录设备已达上限,请退出其他设备重新登录
  13. case EXCEPTION_MSG_USER_NOT_LOGIN = 306 // 用户没有登录,请登录后再访问
  14. case EMAIL_VERIFY_CODE_KEY_ERROR = 309 // email code error!
  15. case EMAIL_REGISTER_ERROR = 310 // Register error!
  16. case EXCEPTION_MSG_PASSWORD_ERROR = 311 // 密码错误,您可以检查大小写状态
  17. case EXCEPTION_MSG_CODE_ACTION_ERROR = 312 // code action error
  18. case EXCEPTION_MSG_CODE_SEND_ERROR = 313 // code send error
  19. case EXCEPTION_MAIL_CODE_SEND_ERROR = 314 // mail send error
  20. case VERIFY_CODE_SEND_TOO_QUICKLY = 315 // code send too quickly
  21. case EXCEPTION_MSG_EMAIL_EXIST = 316 // 该邮箱已有账号,请前往登录
  22. case EXCEPTION_MSG_EMAIL_NOT_REGISTER = 317 // 当前账号未注册,点击下一步我们将为您注册账号
  23. case EXCEPTION_MSG_EMAIL_LOGOUT_ING = 318 // 注销中,无法登录,若有问题可联系客服
  24. case EXCEPTION_MSG_EMAIL_INVALID = 319 // 请输入正确的邮箱格式
  25. case EXCEPTION_MSG_PASSWORD_NOT_INCONSISTENT = 320 // 密码不一致,请重新输入
  26. case EXCEPTION_MSG_PASSWORD_SIZE_MIN = 321 // 密码请包含6~24个字符
  27. case EXCEPTION_MSG_PASSWORD_SIZE_MAX = 322 // 密码请包含6~24个字符
  28. case EXCEPTION_MSG_PLEASE_ADD_AUTH_CONFIG = 323 // please add auth config
  29. case EXCEPTION_MSG_USER_SUBSCRIPTION_IN_PROGRESS = 324 // 您目前还在订阅期内,暂时无法注销,请订阅期结束后再点击注销账号
  30. case EXCEPTION_TIME_TRANSFER_ERROR = 326 // 时间转换失败
  31. case EXCEPTION_MSG_PASSWORD_CONTAIN_EMPTY = 327 // 密码不能包含空格
  32. case EXCEPTION_MSG_CREATE_ORDER_PARAMETER = 328 // 支付方式异常
  33. case EXCEPTION_MSG_EVENT_IS_CURRENTLY_NOT_SUPPORTED = 329 // 当前事件暂不支持
  34. case EXCEPTION_MSG_THE_ACCOUNT_IS_ALREADY_LOGGED_IN_ON_OTHER_DEVICES = 330 // 账号已在其他设备登录
  35. case EXCEPTION_MSG_ABNORMAL_USER_STATUS = 331 // 当前邮箱已被停用或者处于注销中状态
  36. case EXCEPTION_MSG_APP_STORE_TICKET_VALIDATION_FAILED = 332 // Appstore票据验证失败"
  37. case EXCEPTION_MSG_APP_STORE_TICKET_VALIDATION_NEED_TO_RETRY = 333 //Appstore票据验证需要重试
  38. case EXCEPTION_MSG_REPEAT_SUBSCRIPTION = 334 // 用户已订阅该产品
  39. case EXCEPTION_MSG_RESTORING_PURCHASES_IS_NOT_CURRENTLY_SUPPORTED = 335 // 恢复购买暂不支持
  40. case EXCEPTION_MSG_USER_TRANSACTION_CANCELED_OR_FAILED = 336 // 用户交易取消或失败
  41. case EXCEPTION_MSG_CURRENT_ORDER_NOT_RECORDED = 337 // 当前订单末记录,请稍后重试
  42. case EXCEPTION_MSG_THE_SAME_USER = 338 //同一用户,无需处理
  43. case EXCEPTION_MSG_THIRD_PAY_ID_ILLEGAL = 339 //thirdPayld非法
  44. case EXCEPTION_MSG_ORDER_DOES_NOT_EXIST = 340 //订单不存在
  45. case EXCEPTION_MSG_THE_ORDER_STATUS_IS_ABNORMAL = 341 // 订单状态异常
  46. case EXCEPTION_MSG_TRANSACTION_ID_REPEAT = 342 // transactionld重复
  47. case EXCEPTION_TICKET_HAS_BEEN_BLOCKED = 343 // The ticket has been blocked
  48. case EXCEPTION_TICKET_HAS_BEEN_CREATED = 344 // 当前票据已创建订单
  49. case EXCEPTION_USER_IS_NOT_EDUCATION_USER = 345 // 用户不是教育用户
  50. case EXCEPTION_USER_HAS_EDUCATION = 346 // 用户近一年有教育购买订单
  51. case EXCEPTION_USER_CANNOT_BUY_PREMIUM = 347 // 用户已有标准版订阅,无法购买高级版
  52. case EXCEPTION_USER_CANNOT_BUY_VIP = 348 // 用户已有高级版订阅,无法购买标准版
  53. case EXCEPTION_USER_CANNOT_UPGRADE_VIP = 349 // 买断用户无法升级为标准版
  54. case EXCEPTION_COUPON_NOT_EXISTS = 350 // 优惠券不存在
  55. case EXCEPTION_COUPONTYPE_ERROR = 351 // 优惠券类型错误
  56. case EXCEPTION_COUPON_PRODUCT_ERROR = 352 // 优惠券关联产品错误
  57. case EXCEPTION_COUPON_INVALID = 353 // 优惠券已失效
  58. case EXCEPTION_PRODUCT_NOT_EXIST = 354 // 产品不存在
  59. case EXCEPTION_MSG_CONTACT_US = 355 //请联系我们获取最新折扣
  60. case EXCEPTION_MSG_APP_STORE_TRANSACTION_ID_VALIDATION_FAILED = 356 // 验证苹果交易失败
  61. case EXCEPTION_MSG_GOOGLE_STORE_TRANSACTION_ID_VALIDATION_FAILED = 357 // 验证谷歌交易失败
  62. case EXCEPTION_PRICE_ERROR = 358 // 价格错误
  63. case EXCEPTION_MSG_ORDER_CREATE_FAILED = 359 // 订单创建失败
  64. case USER_ALREADY_SUBSCRIBED_PLAN = 360 // 该用户已经是PDF Reader Pro订阅版会员,确定再赠送吗
  65. case USER_ALREADY_SUBSCRIBED_PACKAGE = 361 // 该用户已经是PDF Reader Pro永久版会员,无需再赠送哦
  66. case EXCEPTION_MSG_USER_NOT_EXIST = 400 //用户不存在
  67. case EXCEPTION_USER_ALREADY_LOTTERY = 364 // 用户已经抽过奖啦
  68. }
  69. @objc enum KMVerificationCodeType : Int {
  70. case login = 0 // 登录验证码
  71. case reset // 重置密码验证码
  72. case logout // 注销验证码
  73. }
  74. @objc enum KMBuyPlatformType : Int {
  75. case web = 0 // 官网
  76. case dmg // 重置密码验证码
  77. case macLite // Mac store免费版
  78. case exe
  79. case macPro // Mac store付费版
  80. case iOSLite // iOS免费版
  81. case iOSPro // iOS付费版
  82. case Android
  83. }
  84. typealias KMMemberCenterComplete = (_ success: Bool, _ result: KMMemberCenterResult?) -> Void
  85. typealias KMMemberProductComplete = (_ success: Bool, _ result: KMMemberProductResult?) -> Void
  86. typealias KMMemberRequestInfoComplete = (_ success: Bool, _ info: NSDictionary?) -> Void
  87. class KMMemberCenterManager: NSObject {
  88. static let manager = KMMemberCenterManager()
  89. private let configuration: KMMemberCenterConfig = KMMemberCenterConfig()
  90. // MARK: 判断有无网络
  91. func isConnectionAvailable() -> Bool {
  92. let reachability = Reachability(hostname: "www.apple.com")
  93. let state = reachability?.currentReachabilityStatus()
  94. if(state == NotReachable) {
  95. return false
  96. }
  97. return true
  98. }
  99. // MARK: 拼接URL(为Get类型)
  100. func constructURLString(baseURLString: String, parameters: [String: Any]) -> String? {
  101. // Ensure the base URL is valid
  102. guard var components = URLComponents(string: baseURLString) else {
  103. return nil
  104. }
  105. // Convert parameters to query items
  106. components.queryItems = parameters.map { key, value in
  107. URLQueryItem(name: key, value: "\(value)")
  108. }
  109. // Return the complete URL as a string
  110. return components.url?.absoluteString
  111. }
  112. // MARK: 登录模块
  113. /**
  114. @abstract 新会员系统重置密码
  115. @param email 邮箱
  116. @param verifyCode 验证码
  117. @param password 密码
  118. @param complete 回调
  119. */
  120. func resetPassword(email: String, verifyCode: String, password: String, _ complete: @escaping KMMemberCenterComplete) {
  121. let urlString = configuration.activityBaseURL() + "/member-system-sso/auth/memberResetPassword"
  122. // var escapedString = q
  123. // escapedString = String(data: escapedString.data(using: .utf8)!, encoding: .utf8)!
  124. let paraDict: [String: Any] = ["email": email,
  125. "verifyCode": verifyCode,
  126. "appId": "1",
  127. "password": password]
  128. let postData = try! JSONSerialization.data(withJSONObject: paraDict)
  129. var request = URLRequest(url: URL(string: urlString)!,timeoutInterval: Double.infinity)
  130. request.addValue("application/json", forHTTPHeaderField: "Content-Type")
  131. request.httpMethod = "POST"
  132. request.httpBody = postData
  133. let task = URLSession.shared.dataTask(with: request) { data, response, error in
  134. guard let data = data else {
  135. print(String(describing: error))
  136. return
  137. }
  138. let jsonObject = try? JSONSerialization.jsonObject(with: data, options: []) as? NSDictionary ?? [:]
  139. if jsonObject != nil {
  140. let code: Int = jsonObject!["code"] as? Int ?? 0
  141. let result_bool: Bool = jsonObject!["result"] as? Bool ?? false
  142. let message: String = jsonObject!["msg"] as? String ?? ""
  143. let result = KMMemberCenterResult(code: code, msg: message, result: result_bool)
  144. if code == 200 {
  145. complete(true, result)
  146. } else {
  147. complete(false, result)
  148. }
  149. } else {
  150. complete(false, KMMemberCenterResult(code: 0, msg: "unknown error", result: false))
  151. }
  152. }
  153. task.resume()
  154. // let urlString = configuration.activityBaseURL() + "/member-system-sso/auth/memberResetPassword"
  155. // let params: [String: Any] = ["email": email,
  156. // "verifyCode": verifyCode,
  157. // "appId": "1",
  158. // "password": password]
  159. // KMRequestServer.requestServer.request(urlString: urlString, method: .post, params: params) { requestSerializer in
  160. //
  161. // } completion: { [weak self] (task, responseObject, error) in
  162. // var dic: NSDictionary = [:]
  163. // if error == nil, let responseObject = responseObject as? NSDictionary {
  164. // dic = responseObject
  165. // } else {
  166. // var info = responseObject
  167. // if let error = error {
  168. // if let data = error.userInfo["com.alamofire.serialization.response.error.data"] as? Data {
  169. // info = try? JSONSerialization.jsonObject(with: data, options: .mutableLeaves) as? NSDictionary
  170. // }
  171. // }
  172. // dic = (info as? NSDictionary) ?? [:]
  173. // }
  174. //
  175. // let code: Int = dic["code"] as? Int ?? 0
  176. // let result_bool: Bool = dic["result"] as? Bool ?? false
  177. // let message: String = dic["msg"] as? String ?? ""
  178. //
  179. // let result = KMMemberCenterResult(code: code, msg: message, result: result_bool)
  180. //// let error = NSError(domain: message, code: code)
  181. // if code == 200 {
  182. // complete(true, result)
  183. // } else {
  184. // complete(false, result)
  185. // }
  186. // }
  187. }
  188. /**
  189. @abstract 验证邮箱(重置密码输入邮箱点击下一步时校验邮箱是否注册)
  190. @param email 邮箱
  191. @param complete 回调
  192. */
  193. func emailVerification(email: String, _ complete: @escaping KMMemberCenterComplete) {
  194. let urlString = String(format: "%@/member-system-sso/auth/validEmail?email=%@", configuration.activityBaseURL(), email)
  195. KMRequestServer.requestServer.request(urlString: urlString, method: .post, params: nil) { requestSerializer in
  196. } completion: { (task, responseObject, error) in
  197. var dic: NSDictionary = [:]
  198. if error == nil, let responseObject = responseObject as? NSDictionary {
  199. dic = responseObject
  200. } else {
  201. var info = responseObject
  202. if let error = error {
  203. if let data = error.userInfo["com.alamofire.serialization.response.error.data"] as? Data {
  204. info = try? JSONSerialization.jsonObject(with: data, options: .mutableLeaves) as? NSDictionary
  205. }
  206. }
  207. dic = (info as? NSDictionary) ?? [:]
  208. }
  209. let code: Int = dic["code"] as? Int ?? 0
  210. let result_bool: Bool = dic["result"] as? Bool ?? false
  211. let message: String = dic["msg"] as? String ?? ""
  212. let result = KMMemberCenterResult(code: code, msg: message, result: result_bool)
  213. if code == 200 {
  214. complete(true, result)
  215. } else {
  216. complete(false, result)
  217. }
  218. }
  219. }
  220. /**
  221. @abstract 获取邮箱验证码
  222. @param action 验证码用途
  223. @param receiver 邮箱号
  224. @param complete 回调
  225. */
  226. func getVerificationCode(action: KMVerificationCodeType, receiver: String, _ complete: @escaping KMMemberCenterComplete) {
  227. let urlString = configuration.activityBaseURL() + "/member-system-sso/auth/getVerifyCode"
  228. var actionType = "member_login"
  229. if action == .reset {
  230. actionType = "member_reset_password"
  231. } else if action == .logout {
  232. actionType = "member_log_off"
  233. }
  234. let params: [String: Any] = ["action": actionType,
  235. "type": 0,
  236. "receiver": receiver,
  237. "appId": "1"]
  238. KMRequestServer.requestServer.request(urlString: urlString, method: .get, params: params) { requestSerializer in
  239. } completion: { (task, responseObject, error) in
  240. var dic: NSDictionary = [:]
  241. if error == nil, let responseObject = responseObject as? NSDictionary {
  242. dic = responseObject
  243. } else {
  244. var info = responseObject
  245. if let error = error {
  246. if let data = error.userInfo["com.alamofire.serialization.response.error.data"] as? Data {
  247. info = try? JSONSerialization.jsonObject(with: data, options: .mutableLeaves) as? NSDictionary
  248. }
  249. }
  250. dic = (info as? NSDictionary) ?? [:]
  251. }
  252. let code: Int = dic["code"] as? Int ?? 0
  253. let result_bool: Bool = dic["result"] as? Bool ?? false
  254. let message: String = dic["msg"] as? String ?? ""
  255. let result = KMMemberCenterResult(code: code, msg: message, result: result_bool)
  256. if code == 200 {
  257. complete(true, result)
  258. } else {
  259. complete(false, result)
  260. }
  261. }
  262. }
  263. /**
  264. @abstract 实时检查邮件验证码
  265. @param type 验证码用途
  266. @param account 账户
  267. @param code 验证码
  268. @param complete 回调
  269. */
  270. func checkVerificationCode(type: KMVerificationCodeType, account: String, code: String, _ complete: @escaping KMMemberCenterComplete) {
  271. let urlString = configuration.activityBaseURL() + "/member-system-sso/auth/isEmailCodeValid"
  272. var actionType = "member_login"
  273. if type == .reset {
  274. actionType = "member_reset_password"
  275. } else if type == .logout {
  276. actionType = "user_log_off"
  277. }
  278. let params: [String: Any] = ["type": actionType,
  279. "account": account,
  280. "code": code,
  281. "appId": "1"]
  282. KMRequestServer.requestServer.request(urlString: urlString, method: .get, params: params) { requestSerializer in
  283. } completion: { [weak self] (task, responseObject, error) in
  284. var dic: NSDictionary = [:]
  285. if error == nil, let responseObject = responseObject as? NSDictionary {
  286. dic = responseObject
  287. } else {
  288. var info = responseObject
  289. if let error = error {
  290. if let data = error.userInfo["com.alamofire.serialization.response.error.data"] as? Data {
  291. info = try? JSONSerialization.jsonObject(with: data, options: .mutableLeaves) as? NSDictionary
  292. }
  293. }
  294. dic = (info as? NSDictionary) ?? [:]
  295. }
  296. let code: Int = dic["code"] as? Int ?? 0
  297. let result_bool: Bool = dic["result"] as? Bool ?? false
  298. let message: String = dic["msg"] as? String ?? ""
  299. let result = KMMemberCenterResult(code: code, msg: message, result: result_bool)
  300. if code == 200 {
  301. complete(true, result)
  302. } else {
  303. complete(false, result)
  304. }
  305. }
  306. }
  307. /**
  308. @abstract 邮箱验证码登录 & 密码登录
  309. @param email 邮箱
  310. @param code 验证码/密码
  311. @param type 密码类型(验证码?密码?)
  312. @param complete 回调
  313. */
  314. func emailLogin(email: String, code: String, type: KMSignUpState, _ complete: @escaping KMMemberCenterComplete) {
  315. let urlString = configuration.activityBaseURL() + "/member-system-sso/auth/memberLogin"
  316. let uuid: String = GetHardwareUUID() ?? ""
  317. var params: [String: Any] = [:]
  318. if type == .verificationCode {
  319. params = ["email": email,
  320. "code": code,
  321. "appId": "1",
  322. "deviceSign": uuid,
  323. "deviceName": NSFullUserName(),
  324. "model": "mac"]
  325. } else {
  326. params = ["email": email,
  327. "password": code,
  328. "appId": "1",
  329. "deviceSign": uuid,
  330. "deviceName": NSFullUserName(),
  331. "model": "mac"]
  332. }
  333. KMRequestServer.requestServer.request(urlString: urlString, method: .post, params: params) { requestSerializer in
  334. // requestSerializer.setValue("Apifox/1.0.0 (https://www.apifox.cn)", forHTTPHeaderField: "User-Agent")
  335. } completion: { [weak self] (task, responseObject, error) in
  336. var dic: NSDictionary = [:]
  337. if error == nil, let responseObject = responseObject as? NSDictionary {
  338. dic = responseObject
  339. } else {
  340. var info = responseObject
  341. if let error = error {
  342. if let data = error.userInfo["com.alamofire.serialization.response.error.data"] as? Data {
  343. info = try? JSONSerialization.jsonObject(with: data, options: .mutableLeaves) as? NSDictionary
  344. }
  345. }
  346. dic = (info as? NSDictionary) ?? [:]
  347. }
  348. let code: Int = dic["code"] as? Int ?? 0
  349. let result_dict: NSDictionary = dic["result"] as? NSDictionary ?? [:]
  350. let message: String = dic["msg"] as? String ?? ""
  351. var refresh_token = ""
  352. var access_token = ""
  353. var token_type = ""
  354. var expires_in = ""
  355. var scope = ""
  356. if let token = result_dict["refresh_token"] { refresh_token = token as! String }
  357. if let token = result_dict["access_token"] { access_token = token as! String }
  358. if let token = result_dict["token_type"] { token_type = token as! String }
  359. if let token = result_dict["expires_in"] { expires_in = token as! String }
  360. let loginResult = KMMemberLoginResult(refreshToken: refresh_token, accessToken: access_token, tokenType: token_type, expiresIn: expires_in)
  361. let result = KMMemberCenterResult(loginResult: loginResult)
  362. result.code = code
  363. result.msg = message
  364. // let error = NSError(domain: message, code: code)
  365. if code == 200 {
  366. complete(true, result)
  367. } else {
  368. complete(false, result)
  369. }
  370. }
  371. }
  372. /**
  373. @abstract 获取用户登录设备列表
  374. @param email 邮箱
  375. @param complete 回调
  376. */
  377. func getUserDeviceList(email: String, _ complete: @escaping KMMemberCenterComplete) {
  378. let urlString = configuration.activityBaseURL() + "/member-system-sso/auth/getLoginDeviceList?email=\(email)&appId=1"
  379. KMRequestServer.requestServer.request(urlString: urlString, method: .post, params: [:]) { requestSerializer in
  380. } completion: { [weak self] (task, responseObject, error) in
  381. var dic: NSDictionary = [:]
  382. if error == nil, let responseObject = responseObject as? NSDictionary {
  383. dic = responseObject
  384. } else {
  385. var info = responseObject
  386. if let error = error {
  387. if let data = error.userInfo["com.alamofire.serialization.response.error.data"] as? Data {
  388. info = try? JSONSerialization.jsonObject(with: data, options: .mutableLeaves) as? NSDictionary
  389. }
  390. }
  391. dic = (info as? NSDictionary) ?? [:]
  392. }
  393. let code: Int = dic["code"] as? Int ?? 0
  394. let result_dict: Dictionary = dic["result"] as? Dictionary ?? [:]
  395. let message: String = dic["msg"] as? String ?? ""
  396. let deviceList: [Dictionary] = result_dict["deviceList"] as? [Dictionary] ?? [[:]]
  397. var deviceLists: [KMMemberDeviceList] = []
  398. for dict in deviceList {
  399. var device_id = ""
  400. var productId = ""
  401. var uniqueSn = ""
  402. var deviceName = ""
  403. var id = ""
  404. var model = ""
  405. if let token = dict["device_id"] {
  406. device_id = token as? String ?? ""
  407. }
  408. if let token = dict["productId"] {
  409. productId = token as? String ?? ""
  410. }
  411. if let token = dict["uniqueSn"] {
  412. uniqueSn = token as? String ?? ""
  413. }
  414. if let token = dict["deviceName"] {
  415. deviceName = token as? String ?? ""
  416. }
  417. if let token = dict["model"] {
  418. model = token as? String ?? ""
  419. }
  420. if let token = dict["id"] {
  421. id = token as? String ?? ""
  422. }
  423. let list = KMMemberDeviceList(deviceId: device_id, productId: productId, uniqueSn: uniqueSn, appId: "", device_model:model, deviceName: deviceName)
  424. list.id = id
  425. deviceLists.append(list)
  426. }
  427. var maxDeviceNum = 0
  428. if let token = result_dict["maxDeviceNum"] {
  429. maxDeviceNum = token as! Int
  430. }
  431. let result = KMMemberCenterResult(deviceListResult: deviceLists, maxDeviceNum: maxDeviceNum)
  432. if code == 200 {
  433. complete(true, result)
  434. } else {
  435. complete(false, result)
  436. }
  437. }
  438. }
  439. /**
  440. @abstract 登出用户的指定设备
  441. @param deviceId 设备记录ID
  442. @param complete 回调
  443. */
  444. func logoutDevice(deviceId: String, complete: @escaping KMMemberCenterComplete) {
  445. let urlString = configuration.activityBaseURL() + "/member-system-sso/auth/logoutDevice?deviceId=\(deviceId)"
  446. KMRequestServer.requestServer.request(urlString: urlString, method: .post, params: [:]) { requestSerializer in
  447. } completion: { [weak self] (task, responseObject, error) in
  448. var dic: NSDictionary = [:]
  449. if error == nil, let responseObject = responseObject as? NSDictionary {
  450. dic = responseObject
  451. } else {
  452. var info = responseObject
  453. if let error = error {
  454. if let data = error.userInfo["com.alamofire.serialization.response.error.data"] as? Data {
  455. info = try? JSONSerialization.jsonObject(with: data, options: .mutableLeaves) as? NSDictionary
  456. }
  457. }
  458. dic = (info as? NSDictionary) ?? [:]
  459. }
  460. let code: Int = dic["code"] as? Int ?? 0
  461. let resultStr: String = dic["result"] as? String ?? ""
  462. let message: String = dic["msg"] as? String ?? ""
  463. let result = KMMemberCenterResult(code: code, msg: message, resultStr: resultStr)
  464. if code == 200 {
  465. complete(true, result)
  466. } else {
  467. complete(false, result)
  468. }
  469. }
  470. }
  471. // MARK: 个人信息模块
  472. /**
  473. @abstract 获取老带新已邀请人数
  474. @param complete 回调
  475. */
  476. func getInviteNum(_ complete: @escaping KMMemberCenterComplete) {
  477. let token: String = KMMemberInfo.shared.access_token
  478. if token == "" {
  479. complete(false, nil)
  480. return
  481. }
  482. let urlString = configuration.activityBaseURL() + "/member-system-sso/user/getInviteNum"
  483. KMRequestServer.requestServer.request(urlString: urlString, method: .post, params: nil) { requestSerializer in
  484. requestSerializer.setValue("Bearer " + token, forHTTPHeaderField: "Authorization")
  485. } completion: { [weak self] (task, responseObject, error) in
  486. var dic: NSDictionary = [:]
  487. if error == nil, let responseObject = responseObject as? NSDictionary {
  488. dic = responseObject
  489. } else {
  490. var info = responseObject
  491. if let error = error {
  492. if let data = error.userInfo["com.alamofire.serialization.response.error.data"] as? Data {
  493. info = try? JSONSerialization.jsonObject(with: data, options: .mutableLeaves) as? NSDictionary
  494. }
  495. }
  496. dic = (info as? NSDictionary) ?? [:]
  497. }
  498. let code: Int = dic["code"] as? Int ?? 0
  499. let resultInt: Int = dic["result"] as? Int ?? 0
  500. let message: String = dic["msg"] as? String ?? ""
  501. let result = KMMemberCenterResult(code: code, msg: message, resultInt: resultInt)
  502. if code == 200 {
  503. complete(true, result)
  504. } else {
  505. complete(false, result)
  506. }
  507. }
  508. }
  509. /**
  510. @abstract 获取用户个人信息
  511. @param complete 回调
  512. */
  513. func userInfo(_ complete: @escaping KMMemberCenterComplete) {
  514. let token: String = KMMemberInfo.shared.access_token
  515. if token == "" {
  516. complete(false, nil)
  517. return
  518. }
  519. let urlString = configuration.activityBaseURL() + "/member-system-sso/user/info"
  520. KMRequestServer.requestServer.request(urlString: urlString, method: .get, params: nil) { requestSerializer in
  521. requestSerializer.setValue("Bearer " + token, forHTTPHeaderField: "Authorization")
  522. } completion: { [weak self] (task, responseObject, error) in
  523. var dic: NSDictionary = [:]
  524. if error == nil, let responseObject = responseObject as? NSDictionary {
  525. dic = responseObject
  526. } else {
  527. var info = responseObject
  528. if let error = error {
  529. if let data = error.userInfo["com.alamofire.serialization.response.error.data"] as? Data {
  530. info = try? JSONSerialization.jsonObject(with: data, options: .mutableLeaves) as? NSDictionary
  531. }
  532. }
  533. dic = (info as? NSDictionary) ?? [:]
  534. }
  535. let code: Int = dic["code"] as? Int ?? 0
  536. let result_dict: NSDictionary = dic["result"] as? NSDictionary ?? [:]
  537. let message: String = dic["msg"] as? String ?? ""
  538. var userId = ""
  539. var email = ""
  540. var fullName = ""
  541. var activeVIP = KMMemberUserInfo()
  542. var aiPoint = 0
  543. var validFlag = ""
  544. var isHaveAIDiscount = ""
  545. var canTrail = ""
  546. if let token = result_dict["id"] { userId = token as! String }
  547. if let token = result_dict["email"] { email = token as! String }
  548. if let token = result_dict["fullName"] { fullName = token as! String }
  549. let activeVIP_dict: [String : Any] = result_dict["activeVIP"] as? [String : Any] ?? [:]
  550. let userInfoActiveVIP = KMMemberUserInfoActiveVIP(dict: activeVIP_dict)
  551. if let token = activeVIP_dict["endDate"] as? String {
  552. // 创建一个日期格式化器
  553. let dateFormatter = DateFormatter()
  554. dateFormatter.dateFormat = "yyyy-MM-dd HH:mm:ss"
  555. // 将字符串转换为日期对象
  556. if let date = dateFormatter.date(from: token) {
  557. // 创建一个新的日期格式化器,用于只显示天
  558. let dayFormatter = DateFormatter()
  559. dayFormatter.dateFormat = "yyyy-MM-dd" // 只保留年月日部分
  560. userInfoActiveVIP.endDate = dayFormatter.string(from: date)
  561. }
  562. }
  563. let activeAI_dict: [String : Any] = result_dict["activeAI"] as? [String : Any] ?? [:]
  564. let userInfoActiveAI = KMMemberUserInfoActiveVIP(dict: activeAI_dict)
  565. if let token = result_dict["aiPoint"] { aiPoint = token as! Int }
  566. if let token = result_dict["validFlag"] { validFlag = token as! String }
  567. if let token = result_dict["isHaveAIDiscount"] { isHaveAIDiscount = token as! String }
  568. if let token = result_dict["canTrail"] { canTrail = token as! String }
  569. let userInfo = KMMemberUserInfo(id: userId, email: email, fullName: fullName, activeVIP: [userInfoActiveVIP], activeAI: [userInfoActiveAI], aiPoint: aiPoint, validFlag: validFlag, isHaveAIDiscount: isHaveAIDiscount, canTrail: canTrail)
  570. if let data = result_dict["avatarUrl"] as? String {
  571. userInfo.avatarUrl = data
  572. }
  573. if let data = result_dict["isFreeAccount"] as? String {
  574. userInfo.isFreeAccount = data
  575. }
  576. let result = KMMemberCenterResult(code: code, msg: message, userInfo: userInfo)
  577. if code == 200 {
  578. complete(true, result)
  579. } else {
  580. complete(false, result)
  581. }
  582. }
  583. }
  584. /**
  585. @abstract 退出登录
  586. @param complete 回调
  587. */
  588. func userLogout(_ complete: @escaping KMMemberCenterComplete) {
  589. let token: String = KMMemberInfo.shared.access_token
  590. if token == "" {
  591. complete(false, nil)
  592. return
  593. }
  594. let uuid: String = GetHardwareUUID() ?? ""
  595. let urlString = String(format: "%@/member-system-sso/user/logout?deviceSign=%@&appId=1", configuration.activityBaseURL(),uuid)
  596. KMRequestServer.requestServer.request(urlString: urlString, method: .post, params: nil) { requestSerializer in
  597. requestSerializer.setValue("Bearer " + token, forHTTPHeaderField: "Authorization")
  598. } completion: { [weak self] (task, responseObject, error) in
  599. var dic: NSDictionary = [:]
  600. if error == nil, let responseObject = responseObject as? NSDictionary {
  601. dic = responseObject
  602. } else {
  603. var info = responseObject
  604. if let error = error {
  605. if let data = error.userInfo["com.alamofire.serialization.response.error.data"] as? Data {
  606. info = try? JSONSerialization.jsonObject(with: data, options: .mutableLeaves) as? NSDictionary
  607. }
  608. }
  609. dic = (info as? NSDictionary) ?? [:]
  610. }
  611. let code: Int = dic["code"] as? Int ?? 0
  612. let result_bool: Bool = dic["result"] as? Bool ?? false
  613. let message: String = dic["msg"] as? String ?? ""
  614. let result = KMMemberCenterResult(code: code, msg: message, result: result_bool)
  615. if code == 200 {
  616. complete(true, result)
  617. } else {
  618. complete(false, result)
  619. }
  620. }
  621. }
  622. /**
  623. @abstract 获取用户当前会员情况
  624. @param complete 回调
  625. */
  626. func userRightList(_ complete: @escaping KMMemberCenterComplete) {
  627. let token: String = KMMemberInfo.shared.access_token
  628. if token == "" {
  629. complete(false, nil)
  630. return
  631. }
  632. let urlString = configuration.activityBaseURL() + "/member-system-sso//user/rightList"
  633. KMRequestServer.requestServer.request(urlString: urlString, method: .get, params: nil) { requestSerializer in
  634. requestSerializer.setValue("Bearer " + token, forHTTPHeaderField: "Authorization")
  635. } completion: { [weak self] (task, responseObject, error) in
  636. var dic: NSDictionary = [:]
  637. if error == nil, let responseObject = responseObject as? NSDictionary {
  638. dic = responseObject
  639. } else {
  640. var info = responseObject
  641. if let error = error {
  642. if let data = error.userInfo["com.alamofire.serialization.response.error.data"] as? Data {
  643. info = try? JSONSerialization.jsonObject(with: data, options: .mutableLeaves) as? NSDictionary
  644. }
  645. }
  646. dic = (info as? NSDictionary) ?? [:]
  647. }
  648. let code: Int = dic["code"] as? Int ?? 0
  649. let result_Array: [NSDictionary] = dic["result"] as? [NSDictionary] ?? [[:]]
  650. let message: String = dic["msg"] as? String ?? ""
  651. var results: [KMMemberUserInfoActiveVIP] = []
  652. for dict1 in result_Array {
  653. let userInfoActiveVIP = KMMemberUserInfoActiveVIP(dict: dict1 as? [String : Any] ?? [:])
  654. results.append(userInfoActiveVIP)
  655. }
  656. let result = KMMemberCenterResult(code: code, msg: message, activeVIPs: results)
  657. if code == 200 {
  658. complete(true, result)
  659. } else {
  660. complete(false, result)
  661. }
  662. }
  663. }
  664. /**
  665. @abstract 用户手动注销
  666. @param code 邮箱验证码
  667. @param complete 回调
  668. */
  669. func userLogOffForUser(code: String, _ complete: @escaping KMMemberCenterComplete) {
  670. let token: String = KMMemberInfo.shared.access_token
  671. if token == "" {
  672. complete(false, nil)
  673. return
  674. }
  675. let urlString = String(format: "%@/member-system-sso/user/logOffForUser?code=%@&appId=1", configuration.activityBaseURL(), code)
  676. KMRequestServer.requestServer.request(urlString: urlString, method: .post, params: nil) { requestSerializer in
  677. requestSerializer.setValue("Bearer " + token, forHTTPHeaderField: "Authorization")
  678. } completion: { [weak self] (task, responseObject, error) in
  679. var dic: NSDictionary = [:]
  680. if error == nil, let responseObject = responseObject as? NSDictionary {
  681. dic = responseObject
  682. } else {
  683. var info = responseObject
  684. if let error = error {
  685. if let data = error.userInfo["com.alamofire.serialization.response.error.data"] as? Data {
  686. info = try? JSONSerialization.jsonObject(with: data, options: .mutableLeaves) as? NSDictionary
  687. }
  688. }
  689. dic = (info as? NSDictionary) ?? [:]
  690. }
  691. let code: Int = dic["code"] as? Int ?? 0
  692. let message: String = dic["msg"] as? String ?? ""
  693. let result_dict: NSDictionary = dic["result"] as? NSDictionary ?? [:]
  694. var currentTime = ""
  695. var logOffTime = ""
  696. if let token = result_dict["currentTime"] { currentTime = token as! String }
  697. if let token = result_dict["logOffTime"] { logOffTime = token as! String }
  698. let logOff = KMMemberLogOff(currentTime: currentTime, logOffTime: logOffTime)
  699. let result = KMMemberCenterResult(code: code, msg: message, logOff: logOff)
  700. if code == 200 {
  701. complete(true, result)
  702. } else {
  703. complete(false, result)
  704. }
  705. }
  706. }
  707. /**
  708. @abstract 撤销注销申请
  709. @param complete 回调
  710. */
  711. func userRevokeCancel(_ complete: @escaping KMMemberCenterComplete) {
  712. let token: String = KMMemberInfo.shared.access_token
  713. if token == "" {
  714. complete(false, nil)
  715. return
  716. }
  717. let urlString = configuration.activityBaseURL() + "/member-system-sso/user/revokeCancel"
  718. KMRequestServer.requestServer.request(urlString: urlString, method: .post, params: nil) { requestSerializer in
  719. requestSerializer.setValue("Bearer " + token, forHTTPHeaderField: "Authorization")
  720. } completion: { [weak self] (task, responseObject, error) in
  721. var dic: NSDictionary = [:]
  722. if error == nil, let responseObject = responseObject as? NSDictionary {
  723. dic = responseObject
  724. } else {
  725. var info = responseObject
  726. if let error = error {
  727. if let data = error.userInfo["com.alamofire.serialization.response.error.data"] as? Data {
  728. info = try? JSONSerialization.jsonObject(with: data, options: .mutableLeaves) as? NSDictionary
  729. }
  730. }
  731. dic = (info as? NSDictionary) ?? [:]
  732. }
  733. let code: Int = dic["code"] as? Int ?? 0
  734. let message: String = dic["msg"] as? String ?? ""
  735. let result_Bool: Bool = dic["result"] as? Bool ?? false
  736. let result = KMMemberCenterResult(code: code, msg: message, result: result_Bool)
  737. if code == 200 {
  738. complete(true, result)
  739. } else {
  740. complete(false, result)
  741. }
  742. }
  743. }
  744. // MARK: 商品模块
  745. /**
  746. @abstract 获取上架中的产品
  747. @param isEducation 是否教育优惠
  748. @param complete 回调
  749. */
  750. func getListingProducts(isEducation: Int, discountCode: String, _ complete: @escaping KMMemberProductComplete) {
  751. let urlString = configuration.activityBaseURL() + "/pdf-office-website/web/getListingProducts"
  752. var platformId = "2"
  753. #if VERSION_FREE
  754. #if VERSION_DMG
  755. // DMG
  756. platformId = "2"
  757. #else
  758. // AppStore 免费版本
  759. #endif
  760. #else
  761. // AppStore 付费版
  762. platformId = "5"
  763. #endif
  764. let params: [String: Any] = ["isEducation": NSNumber(value: Int32(isEducation)),
  765. "platformId": platformId,
  766. "code" : discountCode]
  767. if let urlNewString = constructURLString(baseURLString: urlString, parameters: params) {
  768. KMRequestServer.requestServer.request(urlString: urlNewString, method: .get, params: nil) { requestSerializer in
  769. } completion: { [weak self] (task, responseObject, error) in
  770. var dic: NSDictionary = [:]
  771. if error == nil, let responseObject = responseObject as? NSDictionary {
  772. dic = responseObject
  773. } else {
  774. var info = responseObject
  775. if let error = error {
  776. if let data = error.userInfo["com.alamofire.serialization.response.error.data"] as? Data {
  777. info = try? JSONSerialization.jsonObject(with: data, options: .mutableLeaves) as? NSDictionary
  778. }
  779. }
  780. dic = (info as? NSDictionary) ?? [:]
  781. }
  782. let requestCode: Int = dic["code"] as? Int ?? 0
  783. let result_Array: [NSDictionary] = dic["result"] as? [NSDictionary] ?? [[:]]
  784. let message: String = dic["msg"] as? String ?? ""
  785. var results: [KMListingProductsModel] = []
  786. for dict1 in result_Array {
  787. var id = ""
  788. var productName = ""
  789. var maxDeviceNum = 0
  790. var levels = ""
  791. var platforms = ""
  792. var productLineId = 0
  793. var paymentModel = 0
  794. var cycle = 0
  795. var code = ""
  796. var price = NSNumber(value: 0.0)
  797. var displayPrice = NSNumber(value: 0.0)
  798. var upgradePrice = NSNumber(value: 0.0)
  799. var cnyPrice = NSNumber(value: 0.0)
  800. var displayCnyPrice = NSNumber(value: 0.0)
  801. var priceString:String?
  802. var displayPriceString:String?
  803. var upgradePriceString:String?
  804. var cnyPriceString:String?
  805. var displayCnyPriceString:String?
  806. var upgradecnyPriceString:String?
  807. if let token = dict1["id"] { id = token as? String ?? id }
  808. if let token = dict1["productName"] { productName = token as? String ?? productName }
  809. if let token = dict1["maxDeviceNum"] { maxDeviceNum = token as? Int ?? maxDeviceNum }
  810. if let token = dict1["levels"] { levels = token as? String ?? levels }
  811. if let token = dict1["platforms"] { platforms = token as? String ?? platforms }
  812. if let token = dict1["productLineId"] { productLineId = token as? Int ?? productLineId }
  813. if let token = dict1["paymentModel"] { paymentModel = token as? Int ?? paymentModel }
  814. if let token = dict1["cycle"] { cycle = token as? Int ?? cycle }
  815. if let token = dict1["code"] { code = token as? String ?? code }
  816. if let token = dict1["price"] as? NSNumber {
  817. let string = KMFormatNSNumber(token, to: 2)
  818. priceString = string
  819. price = token
  820. }
  821. if let token = dict1["displayPrice"] as? NSNumber {
  822. let string = KMFormatNSNumber(token, to: 2)
  823. displayPriceString = string
  824. displayPrice = token
  825. }
  826. if let token = dict1["cnyUpgradePrice"] as? NSNumber {
  827. let string = KMFormatNSNumber(token, to: 2)
  828. upgradecnyPriceString = string
  829. }
  830. if let token = dict1["upgradePrice"] as? NSNumber {
  831. let string = KMFormatNSNumber(token, to: 2)
  832. upgradePriceString = string
  833. upgradePrice = token
  834. }
  835. if let token = dict1["cnyPrice"] as? NSNumber {
  836. let string = KMFormatNSNumber(token, to: 2)
  837. cnyPriceString = string
  838. cnyPrice = token
  839. }
  840. if let token = dict1["cnyDisplayPrice"] as? NSNumber {
  841. let string = KMFormatNSNumber(token, to: 2)
  842. displayCnyPriceString = string
  843. displayCnyPrice = token
  844. }
  845. let products = KMListingProductsModel(id: id, productName: productName, price: priceString, maxDeviceNum: maxDeviceNum, displayPrice: displayPriceString, levels: levels, platforms: platforms, productLineId: productLineId, paymentModel: paymentModel, cycle: cycle, cnyPrice: cnyPriceString, displayCnyPrice: displayCnyPriceString, upgradePrice: upgradePriceString, code: code)
  846. products.individualPriceString = priceString
  847. products.individualCnyPriceString = cnyPriceString
  848. products.cnyUpgradePriceString = upgradecnyPriceString
  849. if let data = dict1["displayAmount"] as? NSNumber {
  850. let string = KMFormatNSNumber(data, to: 2)
  851. products.displayAmount = string
  852. }
  853. if let data = dict1["cnyDisplayAmount"] as? NSNumber {
  854. let string = KMFormatNSNumber(data, to: 2)
  855. products.cnyDisplayAmount = string
  856. }
  857. results.append(products)
  858. }
  859. let result = KMMemberProductResult(code: requestCode, msg: message, listingProducts: results)
  860. if requestCode == 200 {
  861. complete(true, result)
  862. } else {
  863. complete(false, result)
  864. }
  865. }
  866. } else {
  867. print("Invalid URL")
  868. complete(false, nil)
  869. }
  870. }
  871. /**
  872. @abstract 获取已登录用户购买商品价格
  873. @param productId 购买的产品id
  874. @param isEducation 是否教育优惠
  875. @param complete 回调
  876. */
  877. func getProductPriceForBuy(productId: String, isEducation: Int, userId: String, _ complete: @escaping KMMemberProductComplete) {
  878. let urlString = configuration.activityBaseURL() + "/pdf-office-website/web/getProductPriceForBuy"
  879. let params: [String: Any] = ["productId": productId,
  880. "isEducation": isEducation,
  881. "userId": userId]
  882. if let urlNewString = constructURLString(baseURLString: urlString, parameters: params) {
  883. KMRequestServer.requestServer.request(urlString: urlNewString, method: .get, params: nil) { requestSerializer in
  884. } completion: { [weak self] (task, responseObject, error) in
  885. var dic: NSDictionary = [:]
  886. if error == nil, let responseObject = responseObject as? NSDictionary {
  887. dic = responseObject
  888. } else {
  889. var info = responseObject
  890. if let error = error {
  891. if let data = error.userInfo["com.alamofire.serialization.response.error.data"] as? Data {
  892. info = try? JSONSerialization.jsonObject(with: data, options: .mutableLeaves) as? NSDictionary
  893. }
  894. }
  895. dic = (info as? NSDictionary) ?? [:]
  896. }
  897. let requestCode: Int = dic["code"] as? Int ?? 0
  898. let result_Array: [NSDictionary] = [dic["result"]] as? [NSDictionary] ?? [[:]]
  899. let message: String = dic["msg"] as? String ?? ""
  900. var results: [KMListingProductsModel] = []
  901. for dict1 in result_Array {
  902. var id = ""
  903. var productName = ""
  904. var maxDeviceNum = 0
  905. var levels = ""
  906. var platforms = ""
  907. var productLineId = 0
  908. var paymentModel = 0
  909. var cycle = 0
  910. var code = ""
  911. var price = NSNumber(value: 0.0)
  912. var displayPrice = NSNumber(value: 0.0)
  913. var upgradePrice = NSNumber(value: 0.0)
  914. var cnyPrice = NSNumber(value: 0.0)
  915. var displayCnyPrice = NSNumber(value: 0.0)
  916. var priceString:String?
  917. var displayPriceString:String?
  918. var upgradePriceString:String?
  919. var cnyPriceString:String?
  920. var displayCnyPriceString:String?
  921. var upgradecnyPriceString:String?
  922. if let token = dict1["id"] { id = token as? String ?? id }
  923. if let token = dict1["productName"] { productName = token as? String ?? productName }
  924. if let token = dict1["maxDeviceNum"] { maxDeviceNum = token as? Int ?? maxDeviceNum }
  925. if let token = dict1["levels"] { levels = token as? String ?? levels }
  926. if let token = dict1["platforms"] { platforms = token as? String ?? platforms }
  927. if let token = dict1["productLineId"] { productLineId = token as? Int ?? productLineId }
  928. if let token = dict1["paymentModel"] { paymentModel = token as? Int ?? paymentModel }
  929. if let token = dict1["cycle"] { cycle = token as? Int ?? cycle }
  930. if let token = dict1["code"] { code = token as? String ?? code }
  931. if let token = dict1["price"] as? NSNumber {
  932. let string = KMFormatNSNumber(token, to: 2)
  933. priceString = string
  934. price = token
  935. }
  936. if let token = dict1["displayPrice"] as? NSNumber {
  937. let string = KMFormatNSNumber(token, to: 2)
  938. displayPriceString = string
  939. displayPrice = token
  940. }
  941. if let token = dict1["upgradePrice"] as? NSNumber {
  942. let string = KMFormatNSNumber(token, to: 2)
  943. upgradePriceString = string
  944. upgradePrice = token
  945. }
  946. if let token = dict1["cnyPrice"] as? NSNumber {
  947. let string = KMFormatNSNumber(token, to: 2)
  948. cnyPriceString = string
  949. cnyPrice = token
  950. }
  951. if let token = dict1["cnyDisplayPrice"] as? NSNumber {
  952. let string = KMFormatNSNumber(token, to: 2)
  953. displayCnyPriceString = string
  954. displayCnyPrice = token
  955. }
  956. if let token = dict1["cnyUpgradePrice"] as? NSNumber {
  957. let string = KMFormatNSNumber(token, to: 2)
  958. upgradecnyPriceString = string
  959. }
  960. let products = KMListingProductsModel(id: id, productName: productName, price: priceString, maxDeviceNum: maxDeviceNum, displayPrice: displayPriceString, levels: levels, platforms: platforms, productLineId: productLineId, paymentModel: paymentModel, cycle: cycle, cnyPrice: cnyPriceString, displayCnyPrice: displayCnyPriceString, upgradePrice: upgradePriceString, code: code)
  961. products.cnyUpgradePriceString = upgradecnyPriceString
  962. products.individualPriceString = priceString
  963. products.individualCnyPriceString = cnyPriceString
  964. results.append(products)
  965. }
  966. let result = KMMemberProductResult(code: requestCode, msg: message, listingProducts: results)
  967. if requestCode == 200 {
  968. complete(true, result)
  969. } else {
  970. complete(false, result)
  971. }
  972. }
  973. } else {
  974. print("Invalid URL")
  975. complete(false, nil)
  976. }
  977. }
  978. /**
  979. @abstract 获取批量阶段购买价格
  980. @param productId 购买的产品id
  981. @param num 批量个数
  982. @param complete 回调
  983. */
  984. func getBatchProductPrice(productId: String, num: Int, _ complete: @escaping KMMemberProductComplete) {
  985. let urlString = configuration.activityBaseURL() + "/pdf-office-website/web/getBatchProductPrice"
  986. let params: [String: Any] = ["productId": productId,
  987. "num": NSNumber(value: Int32(num))]
  988. if let urlNewString = constructURLString(baseURLString: urlString, parameters: params) {
  989. KMRequestServer.requestServer.request(urlString: urlNewString, method: .get, params: nil) { requestSerializer in
  990. } completion: { [weak self] (task, responseObject, error) in
  991. var dic: NSDictionary = [:]
  992. if error == nil, let responseObject = responseObject as? NSDictionary {
  993. dic = responseObject
  994. } else {
  995. var info = responseObject
  996. if let error = error {
  997. if let data = error.userInfo["com.alamofire.serialization.response.error.data"] as? Data {
  998. info = try? JSONSerialization.jsonObject(with: data, options: .mutableLeaves) as? NSDictionary
  999. }
  1000. }
  1001. dic = (info as? NSDictionary) ?? [:]
  1002. }
  1003. let requestCode: Int = dic["code"] as? Int ?? 0
  1004. let result: NSDictionary = dic["result"] as? NSDictionary ?? [:]
  1005. let message: String = dic["msg"] as? String ?? ""
  1006. var productId = ""
  1007. var totalPrice = ""
  1008. var price = ""
  1009. var batchPrice = ""
  1010. var cnyPrice = ""
  1011. var cnyBatchPrice = ""
  1012. var cnyTotalPrice = ""
  1013. if let token = result["productId"] { productId = token as? String ?? productId}
  1014. if let token = result["totalPrice"] { totalPrice = token as? String ?? totalPrice}
  1015. if let token = result["price"] { price = token as? String ?? price}
  1016. if let token = result["batchPrice"] { batchPrice = token as? String ?? batchPrice}
  1017. if let token = result["cnyPrice"] { cnyPrice = token as? String ?? cnyPrice}
  1018. if let token = result["cnyBatchPrice"] { cnyBatchPrice = token as? String ?? cnyBatchPrice}
  1019. if let token = result["cnyTotalPrice"] { cnyTotalPrice = token as? String ?? cnyTotalPrice}
  1020. let products = KMBatchProductPriceModel(productId: productId, totalPrice: totalPrice, price: price, batchPrice: batchPrice, cnyPrice: cnyPrice, cnyBatchPrice: cnyBatchPrice, cnyTotalPrice: cnyTotalPrice)
  1021. let result1 = KMMemberProductResult(code: requestCode, msg: message, batchProductPrice: products)
  1022. if requestCode == 200 {
  1023. complete(true, result1)
  1024. } else {
  1025. complete(false, result1)
  1026. }
  1027. }
  1028. } else {
  1029. print("Invalid URL")
  1030. }
  1031. }
  1032. /**
  1033. @abstract 验证商品优惠券,返回商品优惠后价格
  1034. @param productId 购买的产品id
  1035. @param userId 用户ID
  1036. @param code 优惠券
  1037. @param complete 回调
  1038. */
  1039. func checkCoupon(productId: String, userId: String, code: String, _ complete: @escaping KMMemberProductComplete) {
  1040. let token: String = KMMemberInfo.shared.access_token
  1041. if token == "" {
  1042. complete(false, nil)
  1043. return
  1044. }
  1045. let urlString = configuration.activityBaseURL() + "/pdf-office-website/web/checkCoupon"
  1046. let params: [String: Any] = ["productId": productId,
  1047. "userId": userId,
  1048. "code": code]
  1049. if let urlNewString = constructURLString(baseURLString: urlString, parameters: params) {
  1050. KMRequestServer.requestServer.request(urlString: urlNewString, method: .get, params: nil) { requestSerializer in
  1051. requestSerializer.setValue("Bearer " + token, forHTTPHeaderField: "Authorization")
  1052. } completion: { [weak self] (task, responseObject, error) in
  1053. var dic: NSDictionary = [:]
  1054. if error == nil, let responseObject = responseObject as? NSDictionary {
  1055. dic = responseObject
  1056. } else {
  1057. var info = responseObject
  1058. if let error = error {
  1059. if let data = error.userInfo["com.alamofire.serialization.response.error.data"] as? Data {
  1060. info = try? JSONSerialization.jsonObject(with: data, options: .mutableLeaves) as? NSDictionary
  1061. }
  1062. }
  1063. dic = (info as? NSDictionary) ?? [:]
  1064. }
  1065. let requestCode: Int = dic["code"] as? Int ?? 0
  1066. let result: NSDictionary = dic["result"] as? NSDictionary ?? [:]
  1067. let message: String = dic["msg"] as? String ?? ""
  1068. var id = ""
  1069. var productName = ""
  1070. var maxDeviceNum = 0
  1071. var levels = ""
  1072. var platforms = ""
  1073. var productLineId = 0
  1074. var paymentModel = 0
  1075. var cycle = 0
  1076. var code = ""
  1077. var price = NSNumber(value: 0.0)
  1078. var displayPrice = NSNumber(value: 0.0)
  1079. var upgradePrice = NSNumber(value: 0.0)
  1080. var cnyPrice = NSNumber(value: 0.0)
  1081. var displayCnyPrice = NSNumber(value: 0.0)
  1082. var priceString:String?
  1083. var displayPriceString:String?
  1084. var upgradePriceString:String?
  1085. var cnyPriceString:String?
  1086. var displayCnyPriceString:String?
  1087. var upgradecnyPriceString:String?
  1088. if let token = result["id"] { id = token as? String ?? id }
  1089. if let token = result["productName"] { productName = token as? String ?? productName }
  1090. if let token = result["maxDeviceNum"] { maxDeviceNum = token as? Int ?? maxDeviceNum }
  1091. if let token = result["levels"] { levels = token as? String ?? levels }
  1092. if let token = result["platforms"] { platforms = token as? String ?? platforms }
  1093. if let token = result["productLineId"] { productLineId = token as? Int ?? productLineId }
  1094. if let token = result["paymentModel"] { paymentModel = token as? Int ?? paymentModel }
  1095. if let token = result["cycle"] { cycle = token as? Int ?? cycle }
  1096. if let token = result["code"] { code = token as? String ?? code }
  1097. if let token = result["price"] as? NSNumber {
  1098. let string = KMFormatNSNumber(token, to: 2)
  1099. priceString = string
  1100. price = token
  1101. }
  1102. if let token = result["displayPrice"] as? NSNumber {
  1103. let string = KMFormatNSNumber(token, to: 2)
  1104. displayPriceString = string
  1105. displayPrice = token
  1106. }
  1107. if let token = result["upgradePrice"] as? NSNumber {
  1108. let string = KMFormatNSNumber(token, to: 2)
  1109. upgradePriceString = string
  1110. upgradePrice = token
  1111. }
  1112. if let token = result["cnyPrice"] as? NSNumber {
  1113. let string = KMFormatNSNumber(token, to: 2)
  1114. cnyPriceString = string
  1115. cnyPrice = token
  1116. }
  1117. if let token = result["cnyDisplayPrice"] as? NSNumber {
  1118. let string = KMFormatNSNumber(token, to: 2)
  1119. displayCnyPriceString = string
  1120. displayCnyPrice = token
  1121. }
  1122. if let token = result["cnyUpgradePrice"] as? NSNumber {
  1123. let string = KMFormatNSNumber(token, to: 2)
  1124. upgradecnyPriceString = string
  1125. }
  1126. let products = KMCheckCouponModel(id: id, productName: productName, price: priceString, maxDeviceNum: maxDeviceNum, displayPrice: displayPriceString, levels: levels, platforms: platforms, productLineId: productLineId, paymentModel: paymentModel, cycle: cycle, cnyPrice: cnyPriceString, displayCnyPrice: displayCnyPriceString, upgradePrice: upgradePriceString, code: code)
  1127. products.upgradecnyPriceString = upgradecnyPriceString
  1128. let result1 = KMMemberProductResult(code: requestCode, msg: message, checkCoupon: products)
  1129. if requestCode == 200 {
  1130. complete(true, result1)
  1131. } else {
  1132. complete(false, result1)
  1133. }
  1134. }
  1135. } else {
  1136. print("Invalid URL")
  1137. complete(false, nil)
  1138. }
  1139. }
  1140. /**
  1141. @abstract 检查邮箱教育优惠资格
  1142. @param email 邮箱
  1143. @param complete 回调
  1144. */
  1145. func checkEducation(email: String, _ complete: @escaping KMMemberProductComplete) {
  1146. let urlString = configuration.activityBaseURL() + "/pdf-office-website/web/checkEducation"
  1147. let params: [String: Any] = ["email": email]
  1148. if let urlNewString = constructURLString(baseURLString: urlString, parameters: params) {
  1149. KMRequestServer.requestServer.request(urlString: urlNewString, method: .get, params: nil) { requestSerializer in
  1150. } completion: { [weak self] (task, responseObject, error) in
  1151. var dic: NSDictionary = [:]
  1152. if error == nil, let responseObject = responseObject as? NSDictionary {
  1153. dic = responseObject
  1154. } else {
  1155. var info = responseObject
  1156. if let error = error {
  1157. if let data = error.userInfo["com.alamofire.serialization.response.error.data"] as? Data {
  1158. info = try? JSONSerialization.jsonObject(with: data, options: .mutableLeaves) as? NSDictionary
  1159. }
  1160. }
  1161. dic = (info as? NSDictionary) ?? [:]
  1162. }
  1163. let requestCode: Int = dic["code"] as? Int ?? 0
  1164. let result: NSDictionary = dic["result"] as? NSDictionary ?? [:]
  1165. let message: String = dic["msg"] as? String ?? ""
  1166. var productId = ""
  1167. var totalPrice = ""
  1168. var price = ""
  1169. var batchPrice = ""
  1170. var cnyPrice = ""
  1171. var cnyBatchPrice = ""
  1172. var cnyTotalPrice = ""
  1173. if let token = result["productId"] { productId = token as? String ?? productId}
  1174. if let token = result["totalPrice"] { totalPrice = token as? String ?? totalPrice}
  1175. if let token = result["price"] { price = token as? String ?? price}
  1176. if let token = result["batchPrice"] { batchPrice = token as? String ?? batchPrice}
  1177. if let token = result["cnyPrice"] { cnyPrice = token as? String ?? cnyPrice}
  1178. if let token = result["cnyBatchPrice"] { cnyBatchPrice = token as? String ?? cnyBatchPrice}
  1179. if let token = result["cnyTotalPrice"] { cnyTotalPrice = token as? String ?? cnyTotalPrice}
  1180. let products = KMBatchProductPriceModel(productId: productId, totalPrice: totalPrice, price: price, batchPrice: batchPrice, cnyPrice: cnyPrice, cnyBatchPrice: cnyBatchPrice, cnyTotalPrice: cnyTotalPrice)
  1181. let result1 = KMMemberProductResult(code: requestCode, msg: message, batchProductPrice: products)
  1182. if requestCode == 200 {
  1183. complete(true, result1)
  1184. } else {
  1185. complete(false, result1)
  1186. }
  1187. }
  1188. } else {
  1189. print("Invalid URL")
  1190. complete(false, nil)
  1191. }
  1192. }
  1193. // MARK: 个人中心模块
  1194. // MARK: 订单模块
  1195. /**
  1196. @abstract 支付后查询订单状态
  1197. @param orderId 订单id
  1198. @param complete 回调
  1199. */
  1200. func getStateByOrderId(orderId: String, _ complete: @escaping KMMemberRequestInfoComplete) {
  1201. let token: String = KMMemberInfo.shared.access_token
  1202. if token == "" {
  1203. complete(false, nil)
  1204. return
  1205. }
  1206. let urlString = configuration.activityBaseURL() + "/pdf-office-website/order/getStateByOrderId"
  1207. let params: [String: Any] = ["orderId": orderId]
  1208. if let urlNewString = constructURLString(baseURLString: urlString, parameters: params) {
  1209. KMRequestServer.requestServer.request(urlString: urlNewString, method: .get, params: nil) { requestSerializer in
  1210. requestSerializer.setValue("Bearer " + token, forHTTPHeaderField: "Authorization")
  1211. } completion: { [weak self] (task, responseObject, error) in
  1212. var dic: NSDictionary = [:]
  1213. if error == nil, let responseObject = responseObject as? NSDictionary {
  1214. dic = responseObject
  1215. } else {
  1216. var info = responseObject
  1217. if let error = error {
  1218. if let data = error.userInfo["com.alamofire.serialization.response.error.data"] as? Data {
  1219. info = try? JSONSerialization.jsonObject(with: data, options: .mutableLeaves) as? NSDictionary
  1220. }
  1221. }
  1222. dic = (info as? NSDictionary) ?? [:]
  1223. }
  1224. let requestCode: Int = dic["code"] as? Int ?? 0
  1225. let requestDic: NSDictionary = dic["result"] as? NSDictionary ?? [:]
  1226. let status:String = requestDic["status"] as? String ?? ""
  1227. if requestCode == 200{
  1228. complete(true, dic)
  1229. } else {
  1230. complete(false, dic)
  1231. }
  1232. }
  1233. } else {
  1234. print("Invalid URL")
  1235. complete(false, nil)
  1236. }
  1237. }
  1238. /**
  1239. @abstract 创建订单(买断)
  1240. @param productId 产品id
  1241. @param paymentMethod 支付方式 PAYPAL(0),ALIPAY(1),WXPAY(2),PADDLE(3)
  1242. @param price 价格
  1243. @param discountFlag 0原价,1优惠券,2升级,3教育优惠,4批量购买,5黑五折扣
  1244. @param couponCode 优惠卷
  1245. @param num 批量购买数量
  1246. @param complete 回调
  1247. */
  1248. func createOrder(productId: String, paymentMethod: Int, price: String, discountFlag: Int, couponCode: String, num: Int, _ complete: @escaping KMMemberProductComplete) {
  1249. let token: String = KMMemberInfo.shared.access_token
  1250. if token == "" {
  1251. complete(false, nil)
  1252. return
  1253. }
  1254. let urlString = configuration.activityBaseURL() + "/pdf-office-website/order/createOrder"
  1255. let params: [String: Any] = ["productId": productId,
  1256. "paymentMethod": paymentMethod,
  1257. "price": price,
  1258. "discountFlag": discountFlag,
  1259. "couponCode": couponCode,
  1260. "num": num]
  1261. KMRequestServer.requestServer.request(urlString: urlString, method: .post, params: params) { requestSerializer in
  1262. requestSerializer.setValue("Bearer " + token, forHTTPHeaderField: "Authorization")
  1263. } completion: { [weak self] (task, responseObject, error) in
  1264. var dic: NSDictionary = [:]
  1265. if error == nil, let responseObject = responseObject as? NSDictionary {
  1266. dic = responseObject
  1267. } else {
  1268. var info = responseObject
  1269. if let error = error {
  1270. if let data = error.userInfo["com.alamofire.serialization.response.error.data"] as? Data {
  1271. info = try? JSONSerialization.jsonObject(with: data, options: .mutableLeaves) as? NSDictionary
  1272. }
  1273. }
  1274. dic = (info as? NSDictionary) ?? [:]
  1275. }
  1276. let requestCode: Int = dic["code"] as? Int ?? 0
  1277. let result: NSDictionary = dic["result"] as? NSDictionary ?? [:]
  1278. let message: String = dic["msg"] as? String ?? ""
  1279. var thirdOrderNo = ""
  1280. var orderId = ""
  1281. var payHref = ""
  1282. var qrCode = ""
  1283. if requestCode == 200 {
  1284. if let token = result["thirdOrderNo"] { thirdOrderNo = token as? String ?? thirdOrderNo}
  1285. if let token = result["orderId"] { orderId = token as? String ?? orderId}
  1286. if let token = result["payHref"] { payHref = token as? String ?? payHref}
  1287. if let token = result["qrcode"] { qrCode = token as? String ?? qrCode}
  1288. let products = KMCreateOrderModel(thirdOrderNo: thirdOrderNo, orderId: orderId, payHref: payHref, qrCode: qrCode)
  1289. let result1 = KMMemberProductResult(code: requestCode, msg: message, createOrder: products)
  1290. complete(true, result1)
  1291. } else {
  1292. let result1 = KMMemberProductResult(code: requestCode, msg: message, createOrder: KMCreateOrderModel(thirdOrderNo: thirdOrderNo, orderId: orderId, payHref: payHref, qrCode: qrCode))
  1293. complete(false, result1)
  1294. }
  1295. }
  1296. }
  1297. /**
  1298. @abstract 创建订单(订阅)
  1299. @param productId 产品id
  1300. @param paymentMethod 支付方式 PAYPAL(0),ALIPAY(1),WXPAY(2),PADDLE(3)
  1301. @param price 价格
  1302. @param discountFlag 0原价,1优惠券,2升级,3教育优惠,4批量购买,5黑五折扣
  1303. @param couponCode 优惠卷
  1304. @param num 批量购买数量
  1305. @param complete 回调
  1306. */
  1307. func createSubscriber(productId: String, paymentMethod: Int, price: String, discountFlag: Int, couponCode: String, num: Int, _ complete: @escaping KMMemberProductComplete) {
  1308. let token: String = KMMemberInfo.shared.access_token
  1309. if token == "" {
  1310. complete(false, nil)
  1311. return
  1312. }
  1313. let urlString = configuration.activityBaseURL() + "/pdf-office-website/order/createSubscription"
  1314. let params: [String: Any] = ["productId": productId,
  1315. "paymentMethod": paymentMethod,
  1316. "price": price,
  1317. "discountFlag": discountFlag,
  1318. "couponCode": couponCode,
  1319. "num": num]
  1320. KMRequestServer.requestServer.request(urlString: urlString, method: .post, params: params) { requestSerializer in
  1321. requestSerializer.setValue("Bearer " + token, forHTTPHeaderField: "Authorization")
  1322. } completion: { [weak self] (task, responseObject, error) in
  1323. var dic: NSDictionary = [:]
  1324. if error == nil, let responseObject = responseObject as? NSDictionary {
  1325. dic = responseObject
  1326. } else {
  1327. var info = responseObject
  1328. if let error = error {
  1329. if let data = error.userInfo["com.alamofire.serialization.response.error.data"] as? Data {
  1330. info = try? JSONSerialization.jsonObject(with: data, options: .mutableLeaves) as? NSDictionary
  1331. }
  1332. }
  1333. dic = (info as? NSDictionary) ?? [:]
  1334. }
  1335. let requestCode: Int = dic["code"] as? Int ?? 0
  1336. let result: NSDictionary = dic["result"] as? NSDictionary ?? [:]
  1337. let message: String = dic["msg"] as? String ?? ""
  1338. var thirdOrderNo = ""
  1339. var orderId = ""
  1340. var payHref = ""
  1341. var qrCode = ""
  1342. if requestCode == 200 {
  1343. if let token = result["thirdOrderNo"] { thirdOrderNo = token as? String ?? thirdOrderNo}
  1344. if let token = result["orderId"] { orderId = token as? String ?? orderId}
  1345. if let token = result["payHref"] { payHref = token as? String ?? payHref}
  1346. if let token = result["qrcode"] { qrCode = token as? String ?? qrCode}
  1347. let products = KMCreateOrderModel(thirdOrderNo: thirdOrderNo, orderId: orderId, payHref: payHref, qrCode: qrCode)
  1348. let result1 = KMMemberProductResult(code: requestCode, msg: message, createOrder: products)
  1349. complete(true, result1)
  1350. } else {
  1351. let result1 = KMMemberProductResult(code: requestCode, msg: message, createOrder: KMCreateOrderModel(thirdOrderNo: thirdOrderNo, orderId: orderId, payHref: payHref, qrCode: qrCode))
  1352. complete(false, result1)
  1353. }
  1354. }
  1355. }
  1356. /**
  1357. @abstract 获取订单列表
  1358. @param orderStatus 0全部1待支付
  1359. @param complete 回调
  1360. */
  1361. func getOrderListByStatus(orderStatus: Int, _ complete: @escaping KMMemberRequestInfoComplete) {
  1362. let token: String = KMMemberInfo.shared.access_token
  1363. if token == "" {
  1364. complete(false, nil)
  1365. return
  1366. }
  1367. let urlString = configuration.activityBaseURL() + "/pdf-office-website/order/getOrderListByStatus"
  1368. let params: [String: Any] = ["orderStatus": orderStatus]
  1369. if let urlNewString = constructURLString(baseURLString: urlString, parameters: params) {
  1370. KMRequestServer.requestServer.request(urlString: urlNewString, method: .get, params: nil) { requestSerializer in
  1371. requestSerializer.setValue("Bearer " + token, forHTTPHeaderField: "Authorization")
  1372. } completion: { [weak self] (task, responseObject, error) in
  1373. var dic: NSDictionary = [:]
  1374. if error == nil, let responseObject = responseObject as? NSDictionary {
  1375. dic = responseObject
  1376. } else {
  1377. var info = responseObject
  1378. if let error = error {
  1379. if let data = error.userInfo["com.alamofire.serialization.response.error.data"] as? Data {
  1380. info = try? JSONSerialization.jsonObject(with: data, options: .mutableLeaves) as? NSDictionary
  1381. }
  1382. }
  1383. dic = (info as? NSDictionary) ?? [:]
  1384. }
  1385. let requestCode: Int = dic["code"] as? Int ?? 0
  1386. if requestCode == 200 {
  1387. complete(true, dic)
  1388. } else {
  1389. complete(false, dic)
  1390. }
  1391. // var thirdOrderNo = ""
  1392. // var orderId = ""
  1393. // var payHref = ""
  1394. // if code == 200 {
  1395. // if let token = result["thirdOrderNo"] { thirdOrderNo = token as! String }
  1396. // if let token = result["orderId"] { orderId = token as! String }
  1397. // if let token = result["payHref"] { payHref = token as! String }
  1398. // let products = KMCreateOrderModel(thirdOrderNo: thirdOrderNo, orderId: orderId, payHref: payHref)
  1399. // let result1 = KMMemberProductResult(code: code, msg: message, createOrder: products)
  1400. // complete(true, result1)
  1401. // } else {
  1402. // let result1 = KMMemberProductResult(code: code, msg: message, createOrder: KMCreateOrderModel(thirdOrderNo: thirdOrderNo, orderId: orderId, payHref: payHref))
  1403. // complete(false, result1)
  1404. // }
  1405. }
  1406. } else {
  1407. complete(false, nil)
  1408. }
  1409. }
  1410. /**
  1411. @abstract 关闭订单
  1412. @param orderId 订单id
  1413. @param complete 回调
  1414. */
  1415. func closeByOrderId(orderId: String, _ complete: @escaping KMMemberRequestInfoComplete) {
  1416. let token: String = KMMemberInfo.shared.access_token
  1417. if token == "" {
  1418. complete(false, nil)
  1419. return
  1420. }
  1421. let urlString = configuration.activityBaseURL() + "/pdf-office-website/order/closeOrder"
  1422. let params: [String: Any] = ["orderId": orderId]
  1423. if let urlNewString = constructURLString(baseURLString: urlString, parameters: params) {
  1424. KMRequestServer.requestServer.request(urlString: urlNewString, method: .post, params: nil) { requestSerializer in
  1425. requestSerializer.setValue("Bearer " + token, forHTTPHeaderField: "Authorization")
  1426. } completion: { [weak self] (task, responseObject, error) in
  1427. var dic: NSDictionary = [:]
  1428. if error == nil, let responseObject = responseObject as? NSDictionary {
  1429. dic = responseObject
  1430. } else {
  1431. var info = responseObject
  1432. if let error = error {
  1433. if let data = error.userInfo["com.alamofire.serialization.response.error.data"] as? Data {
  1434. info = try? JSONSerialization.jsonObject(with: data, options: .mutableLeaves) as? NSDictionary
  1435. }
  1436. }
  1437. dic = (info as? NSDictionary) ?? [:]
  1438. }
  1439. let requestCode: Int = dic["code"] as? Int ?? 0
  1440. if requestCode == 200 {
  1441. complete(true, dic)
  1442. } else {
  1443. complete(false, dic)
  1444. }
  1445. }
  1446. } else {
  1447. complete(false, nil)
  1448. }
  1449. }
  1450. // MARK: 苹果支付
  1451. /**
  1452. @abstract APPstore 权益校验
  1453. @param applePayProductId
  1454. @param transactionId
  1455. @param productCode
  1456. @param complete 回调
  1457. */
  1458. func appStoreEquityVerification(applePayProductId: String, transactionId: String, productCode: String, _ complete: @escaping KMMemberProductComplete) {
  1459. let token: String = KMMemberInfo.shared.access_token
  1460. if token == "" {
  1461. complete(false, nil)
  1462. return
  1463. }
  1464. let urlString = configuration.activityBaseURL() + "/member-system-website/applePay/appStoreEquityVerification"
  1465. let bundleID = Bundle.main.object(forInfoDictionaryKey: "CFBundleIdentifier") ?? ""
  1466. let params: [String: Any] = ["appBundleId": bundleID,
  1467. "applePayProductId": applePayProductId,
  1468. "transactionId": transactionId,
  1469. "productCode": productCode]
  1470. let postData = try! JSONSerialization.data(withJSONObject: params)
  1471. var request = URLRequest(url: URL(string: urlString)!,timeoutInterval: Double.infinity)
  1472. request.addValue("Bearer " + token, forHTTPHeaderField: "Authorization")
  1473. request.addValue("application/json", forHTTPHeaderField: "Content-Type")
  1474. request.httpMethod = "POST"
  1475. request.httpBody = postData
  1476. let task = URLSession.shared.dataTask(with: request) { data, response, error in
  1477. guard let data = data else {
  1478. print(String(describing: error))
  1479. return
  1480. }
  1481. let jsonObject = try? JSONSerialization.jsonObject(with: data, options: []) as? NSDictionary ?? [:]
  1482. if jsonObject != nil {
  1483. let code: Int = jsonObject!["code"] as? Int ?? 0
  1484. let result: NSDictionary = jsonObject!["result"] as? NSDictionary ?? [:]
  1485. let message: String = jsonObject!["msg"] as? String ?? ""
  1486. let result1 = KMMemberProductResult(code: code, msg: message, result: "")
  1487. if code == 200 {
  1488. complete(true, result1)
  1489. } else {
  1490. complete(false, result1)
  1491. }
  1492. } else {
  1493. complete(false, KMMemberProductResult(code: 0, msg: "", result: ""))
  1494. }
  1495. }
  1496. task.resume()
  1497. }
  1498. // MARK: 评估模块
  1499. // MARK: 活动模块
  1500. // 签到
  1501. static func checkIn(callback: @escaping ((_ success: Bool, _ resultModel: KMRequestResultModel?, _ error: NSError?)->Void)) {
  1502. let uuid = GetHardwareUUID() ?? ""
  1503. var model = "MAC_APP_STORE_FREE"
  1504. if KMIsDMGVersion() {
  1505. model = "DMG_DOWNLOAD"
  1506. } else if KMIsAppStoreProVersion() {
  1507. model = "MAC_APP_STORE_PAID"
  1508. }
  1509. // let (major, minor, bugFix) = KMTools.getSystemVersion()
  1510. // let versionInfoString = "\(KMTools.getRawSystemInfo()) - \(major).\(minor).\(bugFix)"
  1511. let appVersion = KMTools.getAppVersion()
  1512. let language = NSLocale.current.identifier
  1513. let timeZone = NSTimeZone.local.localizedName(for: .shortDaylightSaving, locale: .current) ?? ""
  1514. let params = ["uniqueSn" : uuid,
  1515. "model" : model,
  1516. "os" : "",
  1517. "language" : language,
  1518. "timeZone" : timeZone,
  1519. "appVersion" : appVersion]
  1520. KMRequestServer.Member_POST(url: kURLAPI_memberSystemWebsite_activity_signIn, params: params, callback: callback)
  1521. }
  1522. // 判断用户是否处于试用后退订
  1523. static func judgeTrailCancel(callback: @escaping ((_ success: Bool, _ resultModel: KMRequestResultModel?, _ error: NSError?)->Void)) {
  1524. KMRequestServer.Member_GET(url: kURLAPI_memberSystemSSO_user_judgeTrailCancel, params: nil, callback: callback)
  1525. }
  1526. // MARK: 翻译模块
  1527. // MARK: AI模块
  1528. // MARK: 会员赠送模块
  1529. // MARK: Error Code
  1530. static func quickShowAlert(result: KMMemberProductResult?, callback: ((NSApplication.ModalResponse?, Any ...)->Void)?) {
  1531. guard let data = result else {
  1532. return
  1533. }
  1534. showAlert(code: .init(rawValue: data.code ?? 0), message: data.msg, callback: callback)
  1535. }
  1536. static func showAlert(code: KMMemberCenterErrorCodeType?, message: String?, callback: ((NSApplication.ModalResponse?, Any ...)->Void)?) {
  1537. let string = self.getCodeMessage(code: code, message: message)
  1538. KMMainThreadExecute {
  1539. let alert = NSAlert()
  1540. alert.messageText = NSLocalizedString(string, tableName: "MemberCenterLocalizable", comment: "")
  1541. let resp = alert.runModal()
  1542. callback?(resp)
  1543. }
  1544. }
  1545. static func getCodeMessage(code: KMMemberCenterErrorCodeType?, message: String?) -> String {
  1546. var string = self.typeOfMessage(type: code)
  1547. if string.isEmpty {
  1548. string = message ?? ""
  1549. }
  1550. return string
  1551. }
  1552. static func typeOfMessage(type: KMMemberCenterErrorCodeType?) -> String {
  1553. var result: String = ""
  1554. switch type {
  1555. case .EXCEPTION_MSG_TOKEN_IS_INVALID:
  1556. result = "Invalid token or token has expired."
  1557. break;
  1558. case .EXCEPTION_MSG_DEVICE_NUM_MAX:
  1559. result = "Your device logged-in has been limited. Please log out from other devices first."
  1560. break;
  1561. case .EXCEPTION_MSG_USER_NOT_LOGIN:
  1562. result = "The user has not logged in. Please login before accessing."
  1563. break;
  1564. case .EMAIL_VERIFY_CODE_KEY_ERROR:
  1565. result = "Email code error!"
  1566. break;
  1567. case .EMAIL_REGISTER_ERROR:
  1568. result = "Register error!"
  1569. break;
  1570. case .EXCEPTION_MSG_PASSWORD_ERROR:
  1571. result = "The password is wrong, you can check the case status."
  1572. break;
  1573. case .EXCEPTION_MSG_CODE_ACTION_ERROR:
  1574. result = "Code action error."
  1575. break;
  1576. case .EXCEPTION_MSG_CODE_SEND_ERROR:
  1577. result = "Code send error."
  1578. break;
  1579. case .EXCEPTION_MAIL_CODE_SEND_ERROR:
  1580. result = "Mail send error."
  1581. break;
  1582. case .VERIFY_CODE_SEND_TOO_QUICKLY:
  1583. result = "Code send too quickly!"
  1584. break;
  1585. case .EXCEPTION_MSG_EMAIL_EXIST:
  1586. result = "This email is already associated with an account. please log in."
  1587. break;
  1588. case .EXCEPTION_MSG_EMAIL_NOT_REGISTER:
  1589. result = "The current account is not registered. Please sign up using the verification code directly."
  1590. break;
  1591. case .EXCEPTION_MSG_EMAIL_LOGOUT_ING:
  1592. result = "The account is being removed and unable to log in. If you have any questions, please get in touch with customer service."
  1593. break;
  1594. case .EXCEPTION_MSG_EMAIL_INVALID:
  1595. result = "Please enter the correct email format."
  1596. break;
  1597. case .EXCEPTION_MSG_PASSWORD_NOT_INCONSISTENT:
  1598. result = "Password is inconsistent, please re-enter."
  1599. break;
  1600. case .EXCEPTION_MSG_PASSWORD_SIZE_MIN:
  1601. result = "The password must contain 6 to 24 characters."
  1602. break;
  1603. case .EXCEPTION_MSG_PASSWORD_SIZE_MAX:
  1604. result = "The password must contain 6 to 24 characters."
  1605. break;
  1606. case .EXCEPTION_MSG_PLEASE_ADD_AUTH_CONFIG:
  1607. result = "Please add auth config"
  1608. break;
  1609. case .EXCEPTION_MSG_USER_SUBSCRIPTION_IN_PROGRESS:
  1610. result = "You are still subscribing and cannot remove your account at the moment. Please wait until the subscription period is over."
  1611. break;
  1612. case .EXCEPTION_TIME_TRANSFER_ERROR:
  1613. result = "Time conversion failed."
  1614. break;
  1615. case .EXCEPTION_MSG_PASSWORD_CONTAIN_EMPTY:
  1616. result = "Password cannot contain spaces."
  1617. break;
  1618. case .EXCEPTION_MSG_CREATE_ORDER_PARAMETER: // 支付方式异常
  1619. result = "Abnormal payment method."
  1620. case .EXCEPTION_MSG_EVENT_IS_CURRENTLY_NOT_SUPPORTED: // 当前事件暂不支持
  1621. result = "The current event is not supported yet."
  1622. case .EXCEPTION_MSG_THE_ACCOUNT_IS_ALREADY_LOGGED_IN_ON_OTHER_DEVICES: // 账号已在其他设备登录
  1623. result = "This account has been logged in on other devices."
  1624. case .EXCEPTION_MSG_ABNORMAL_USER_STATUS: // 当前邮箱已被停用或者处于注销中状态
  1625. result = "The current email address has been deactivated or is in the account cancellation state."
  1626. case .EXCEPTION_MSG_APP_STORE_TICKET_VALIDATION_FAILED: // Appstore票据验证失败"
  1627. result = "Ticket verification of AppStore failed."
  1628. case .EXCEPTION_MSG_APP_STORE_TICKET_VALIDATION_NEED_TO_RETRY: //Appstore票据验证需要重试
  1629. result = "Ticket verification of AppStore needs to be retried."
  1630. case .EXCEPTION_MSG_REPEAT_SUBSCRIPTION: // 用户已订阅该产品
  1631. result = "The user has subscribed to this product."
  1632. case .EXCEPTION_MSG_RESTORING_PURCHASES_IS_NOT_CURRENTLY_SUPPORTED: // 恢复购买暂不支持
  1633. result = "Restoring purchases is not supported yet."
  1634. case .EXCEPTION_MSG_USER_TRANSACTION_CANCELED_OR_FAILED: // 用户交易取消或失败
  1635. result = "The user's transaction is canceled or failed."
  1636. case .EXCEPTION_MSG_CURRENT_ORDER_NOT_RECORDED: // 当前订单末记录,请稍后重试
  1637. result = "The current order is not recorded, please try again later."
  1638. case .EXCEPTION_MSG_THE_SAME_USER: //同一用户,无需处理
  1639. result = "Same user, no need to process."
  1640. case .EXCEPTION_MSG_THIRD_PAY_ID_ILLEGAL: //thirdPayld非法
  1641. result = "Third-party payment is illegal."
  1642. case .EXCEPTION_MSG_ORDER_DOES_NOT_EXIST: //订单不存在
  1643. result = "Order does not exist."
  1644. case .EXCEPTION_MSG_THE_ORDER_STATUS_IS_ABNORMAL: // 订单状态异常
  1645. result = "Order status abnormal."
  1646. case .EXCEPTION_MSG_TRANSACTION_ID_REPEAT: // transactionld重复
  1647. result = "Transaction duplicate."
  1648. case .EXCEPTION_TICKET_HAS_BEEN_BLOCKED: // The ticket has been blocked
  1649. result = "The ticket has been blocked."
  1650. case .EXCEPTION_TICKET_HAS_BEEN_CREATED: // 当前票据已创建订单
  1651. result = "The current ticket has created an order."
  1652. case .EXCEPTION_USER_IS_NOT_EDUCATION_USER: // 用户不是教育用户
  1653. result = "The user is not an educational user."
  1654. case .EXCEPTION_USER_HAS_EDUCATION: // 用户近一年有教育购买订单
  1655. result = "The user has education purchase orders in the past year."
  1656. case .EXCEPTION_USER_CANNOT_BUY_PREMIUM: // 用户已有标准版订阅,无法购买高级版
  1657. result = "The user already has a PDF Reader Pro Standard Plan and cannot purchase the Advance Plan."
  1658. case .EXCEPTION_USER_CANNOT_BUY_VIP: // 用户已有高级版订阅,无法购买标准版
  1659. result = "The user already has a PDF Reader Pro Advance Plan and cannot purchase the Standard Plan."
  1660. case .EXCEPTION_USER_CANNOT_UPGRADE_VIP: // 买断用户无法升级为标准版
  1661. result = "The Permanent Plan user cannot upgrade to the Standard Plan."
  1662. case .EXCEPTION_COUPON_NOT_EXISTS: // 优惠券不存在
  1663. result = "The coupon code does not exist."
  1664. case .EXCEPTION_COUPONTYPE_ERROR: // 优惠券类型错误
  1665. result = "Wrong coupon code type."
  1666. case .EXCEPTION_COUPON_PRODUCT_ERROR: // 优惠券关联产品错误
  1667. result = "Coupon-associated product error."
  1668. case .EXCEPTION_COUPON_INVALID: // 优惠券已失效
  1669. result = "The coupon code has expired."
  1670. case .EXCEPTION_PRODUCT_NOT_EXIST: // 产品不存在
  1671. result = "The product does not exist."
  1672. case .EXCEPTION_MSG_CONTACT_US: //请联系我们获取最新折扣
  1673. result = "Please get in touch with us for the latest discounts."
  1674. case .EXCEPTION_MSG_APP_STORE_TRANSACTION_ID_VALIDATION_FAILED: // 验证苹果交易失败
  1675. result = "Verification of Apple's Transaction failed."
  1676. case .EXCEPTION_MSG_GOOGLE_STORE_TRANSACTION_ID_VALIDATION_FAILED: // 验证谷歌交易失败
  1677. result = "Verification of Google's Transaction failed."
  1678. case .EXCEPTION_PRICE_ERROR: // 价格错误
  1679. result = "Price error."
  1680. case .EXCEPTION_MSG_ORDER_CREATE_FAILED: // 订单创建失败
  1681. result = "Order creation failed."
  1682. case .USER_ALREADY_SUBSCRIBED_PLAN: // 该用户已经是PDF Reader Pro订阅版会员,确定再赠送吗
  1683. result = "This user is already a subscription member of PDF Reader Pro. Are you sure you want to share benefits?"
  1684. case .USER_ALREADY_SUBSCRIBED_PACKAGE: // 该用户已经是PDF Reader Pro永久版会员,无需再赠送哦
  1685. result = "This user is already a permanent member of PDF Reader Pro. You don't need to share benefits anymore."
  1686. case .EXCEPTION_MSG_USER_NOT_EXIST: //用户不存在
  1687. result = "User does not exist."
  1688. case .EXCEPTION_USER_ALREADY_LOTTERY: // 用户已经抽过奖啦
  1689. result = "The user already has a prize draw!"
  1690. case .UNKNOWN:
  1691. result = "UNKNOWN"
  1692. break;
  1693. case .SUCCESS:
  1694. result = "SUCCESS"
  1695. break;
  1696. default:
  1697. result = "Network error"
  1698. }
  1699. return result
  1700. }
  1701. }