KMAIRequestServerManager.swift 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662
  1. //
  2. // KMAIRequestServerManager.swift
  3. // Cisdem PDFMaster
  4. //
  5. // Created by wanjun on 2024/1/17.
  6. //
  7. import Cocoa
  8. import AFNetworking
  9. @objcMembers
  10. class ResultWrapper: NSObject {
  11. var success: Bool = false
  12. var result: NSDictionary = [:]
  13. // var message: String = ""
  14. // var code : Int = 200
  15. // var error: NSError?
  16. // var state: KMAIRewritingState = .rewrite
  17. var content: String = ""
  18. // init(success: Bool, result: NSDictionary, message: String, code: Int, error: NSError? = nil, state: KMAIRewritingState) {
  19. // self.success = success
  20. // self.result = result
  21. // self.message = message
  22. // self.code = code
  23. // self.error = error
  24. // self.state = state
  25. // }
  26. init(success: Bool, content: String) {
  27. self.success = success
  28. self.content = content
  29. self.result = NSDictionary.init()
  30. }
  31. init(success: Bool, resultData: NSDictionary) {
  32. self.success = success
  33. self.content = ""
  34. self.result = resultData
  35. }
  36. }
  37. @objc enum KMAIRewritingState : Int {
  38. case rewrite = 0 // 重写
  39. case correctTypos // 纠错
  40. case uploadTranslate // 翻译上传文件
  41. case fileTranslate // 翻译文件
  42. case textTranslate // 翻译文本
  43. case extractSummaryFile //摘要
  44. }
  45. @objc enum KMAIFileUploadState : Int {
  46. case Translation = 0
  47. case ExtractAbstract
  48. }
  49. //typealias KMRequestServerComplete = (_ success: Bool, _ result: Result?) -> Void
  50. @objcMembers class KMAIRequestServerManager: NSObject {
  51. static let defaultManager = KMAIRequestServerManager()
  52. typealias KMRequestServerComplete = (_ wrapper: ResultWrapper) -> Void
  53. private var downFileUrl: String = "" // 文件翻译
  54. var downFileName: String = "" // 文件翻译
  55. var fromLanguages: [String] = ["Automatic", "English", "Simplified Chinese", "Traditional Chinese", "Japanese", "Korean", "French", "Spanish", "Italian", "German", "Portuguese", "Russian", "Vietnamese", "Thai", "Arabic", "Greek", "Bulgarian", "Finnish", "Slovene", "Dutch", "Czech", "Swedish", "Polish", "Danish", "Romanian", "Hungarian"]
  56. var toLanguages: [String] = ["English", "Simplified Chinese", "Traditional Chinese", "Japanese", "Korean", "French", "Spanish", "Italian", "German", "Portuguese", "Russian", "Vietnamese", "Thai", "Arabic", "Greek", "Bulgarian", "Finnish", "Slovene", "Dutch", "Czech", "Swedish", "Polish", "Danish", "Romanian", "Hungarian"]
  57. // MARK: AI Action (public)
  58. func aiAction(content: String, state: KMAIRewritingState, from: String = "auto", to: String = "en", complete: @escaping KMRequestServerComplete) {
  59. if state == .rewrite || state == .correctTypos { //重写 && 纠错
  60. aiRewriting(content: content, state: state, complete: complete)
  61. } else if state == .uploadTranslate || state == .fileTranslate { // 上传文件 || 文件翻译
  62. aiTranslationFileUpload(file: content, complete: { [unowned self] wrapper in
  63. let success: Bool = wrapper.success
  64. let fileKey = wrapper.content
  65. if success {
  66. let fileData = wrapper.result
  67. complete(wrapper)
  68. // aiTranslationFileTranslateHandle(fileKey: fileKey, from: languageAbbreviation(from), to: languageAbbreviation(to), complete: complete)
  69. } else {
  70. complete(wrapper)
  71. }
  72. })
  73. } else if state == .textTranslate { // 文本翻译
  74. aiTranslationTextTrans(q: content, from: languageAbbreviation(from), to: languageAbbreviation(to), complete: complete)
  75. } else if state == .extractSummaryFile { // 提取摘要
  76. extractSummaryFile(file: content, complete: complete)
  77. }
  78. }
  79. // MARK: Private
  80. private func uuid() -> String {
  81. return GetHardwareUUID()!
  82. }
  83. private func platform() -> String {
  84. var platform = "DMG"
  85. #if VERSION_DMG
  86. platform = "DMG"
  87. #else
  88. platform = "AiStore"
  89. #endif
  90. return platform
  91. }
  92. private func app_name() -> String {
  93. return "com.cisdem.pdfmaster.mac"
  94. }
  95. func downloadFile(filePath: String, downFileName: String, toPath: String, complete: @escaping KMRequestServerComplete) {
  96. self.downFileUrl = ""
  97. guard let fileURL = URL(string: filePath) else {
  98. let alert = NSAlert()
  99. alert.alertStyle = .critical
  100. alert.messageText = NSLocalizedString("Invalid file link", comment: "")
  101. alert.runModal()
  102. return
  103. }
  104. var destinationURL = FileManager.default.temporaryDirectory.appendingPathComponent(downFileName)
  105. if URL(fileURLWithPath: toPath) != nil {
  106. destinationURL = URL(fileURLWithPath: toPath)
  107. }
  108. if FileManager.default.fileExists(atPath: destinationURL.path) {
  109. do {
  110. try FileManager.default.removeItem(at: destinationURL)
  111. print("删除旧文件成功")
  112. } catch {
  113. print("删除旧文件失败:\(error)")
  114. }
  115. }
  116. let sessionConfiguration = URLSessionConfiguration.default
  117. let session = URLSession(configuration: sessionConfiguration)
  118. let downloadTask = session.downloadTask(with: fileURL) { (tempLocalURL, response, error) in
  119. if let error = error {
  120. let alert = NSAlert()
  121. alert.alertStyle = .critical
  122. alert.messageText = String(format: "%@:\(error)", NSLocalizedString("Download failed", comment: ""))
  123. alert.runModal()
  124. return
  125. }
  126. guard let tempLocalURL = tempLocalURL else {
  127. let alert = NSAlert()
  128. alert.alertStyle = .critical
  129. alert.messageText = NSLocalizedString("Invalid temporary directory", comment: "")
  130. alert.runModal()
  131. return
  132. }
  133. do {
  134. try FileManager.default.moveItem(at: tempLocalURL, to: destinationURL)
  135. let wrapper = ResultWrapper(success: true, content: "")
  136. wrapper.content = destinationURL.path
  137. complete(wrapper)
  138. } catch {
  139. let alert = NSAlert()
  140. alert.alertStyle = .critical
  141. alert.messageText = String(format: "%@:\(error)", NSLocalizedString("Failed to save file", comment: ""))
  142. alert.runModal()
  143. }
  144. }
  145. self.downFileUrl = destinationURL.path
  146. downloadTask.resume()
  147. }
  148. private func languageAbbreviation(_ language: String) -> String {
  149. if language == "Automatic" || language == "auto" {
  150. return "auto"
  151. } else if language == "English" || language == "en" {
  152. return "en"
  153. } else if language == "Simplified Chinese" || language == "zh" {
  154. return "zh"
  155. } else if language == "Traditional Chinese" || language == "cht" {
  156. return "cht"
  157. } else if language == "Japanese" || language == "jp" {
  158. return "jp"
  159. } else if language == "Korean" || language == "kor" {
  160. return "kor"
  161. } else if language == "French" || language == "fra" {
  162. return "fra"
  163. } else if language == "Spanish" || language == "spa" {
  164. return "spa"
  165. } else if language == "Italian" || language == "it" {
  166. return "it"
  167. } else if language == "German" || language == "de" {
  168. return "de"
  169. } else if language == "Portuguese" || language == "pt" {
  170. return "pt"
  171. } else if language == "Russian" || language == "ru" {
  172. return "ru"
  173. } else if language == "Vietnamese" || language == "vie" {
  174. return "vie"
  175. } else if language == "Thai" || language == "th" {
  176. return "th"
  177. } else if language == "Arabic" || language == "ara" {
  178. return "ara"
  179. } else if language == "Greek" || language == "el" {
  180. return "el"
  181. } else if language == "Bulgarian" || language == "bul" {
  182. return "bul"
  183. } else if language == "Finnish" || language == "fin" {
  184. return "fin"
  185. } else if language == "Slovene" || language == "slo" {
  186. return "slo"
  187. } else if language == "Dutch" || language == "nl" {
  188. return "nl"
  189. } else if language == "Czech" || language == "cs" {
  190. return "cs"
  191. } else if language == "Swedish" || language == "swe" {
  192. return "swe"
  193. } else if language == "Polish" || language == "pl" {
  194. return "pl"
  195. } else if language == "Danish" || language == "dan" {
  196. return "dan"
  197. } else if language == "Romanian" || language == "rom" {
  198. return "rom"
  199. } else if language == "Hungarian" || language == "hu" {
  200. return "hu"
  201. }
  202. return "auto"
  203. }
  204. // MARK: AI Action (private)
  205. /**
  206. @abstract 翻译上传
  207. @param file 文件路径
  208. @param complete 上传完成回调
  209. */
  210. private func aiTranslationFileUpload(file: String, complete: @escaping KMRequestServerComplete) {
  211. let infoDictionary = Bundle .main.infoDictionary!
  212. let urlString = AIInfoConfig().aiActionURL + "/api/AI/uploadTranslate"
  213. let fileData = FileManager.default.contents(atPath: file)
  214. let params: [String: Any] = ["file": fileData,
  215. "uuid": uuid(),
  216. "platform": platform(),
  217. "app_name": app_name(),
  218. "calculate":"1"]
  219. KMAIRequestServer.requestServer.uploadFile(urlString: urlString, params: params) { formData in
  220. let fileURL = URL(fileURLWithPath: file)
  221. try? formData.appendPart(withFileURL: fileURL, name: "file", fileName: fileURL.lastPathComponent, mimeType: "application/octet-stream")
  222. } requestSerializer: { requestSerializer in
  223. requestSerializer.setValue("Apifox/1.0.0 (https://www.apifox.cn)", forHTTPHeaderField: "User-Agent")
  224. } completion: { task, responseObject, error in
  225. if responseObject != nil {
  226. let data: NSDictionary = responseObject!["data"] as? NSDictionary ?? [:]
  227. var code: String = responseObject!["code"] as? String ?? "06005"
  228. if code == "06005" {
  229. let tempCode: Int = responseObject!["code"] as? Int ?? 0
  230. if tempCode == 501 {
  231. code = "501"
  232. }
  233. }
  234. let message: String = responseObject!["message"] as? String ?? "unknown error"
  235. let error = NSError(domain: message, code: Int(code)!)
  236. // let result = ResultWrapper(success: true, result: data, message: message, code: Int(code)!, error: error, state: .uploadTranslate)
  237. // if result.code == 200 {
  238. // result.success = true
  239. // complete(result)
  240. // } else {
  241. // result.success = false
  242. // complete(result)
  243. // }
  244. if Int(code)! == 200 {
  245. let wrapper = ResultWrapper(success: true, resultData: data)
  246. wrapper.content = data["fileKey"] as! String
  247. complete(wrapper)
  248. } else {
  249. let wrapper = ResultWrapper(success: false, resultData: data)
  250. if Int(code)! == 501 {
  251. wrapper.content = "501"
  252. } else {
  253. wrapper.content = message
  254. }
  255. complete(wrapper)
  256. }
  257. } else {
  258. // let error = NSError(domain: "unknown error", code: 404)
  259. // let result = ResultWrapper(success: false, result: [:], message: "unknown error", code: 404, error: error, state: .uploadTranslate)
  260. // complete(result)
  261. complete(ResultWrapper(success: false, content: "unknown error"))
  262. }
  263. }
  264. }
  265. /**
  266. @abstract 文件翻译
  267. @param fileKey 文件Key
  268. @param from 初始语言
  269. @param to 结束语言
  270. */
  271. func aiTranslationFileTranslateHandle(fileKey: String, from: String, to: String, complete: @escaping KMRequestServerComplete) {
  272. let infoDictionary = Bundle .main.infoDictionary!
  273. let urlString = AIInfoConfig().aiActionURL + "/api/AI/fileTranslate"
  274. let paraDict = ["fileKey": fileKey,
  275. "from": languageAbbreviation(from),
  276. "to": languageAbbreviation(to),
  277. "uuid": uuid(),
  278. "platform": platform(),
  279. "app_name": app_name()]
  280. var postData = try! JSONSerialization.data(withJSONObject: paraDict)
  281. var request = URLRequest(url: URL(string: urlString)!,timeoutInterval: Double.infinity)
  282. request.addValue("Apifox/1.0.0 (https://www.apifox.cn)", forHTTPHeaderField: "User-Agent")
  283. request.addValue("application/json", forHTTPHeaderField: "Content-Type")
  284. request.httpMethod = "POST"
  285. request.httpBody = postData
  286. let task = URLSession.shared.dataTask(with: request) { data, response, error in
  287. guard let data = data else {
  288. print(String(describing: error))
  289. return
  290. }
  291. let jsonObject = try? JSONSerialization.jsonObject(with: data, options: []) as? NSDictionary ?? [:]
  292. if jsonObject != nil {
  293. let data1: NSDictionary = jsonObject!["data"] as? NSDictionary ?? [:]
  294. let code: String = jsonObject!["code"] as? String ?? "06005"
  295. let message: String = jsonObject!["message"] as? String ?? "unknown error"
  296. let error = NSError(domain: message, code: Int(code)!)
  297. // let result = ResultWrapper(success: true, result: data1, message: message, code: Int(code)!, error: error, state: .fileTranslate)
  298. // if result.code == 200 {
  299. // result.success = true
  300. // complete(result)
  301. // } else {
  302. // result.success = false
  303. // complete(result)
  304. // }
  305. if Int(code)! == 200 {
  306. let fileUrl = data1["fileUrl"]
  307. let downFileUrl = data1["downFileUrl"]
  308. let ossDownUrl = data1["ossDownUrl"]
  309. let fileName = data1["fileName"]
  310. let downFileName = data1["downFileName"]
  311. let fromStr = data1["from"]
  312. let toStr = data1["to"]
  313. self.downFileName = downFileName as! String
  314. // self.downloadFile(filePath: ossDownUrl as! String, downFileName: downFileName as! String)
  315. complete(ResultWrapper(success: true, content: ossDownUrl as! String))
  316. } else {
  317. complete(ResultWrapper(success: false, content: message))
  318. }
  319. } else {
  320. // let error = NSError(domain: "unknown error", code: 404)
  321. // let result = ResultWrapper(success: false, result: [:], message: "unknown error", code: 404, error: error, state: .fileTranslate)
  322. // complete(result)
  323. complete(ResultWrapper(success: false, content: "unknown error"))
  324. }
  325. }
  326. task.resume()
  327. }
  328. /**
  329. @abstract 内容翻译
  330. @param q 选中
  331. @param from 初始语言
  332. @param to 结束语言
  333. */
  334. private func aiTranslationTextTrans(q: String, from: String, to: String, complete: @escaping KMRequestServerComplete) {
  335. let infoDictionary = Bundle .main.infoDictionary!
  336. let urlString = AIInfoConfig().aiActionURL + "/api/AI/textTranslate"
  337. var escapedString = q
  338. escapedString = String(data: escapedString.data(using: .utf8)!, encoding: .utf8)!
  339. let paraDict = ["text":escapedString,
  340. "from":from,
  341. "to":to,
  342. "uuid":uuid(),
  343. "platform": platform(),
  344. "app_name": app_name()]
  345. var postData = try! JSONSerialization.data(withJSONObject: paraDict)
  346. var request = URLRequest(url: URL(string: urlString)!,timeoutInterval: Double.infinity)
  347. request.addValue("Apifox/1.0.0 (https://www.apifox.cn)", forHTTPHeaderField: "User-Agent")
  348. request.addValue("application/json", forHTTPHeaderField: "Content-Type")
  349. request.httpMethod = "POST"
  350. request.httpBody = postData
  351. let task = URLSession.shared.dataTask(with: request) { data, response, error in
  352. guard let data = data else {
  353. print(String(describing: error))
  354. return
  355. }
  356. let jsonObject = try? JSONSerialization.jsonObject(with: data, options: []) as? NSDictionary ?? [:]
  357. if jsonObject != nil {
  358. let data1: NSDictionary = jsonObject!["data"] as? NSDictionary ?? [:]
  359. let code: String = jsonObject!["code"] as? String ?? "06005"
  360. let message: String = jsonObject!["message"] as? String ?? "unknown error"
  361. let error = NSError(domain: message, code: Int(code)!)
  362. if Int(code)! == 200 {
  363. var resultStr = data1["dst"] as! String
  364. complete(ResultWrapper(success: true, content: resultStr))
  365. } else {
  366. complete(ResultWrapper(success: false, content: message))
  367. }
  368. } else {
  369. complete(ResultWrapper(success: false, content: "unknown error"))
  370. }
  371. }
  372. task.resume()
  373. }
  374. /**
  375. @abstract重写 & 纠错
  376. @param content 内容
  377. @param state 类型
  378. */
  379. private func aiRewriting(content: String, state: KMAIRewritingState, complete: @escaping KMRequestServerComplete) {
  380. var urlString = AIInfoConfig().aiActionURL + "/api/AI/rewrite"
  381. if state == .correctTypos {
  382. urlString = AIInfoConfig().aiActionURL + "/api/AI/correctTypos"
  383. }
  384. let params: [String: Any] = ["content": content,
  385. "uuid": uuid(),
  386. "platform": platform(),
  387. "app_name": app_name()]
  388. KMAIRequestServer.requestServer.aiRewriting(urlString: urlString, params: params) { formData in
  389. } requestSerializer: { requestSerializer in
  390. requestSerializer.setValue("Apifox/1.0.0 (https://www.apifox.cn)", forHTTPHeaderField: "User-Agent")
  391. } completion: { task, responseObject, error in
  392. if responseObject != nil {
  393. let data: NSDictionary = responseObject!["data"] as? NSDictionary ?? [:]
  394. let code: String = responseObject!["code"] as? String ?? "06005"
  395. let message: String = responseObject!["message"] as? String ?? "unknown error"
  396. let error = NSError(domain: message, code: Int(code)!)
  397. // let result = ResultWrapper(success: true, result: data, message: message, code: Int(code)!, error: error, state: state)
  398. // if result.code == 200 {
  399. // result.success = true
  400. // complete(result)
  401. // } else {
  402. // result.success = false
  403. // complete(result)
  404. // }
  405. if Int(code)! == 200 {
  406. complete(ResultWrapper(success: true, content: data["content"] as! String))
  407. } else {
  408. complete(ResultWrapper(success: false, content: message))
  409. }
  410. } else {
  411. // let error = NSError(domain: "unknown error", code: 404)
  412. // let result = ResultWrapper(success: false, result: [:], message: "unknown error", code: 404, error: error, state: state)
  413. // complete(result)
  414. complete(ResultWrapper(success: false, content: "unknown error"))
  415. }
  416. }
  417. }
  418. /**
  419. @abstract 提取摘要
  420. @param file 文件路径
  421. */
  422. private func extractSummaryFile(file: String, complete: @escaping KMRequestServerComplete) {
  423. let infoDictionary = Bundle .main.infoDictionary!
  424. let urlString = AIInfoConfig().aiActionURL + "/api/AI/extractSummaryFile"
  425. let fileData = FileManager.default.contents(atPath: file)
  426. let params: [String: Any] = ["file": fileData,
  427. "uuid": uuid(),
  428. "platform": platform(),
  429. "app_name": app_name()]
  430. KMAIRequestServer.requestServer.uploadFile(urlString: urlString, params: params) { formData in
  431. let fileURL = URL(fileURLWithPath: file)
  432. try? formData.appendPart(withFileURL: fileURL, name: "file", fileName: fileURL.lastPathComponent, mimeType: "application/octet-stream")
  433. } requestSerializer: { requestSerializer in
  434. requestSerializer.setValue("Apifox/1.0.0 (https://www.apifox.cn)", forHTTPHeaderField: "User-Agent")
  435. } completion: { task, responseObject, error in
  436. if responseObject != nil {
  437. let data: NSDictionary = responseObject!["data"] as? NSDictionary ?? [:]
  438. let code: Int = responseObject!["code"] as? Int ?? 06005
  439. let message: String = responseObject!["message"] as? String ?? "unknown error"
  440. let error = NSError(domain: message, code: code)
  441. // let result = ResultWrapper(success: true, result: data, message: message, code: Int(code)!, error: error, state: .extractSummaryFile)
  442. // if result.code == 200 {
  443. // result.success = true
  444. // complete(result)
  445. // } else {
  446. // result.success = false
  447. // complete(result)
  448. // }
  449. if code == 200 {
  450. complete(ResultWrapper(success: true, content: data["summary"] as! String))
  451. } else {
  452. complete(ResultWrapper(success: false, content: message))
  453. }
  454. } else {
  455. let error = NSError(domain: "unknown error", code: 404)
  456. // let result = ResultWrapper(success: false, result: [:], message: "unknown error", code: 404, error: error, state: .extractSummaryFile)
  457. // complete(result)
  458. complete(ResultWrapper(success: false, content: "unknown error"))
  459. }
  460. }
  461. }
  462. }
  463. //typealias KMHttpRequestServerComplete = (_ task: URLSessionDataTask?, _ responseObject: AnyObject?, _ error: NSError?) -> Void
  464. class KMAIRequestServer {
  465. var sessionManager: AFHTTPSessionManager!
  466. static let requestServer = KMAIRequestServer()
  467. var task: URLSessionTask?
  468. init() {
  469. let configuration: URLSessionConfiguration = URLSessionConfiguration.default
  470. sessionManager = AFHTTPSessionManager.init(sessionConfiguration: configuration)
  471. sessionManager.securityPolicy = AFSecurityPolicy.default()
  472. }
  473. /**
  474. 上传文件
  475. - 翻译
  476. - 摘要提取
  477. */
  478. func uploadFile(urlString: String,
  479. params: Dictionary<String, Any>?,
  480. body: ((_ formData:AFMultipartFormData) -> Void)?,
  481. requestSerializer: ((_ requestSerializer:AFHTTPRequestSerializer) -> Void)?,
  482. completion: KMHttpRequestServerComplete?) -> Void {
  483. sessionManager.requestSerializer.setValue("multipart/form-data", forHTTPHeaderField: "Content-Type")
  484. sessionManager.requestSerializer.timeoutInterval = 60
  485. sessionManager.responseSerializer = AFJSONResponseSerializer()
  486. sessionManager.responseSerializer.acceptableContentTypes = ["application/json","text/html","text/json","text/javascript","text/plain","image/gif"]
  487. if (requestSerializer != nil) {
  488. requestSerializer!(sessionManager.requestSerializer);
  489. }
  490. if (body != nil) {
  491. self.task = sessionManager.post(urlString, parameters: params, headers: nil) { formData in
  492. body!(formData)
  493. } progress: { progress in
  494. } success: { task, responseObject in
  495. let responseObject = responseObject as AnyObject
  496. if (completion != nil) {
  497. completion!(task,responseObject,nil);
  498. }
  499. } failure: { task, error in
  500. if (completion != nil) {
  501. completion!(task, nil, error as NSError);
  502. }
  503. }
  504. } else {
  505. self.task = sessionManager.post(urlString, parameters: params, headers: nil) { progress in
  506. } success: { task, responseObject in
  507. if (completion != nil) {
  508. let responseObject = responseObject as AnyObject
  509. completion!(task,responseObject,nil);
  510. }
  511. } failure: { task, error in
  512. if (completion != nil) {
  513. completion!(task, nil, error as NSError);
  514. }
  515. }
  516. }
  517. }
  518. /**
  519. 文件翻译
  520. */
  521. func aiFileTranslateHandle(urlString: String,
  522. params: Dictionary<String, Any>?,
  523. body: ((_ formData:AFMultipartFormData) -> Void)?,
  524. requestSerializer: ((_ requestSerializer:AFHTTPRequestSerializer) -> Void)?,
  525. completion: KMHttpRequestServerComplete?) -> Void {
  526. sessionManager.requestSerializer = AFJSONRequestSerializer()
  527. sessionManager.responseSerializer = AFJSONResponseSerializer()
  528. sessionManager.responseSerializer.acceptableContentTypes = ["application/json","text/html","text/json","text/javascript","text/plain","image/gif"]
  529. if (requestSerializer != nil) {
  530. requestSerializer!(sessionManager.requestSerializer);
  531. }
  532. if (body != nil) {
  533. self.task = sessionManager.post(urlString, parameters: params, headers: nil) { formData in
  534. body!(formData)
  535. } progress: { progress in
  536. } success: { task, responseObject in
  537. let responseObject = responseObject as AnyObject
  538. if (completion != nil) {
  539. completion!(task,responseObject,nil);
  540. }
  541. } failure: { task, error in
  542. if (completion != nil) {
  543. completion!(task, nil, error as NSError);
  544. }
  545. }
  546. } else {
  547. self.task = sessionManager.post(urlString, parameters: params, headers: nil) { progress in
  548. } success: { task, responseObject in
  549. if (completion != nil) {
  550. let responseObject = responseObject as AnyObject
  551. completion!(task,responseObject,nil);
  552. }
  553. } failure: { task, error in
  554. if (completion != nil) {
  555. completion!(task, nil, error as NSError);
  556. }
  557. }
  558. }
  559. }
  560. /**
  561. 重写
  562. */
  563. func aiRewriting(urlString: String,
  564. params: Dictionary<String, Any>?,
  565. body: ((_ formData:AFMultipartFormData) -> Void)?,
  566. requestSerializer: ((_ requestSerializer:AFHTTPRequestSerializer) -> Void)?,
  567. completion: KMHttpRequestServerComplete?) -> Void {
  568. sessionManager.requestSerializer.setValue("multipart/form-data", forHTTPHeaderField: "Content-Type")
  569. sessionManager.requestSerializer.timeoutInterval = 60
  570. sessionManager.responseSerializer = AFJSONResponseSerializer()
  571. sessionManager.responseSerializer.acceptableContentTypes = ["application/json","text/html","text/json","text/javascript","text/plain","image/gif"]
  572. if (requestSerializer != nil) {
  573. requestSerializer!(sessionManager.requestSerializer);
  574. }
  575. if (body != nil) {
  576. self.task = sessionManager.post(urlString, parameters: params, headers: nil) { formData in
  577. body!(formData)
  578. } progress: { progress in
  579. } success: { task, responseObject in
  580. let responseObject = responseObject as AnyObject
  581. if (completion != nil) {
  582. completion!(task,responseObject,nil);
  583. }
  584. } failure: { task, error in
  585. if (completion != nil) {
  586. completion!(task, nil, error as NSError);
  587. }
  588. }
  589. } else {
  590. self.task = sessionManager.post(urlString, parameters: params, headers: nil) { progress in
  591. } success: { task, responseObject in
  592. if (completion != nil) {
  593. let responseObject = responseObject as AnyObject
  594. completion!(task,responseObject,nil);
  595. }
  596. } failure: { task, error in
  597. if (completion != nil) {
  598. completion!(task, nil, error as NSError);
  599. }
  600. }
  601. }
  602. }
  603. }