FileConverter.swift 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289
  1. //
  2. // FileConverter.swift
  3. // KdanAuto
  4. //
  5. // Created by 朱东勇 on 2022/12/21.
  6. //
  7. import Foundation
  8. import ComPDFKit_Conversion
  9. import PDFKit
  10. let KMComPDFKit_Conversion_FreeKey = "hw5vIMzKU2Im6cPijLjG45VAHy01ikUF5/GdAMdzCV8n2QTKNN0d8kG8crVbGYjIMsvVP+A9gx5g+W8qEi4ho0YTkGDratHOrX68W7khEBHAv7OEyRxIhlhBmdEQD+21lsRpIEW5zucUAF231lo3ZZiiT2s9CualDQJdAo1G0DI=";
  11. let KMComPDFKit_Conversion_FreeSecret = "mG0c3O3Mzeu5dkZJW3gpqh188cTuhYlGRPrbR/gfX4p9ms/F1zY6gZ1RBu8mNJH8zLwqe9EJswNmwV09TNi2IiIDeG7Ulx+U4pbeFB3/eYl2J6LePb3Kl54OsKlYiaf3Mv7C2jvq4o0q6sQtN3jR4897KG6mIUGJSRuOsvjYroVgMwna6EUx0K0SBmBGoFYDYkwcNWVMyYvggPV2rTFvfawopGIC034QzjthmhwwX90=";
  12. let KMPDFConvertOptionsKeyImageDPI = "KMPDFConvertOptionsKeyImageDPI"
  13. let KMPDFConvertOptionsKeyImageWithAnnotation = "KMPDFConvertOptionsKeyImageWithAnnotation"
  14. let kDefaultPassword = "666666"
  15. class FileConverter : NSObject, CPDFConverterDelegate, CPDFConverterFPDelegate {
  16. var pdfConverter:CPDFConverter?
  17. var fpConverter:CPDFConverterFP?
  18. var options:CPDFConvertOptions?
  19. var srcPath:String = ""
  20. var desPath:String = ""
  21. var pages:[Int] = []
  22. var pathExtension = ""
  23. var convertQueue = DispatchQueue.main
  24. var semaphore:DispatchSemaphore? = DispatchSemaphore.init(value: 0)
  25. var accessSemaphore:DispatchSemaphore? = DispatchSemaphore.init(value: 1)
  26. var didSuccess:Bool = false
  27. static var instance = FileConverter()
  28. class func shared() -> FileConverter {
  29. return instance
  30. }
  31. func converter(_ inSrcPath: String, inDesPath: String) -> Bool {
  32. return converter(inSrcPath, inDesPath: inDesPath, params: nil)
  33. }
  34. func converter(_ inSrcPath: String, inDesPath: String, params:NSDictionary?) -> Bool {
  35. if !FileManager.default.fileExists(atPath: inSrcPath) {
  36. return false
  37. }
  38. accessSemaphore?.wait()
  39. self.srcPath = inSrcPath
  40. self.desPath = inDesPath
  41. if FileManager.default.fileExists(atPath: desPath) {
  42. try! FileManager.default.removeItem(atPath: desPath)
  43. }
  44. let attributy = try! FileManager.default.attributesOfItem(atPath: srcPath)
  45. let fileType = attributy[FileAttributeKey.type] as! FileAttributeType
  46. if NSString(string: FileAttributeType.typeSymbolicLink.rawValue).isEqual(to: fileType.rawValue) {
  47. let symbolicLink = try? FileManager.default.destinationOfSymbolicLink(atPath: self.srcPath)
  48. if nil != symbolicLink {
  49. self.srcPath = symbolicLink!
  50. }
  51. }
  52. if FileManager.default.fileExists(atPath: self.desPath) {
  53. try! FileManager.default.removeItem(atPath: self.desPath)
  54. }
  55. self.pathExtension = NSString(string: self.desPath).pathExtension
  56. // let outputPath = NSString(string: self.desPath).deletingPathExtension
  57. // let output = self.desPath
  58. let password = params?.value(forKey: "password")
  59. let tParams = params as? NSDictionary
  60. let useOldLibValue = params?.value(forKey: "useOldLib")
  61. var useOldLib = false;
  62. if (nil != useOldLibValue) {
  63. if ((useOldLibValue as? String) != nil) {
  64. useOldLib = NSArray(array: ["TRUE", "true", "1"]).contains((useOldLibValue as! String))
  65. }else if ((useOldLibValue as? NSNumber) != nil) {
  66. useOldLib = (useOldLibValue as? NSNumber)!.boolValue || (useOldLibValue as? NSNumber)!.intValue == 1
  67. }
  68. }
  69. NSLog("%@ - %@", useOldLib ? "老库" : "新库", params ?? "")
  70. self.convertQueue.async {
  71. let url = URL.init(fileURLWithPath: self.srcPath, isDirectory: false)
  72. let document = PDFDocument(url: url)
  73. if document == nil {
  74. self.accessSemaphore?.signal()
  75. return
  76. }
  77. let pageCount = document!.pageCount
  78. self.pages = []
  79. for i in 1...pageCount {
  80. self.pages.append(i)
  81. }
  82. if !useOldLib && NSArray(array: ["jpg", "JPG", "png", "PNG"]).contains(self.pathExtension) {
  83. autoreleasepool {
  84. let cachePath = NSString(string: self.desPath).deletingPathExtension+".zip"
  85. self.pdfConverter = CPDFConverterImg.init(url: url, password: nil)
  86. if (nil == self.pdfConverter && nil != password) {
  87. self.pdfConverter = CPDFConverterImg.init(url: url, password: password as? String)
  88. }
  89. self.pdfConverter?.delegate = self
  90. self.options = CPDFConvertImgOptions()
  91. if (NSArray(array: ["jpg", "JPG"]).contains(self.pathExtension)) {
  92. (self.options as! CPDFConvertImgOptions).type = .JPEG
  93. }else {
  94. (self.options as! CPDFConvertImgOptions).type = .PNG
  95. }
  96. self.pdfConverter?.convert(toFilePath: cachePath, pageIndexs: self.pages, options: self.options)
  97. }
  98. }else if !useOldLib && NSArray(array: ["ppt", "PPT", "PPTX", "pptx"]).contains(self.pathExtension) {
  99. autoreleasepool {
  100. self.pdfConverter = CPDFConverterPPT.init(url: url, password: nil)
  101. if (nil == self.pdfConverter && nil != password) {
  102. self.pdfConverter = CPDFConverterPPT.init(url: url, password: password as? String)
  103. }
  104. self.pdfConverter?.delegate = self
  105. self.options = CPDFConvertPPTOptions()
  106. self.pdfConverter?.convert(toFilePath: self.desPath,
  107. pageIndexs: self.pages, options: self.options)
  108. }
  109. }else if !useOldLib && NSArray(array: ["doc", "DOC", "docx", "DOCX"]).contains(self.pathExtension) {
  110. autoreleasepool {
  111. self.pdfConverter = CPDFConverterWord.init(url: url, password: nil)
  112. if (nil == self.pdfConverter && nil != password) {
  113. self.pdfConverter = CPDFConverterWord.init(url: url, password: password as? String)
  114. }
  115. self.pdfConverter?.delegate = self
  116. self.options = CPDFConvertWordOptions()
  117. self.pdfConverter?.convert(toFilePath: self.desPath,
  118. pageIndexs: self.pages, options: self.options)
  119. }
  120. }else if !useOldLib && NSArray(array: ["xls", "XLS", "xlsx", "XLSX"]).contains(self.pathExtension) {
  121. autoreleasepool {
  122. self.pdfConverter = CPDFConverterExcel.init(url: url, password: nil)
  123. if (nil == self.pdfConverter && nil != password) {
  124. self.pdfConverter = CPDFConverterExcel.init(url: url, password: password as? String)
  125. }
  126. self.pdfConverter?.delegate = self
  127. self.options = CPDFConvertExcelOptions()
  128. self.pdfConverter?.convert(toFilePath: self.desPath,
  129. pageIndexs: self.pages, options: self.options)
  130. }
  131. }else if !useOldLib && NSArray(array: ["csv", "CSV"]).contains(self.pathExtension) {
  132. autoreleasepool {
  133. self.pdfConverter = CPDFConverterCsv.init(url: url, password: nil)
  134. if (nil == self.pdfConverter && nil != password) {
  135. self.pdfConverter = CPDFConverterCsv.init(url: url, password: password as? String)
  136. }
  137. self.pdfConverter?.delegate = self
  138. self.options = CPDFConvertCsvOptions()
  139. self.pdfConverter?.convert(toFilePath: self.desPath,
  140. pageIndexs: self.pages, options: self.options)
  141. }
  142. }else if !useOldLib && NSArray(array: ["html", "HTML"]).contains(self.pathExtension) {
  143. autoreleasepool {
  144. let cachePath = NSString(string: self.desPath).deletingPathExtension+".zip"
  145. self.pdfConverter = CPDFConverterHtml.init(url: url, password: nil)
  146. if (nil == self.pdfConverter && nil != password) {
  147. self.pdfConverter = CPDFConverterHtml.init(url: url, password: password as? String)
  148. }
  149. self.pdfConverter?.delegate = self
  150. self.options = CPDFConvertHtmlOptions()
  151. if ((tParams?.value(forKey: "paneOptions") as? NSNumber) != nil) {
  152. (self.options as! CPDFConvertHtmlOptions).paneOptions = CPDFConvertHtmlPageAndNavigationPaneOptions(rawValue: (tParams?.value(forKey: "paneOptions") as! NSNumber).intValue)!
  153. }
  154. self.pdfConverter?.convert(toFilePath: cachePath,
  155. pageIndexs: self.pages, options: self.options)
  156. }
  157. }else if !useOldLib && NSArray(array: ["rtf", "RTF"]).contains(self.pathExtension) {
  158. autoreleasepool {
  159. self.pdfConverter = CPDFConverterRtf.init(url: url, password: nil)
  160. if (nil == self.pdfConverter && nil != password) {
  161. self.pdfConverter = CPDFConverterRtf.init(url: url, password: password as? String)
  162. }
  163. self.pdfConverter?.delegate = self
  164. self.options = CPDFConvertRtfOptions()
  165. self.pdfConverter?.convert(toFilePath: self.desPath,
  166. pageIndexs: self.pages, options: self.options)
  167. }
  168. }else if !useOldLib && NSArray(array: ["txt", "TXT"]).contains(self.pathExtension) {
  169. autoreleasepool {
  170. self.pdfConverter = CPDFConverterTxt.init(url: url, password: nil)
  171. if (nil == self.pdfConverter && nil != password) {
  172. self.pdfConverter = CPDFConverterTxt.init(url: url, password: password as? String)
  173. }
  174. self.pdfConverter?.delegate = self
  175. self.options = CPDFConvertTxtOptions()
  176. self.pdfConverter?.convert(toFilePath: self.desPath,
  177. pageIndexs: self.pages, options: self.options)
  178. }
  179. }else {
  180. autoreleasepool {
  181. if self.fpConverter == nil {
  182. self.fpConverter = CPDFConverterFP.init()
  183. self.fpConverter?.setDelegate(self)
  184. }else {
  185. self.fpConverter?.stopConvertsionIfNeed()
  186. }
  187. var needMerge = NSArray(array: ["csv", "CSV"]).contains(self.pathExtension)
  188. let dpi = tParams?.value(forKey: "KMPDFConvertOptionsKeyImageDPI")
  189. if (needMerge && tParams?.value(forKey: "CPDFConvertOptionsKeyAllInOneSheet") != nil) {
  190. needMerge = (tParams?.value(forKey: "CPDFConvertOptionsKeyAllInOneSheet") as! NSNumber).boolValue
  191. }
  192. self.fpConverter?.convertPDF(atPath: self.srcPath,
  193. pdfPassword: password as? String,
  194. pdfPageIndexs: self.pages,
  195. destDocType: self.pathExtension,
  196. destDocPath: self.desPath,
  197. moreOptions: [
  198. "KMPDFConvertOptionsKeyImageDPI" : (dpi as? String) ?? "72",
  199. "CPDFConvertOptionsKeyAllInOneSheet":NSNumber(booleanLiteral: needMerge)
  200. ])
  201. }
  202. }
  203. }
  204. semaphore?.wait()
  205. accessSemaphore?.signal()
  206. return didSuccess
  207. }
  208. /// CPDFConverterDelegate
  209. func converter(_ converter: CPDFConverter!, didStartConvert error: Error!) {
  210. }
  211. func converter(_ converter: CPDFConverter!, didEndConvert error: Error!) {
  212. didSuccess = nil == error
  213. autoreleasepool {
  214. sleep(2)
  215. if NSArray(array: ["jpg", "JPG", "png", "PNG", "HTML", "html"]).contains(self.pathExtension) {
  216. let cachePath = NSString(string: self.desPath).deletingPathExtension+".zip"
  217. let zip = ZipArchive.init()
  218. zip.unzipOpenFile(cachePath)
  219. zip.unzipFile(to: self.desPath, overWrite: true)
  220. try? FileManager.default.removeItem(atPath: cachePath)
  221. }
  222. sleep(1)
  223. if self.pdfConverter?.isConverting == true {
  224. self.pdfConverter?.cancel()
  225. }
  226. self.pdfConverter?.delegate = nil
  227. self.pdfConverter = nil
  228. semaphore?.signal()
  229. }
  230. }
  231. func converter(_ converter: CPDFConverter!, pageIndex index: UInt, pageCount count: UInt) {
  232. }
  233. /// CPDFConverterFPDelegate
  234. func fppdfConverter(_ converter: Any!, didEndConversion error: Error!) {
  235. autoreleasepool {
  236. didSuccess = nil == error
  237. self.fpConverter?.stopConvertsionIfNeed()
  238. sleep(2)
  239. // self.fpConverter?.stopConvertsionIfNeed()
  240. // self.fpConverter?.setDelegate(nil)
  241. // self.fpConverter = nil
  242. //
  243. semaphore?.signal()
  244. }
  245. }
  246. }