libwz 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (362) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +165 -0
  3. package/binding.gyp +149 -0
  4. package/deps/tiny-aes/.github/workflows/c-cpp.yml +27 -0
  5. package/deps/tiny-aes/CMakeLists.txt +17 -0
  6. package/deps/tiny-aes/Makefile +61 -0
  7. package/deps/tiny-aes/README.md +83 -0
  8. package/deps/tiny-aes/aes.c +572 -0
  9. package/deps/tiny-aes/aes.h +91 -0
  10. package/deps/tiny-aes/aes.hpp +12 -0
  11. package/deps/tiny-aes/conanfile.py +73 -0
  12. package/deps/tiny-aes/library.json +19 -0
  13. package/deps/tiny-aes/library.properties +11 -0
  14. package/deps/tiny-aes/test.c +316 -0
  15. package/deps/tiny-aes/test.cpp +2 -0
  16. package/deps/tiny-aes/test_package/CMakeLists.txt +11 -0
  17. package/deps/tiny-aes/test_package/conanfile.py +17 -0
  18. package/deps/tiny-aes/unlicense.txt +24 -0
  19. package/deps/zlib/.cmake-format.yaml +245 -0
  20. package/deps/zlib/.github/workflows/c-std.yml +268 -0
  21. package/deps/zlib/.github/workflows/cmake.yml +147 -0
  22. package/deps/zlib/.github/workflows/configure.yml +146 -0
  23. package/deps/zlib/.github/workflows/contribs.yml +64 -0
  24. package/deps/zlib/.github/workflows/fuzz.yml +25 -0
  25. package/deps/zlib/.github/workflows/msys-cygwin.yml +92 -0
  26. package/deps/zlib/.github/workflows/others.yml +153 -0
  27. package/deps/zlib/BUILD.bazel +134 -0
  28. package/deps/zlib/CMakeLists.txt +310 -0
  29. package/deps/zlib/ChangeLog +1669 -0
  30. package/deps/zlib/FAQ +371 -0
  31. package/deps/zlib/INDEX +67 -0
  32. package/deps/zlib/LICENSE +22 -0
  33. package/deps/zlib/MODULE.bazel +9 -0
  34. package/deps/zlib/Makefile.in +426 -0
  35. package/deps/zlib/README +115 -0
  36. package/deps/zlib/README-cmake.md +79 -0
  37. package/deps/zlib/adler32.c +164 -0
  38. package/deps/zlib/amiga/Makefile.pup +69 -0
  39. package/deps/zlib/amiga/Makefile.sas +68 -0
  40. package/deps/zlib/compress.c +99 -0
  41. package/deps/zlib/configure +1078 -0
  42. package/deps/zlib/contrib/CMakeLists.txt +61 -0
  43. package/deps/zlib/contrib/README.contrib +57 -0
  44. package/deps/zlib/contrib/ada/CMakeLists.txt +217 -0
  45. package/deps/zlib/contrib/ada/buffer_demo.adb +106 -0
  46. package/deps/zlib/contrib/ada/cmake/Modules/CMakeADACompiler.cmake.in +23 -0
  47. package/deps/zlib/contrib/ada/cmake/Modules/CMakeADAInformation.cmake +133 -0
  48. package/deps/zlib/contrib/ada/cmake/Modules/CMakeDetermineADACompiler.cmake +33 -0
  49. package/deps/zlib/contrib/ada/cmake/Modules/CMakeTestADACompiler.cmake +46 -0
  50. package/deps/zlib/contrib/ada/cmake/binder_helper.cmake +47 -0
  51. package/deps/zlib/contrib/ada/cmake/compile_helper.cmake +32 -0
  52. package/deps/zlib/contrib/ada/cmake/exe_link_helper.cmake +53 -0
  53. package/deps/zlib/contrib/ada/cmake/shared_link_helper.cmake +52 -0
  54. package/deps/zlib/contrib/ada/cmake/static_link_helper.cmake +25 -0
  55. package/deps/zlib/contrib/ada/mtest.adb +156 -0
  56. package/deps/zlib/contrib/ada/read.adb +156 -0
  57. package/deps/zlib/contrib/ada/readme.txt +65 -0
  58. package/deps/zlib/contrib/ada/test.adb +463 -0
  59. package/deps/zlib/contrib/ada/zlib-streams.adb +225 -0
  60. package/deps/zlib/contrib/ada/zlib-streams.ads +114 -0
  61. package/deps/zlib/contrib/ada/zlib-thin.adb +142 -0
  62. package/deps/zlib/contrib/ada/zlib-thin.ads +450 -0
  63. package/deps/zlib/contrib/ada/zlib.adb +701 -0
  64. package/deps/zlib/contrib/ada/zlib.ads +328 -0
  65. package/deps/zlib/contrib/ada/zlib.gpr +20 -0
  66. package/deps/zlib/contrib/blast/CMakeLists.txt +166 -0
  67. package/deps/zlib/contrib/blast/Makefile +14 -0
  68. package/deps/zlib/contrib/blast/README +4 -0
  69. package/deps/zlib/contrib/blast/blast-test.c +42 -0
  70. package/deps/zlib/contrib/blast/blast.c +422 -0
  71. package/deps/zlib/contrib/blast/blast.h +84 -0
  72. package/deps/zlib/contrib/blast/blastConfig.cmake.in +18 -0
  73. package/deps/zlib/contrib/blast/test/CMakeLists.txt +193 -0
  74. package/deps/zlib/contrib/blast/test/add_subdirectory_exclude_test.cmake.in +27 -0
  75. package/deps/zlib/contrib/blast/test/add_subdirectory_test.cmake.in +25 -0
  76. package/deps/zlib/contrib/blast/test/find_package_no_components_test.cmake.in +24 -0
  77. package/deps/zlib/contrib/blast/test/find_package_test.cmake.in +24 -0
  78. package/deps/zlib/contrib/blast/test/find_package_wrong_components_test.cmake.in +24 -0
  79. package/deps/zlib/contrib/blast/test.pk +0 -0
  80. package/deps/zlib/contrib/blast/test.txt +1 -0
  81. package/deps/zlib/contrib/blast/tester.cmake +28 -0
  82. package/deps/zlib/contrib/crc32vx/CMakeLists.txt +67 -0
  83. package/deps/zlib/contrib/crc32vx/README +9 -0
  84. package/deps/zlib/contrib/crc32vx/crc32_vx.c +254 -0
  85. package/deps/zlib/contrib/crc32vx/crc32_vx_hooks.h +9 -0
  86. package/deps/zlib/contrib/delphi/ZLib.pas +557 -0
  87. package/deps/zlib/contrib/delphi/ZLibConst.pas +11 -0
  88. package/deps/zlib/contrib/delphi/readme.txt +76 -0
  89. package/deps/zlib/contrib/delphi/zlibd32.mak +99 -0
  90. package/deps/zlib/contrib/dotzlib/DotZLib/AssemblyInfo.cs +58 -0
  91. package/deps/zlib/contrib/dotzlib/DotZLib/ChecksumImpl.cs +202 -0
  92. package/deps/zlib/contrib/dotzlib/DotZLib/CircularBuffer.cs +83 -0
  93. package/deps/zlib/contrib/dotzlib/DotZLib/CodecBase.cs +198 -0
  94. package/deps/zlib/contrib/dotzlib/DotZLib/Deflater.cs +106 -0
  95. package/deps/zlib/contrib/dotzlib/DotZLib/DotZLib.cs +288 -0
  96. package/deps/zlib/contrib/dotzlib/DotZLib/DotZLib.csproj +141 -0
  97. package/deps/zlib/contrib/dotzlib/DotZLib/GZipStream.cs +301 -0
  98. package/deps/zlib/contrib/dotzlib/DotZLib/Inflater.cs +105 -0
  99. package/deps/zlib/contrib/dotzlib/DotZLib/UnitTests.cs +274 -0
  100. package/deps/zlib/contrib/dotzlib/DotZLib.build +33 -0
  101. package/deps/zlib/contrib/dotzlib/DotZLib.chm +0 -0
  102. package/deps/zlib/contrib/dotzlib/DotZLib.sln +21 -0
  103. package/deps/zlib/contrib/dotzlib/LICENSE_1_0.txt +23 -0
  104. package/deps/zlib/contrib/dotzlib/readme.txt +58 -0
  105. package/deps/zlib/contrib/gcc_gvmat64/CMakeLists.txt +19 -0
  106. package/deps/zlib/contrib/gcc_gvmat64/gvmat64.S +570 -0
  107. package/deps/zlib/contrib/infback9/CMakeLists.txt +19 -0
  108. package/deps/zlib/contrib/infback9/README +1 -0
  109. package/deps/zlib/contrib/infback9/infback9.c +603 -0
  110. package/deps/zlib/contrib/infback9/infback9.h +37 -0
  111. package/deps/zlib/contrib/infback9/inffix9.h +107 -0
  112. package/deps/zlib/contrib/infback9/inflate9.h +47 -0
  113. package/deps/zlib/contrib/infback9/inftree9.c +319 -0
  114. package/deps/zlib/contrib/infback9/inftree9.h +61 -0
  115. package/deps/zlib/contrib/iostream/test.cpp +24 -0
  116. package/deps/zlib/contrib/iostream/zfstream.cpp +329 -0
  117. package/deps/zlib/contrib/iostream/zfstream.h +128 -0
  118. package/deps/zlib/contrib/iostream2/zstream.h +306 -0
  119. package/deps/zlib/contrib/iostream2/zstream_test.cpp +25 -0
  120. package/deps/zlib/contrib/iostream3/CMakeLists.txt +200 -0
  121. package/deps/zlib/contrib/iostream3/README +35 -0
  122. package/deps/zlib/contrib/iostream3/TODO +17 -0
  123. package/deps/zlib/contrib/iostream3/iostream3Config.cmake.in +23 -0
  124. package/deps/zlib/contrib/iostream3/test/CMakeLists.txt +191 -0
  125. package/deps/zlib/contrib/iostream3/test/add_subdirectory_exclude_test.cmake.in +27 -0
  126. package/deps/zlib/contrib/iostream3/test/add_subdirectory_test.cmake.in +25 -0
  127. package/deps/zlib/contrib/iostream3/test/find_package_no_components_test.cmake.in +24 -0
  128. package/deps/zlib/contrib/iostream3/test/find_package_test.cmake.in +24 -0
  129. package/deps/zlib/contrib/iostream3/test/find_package_wrong_components_test.cmake.in +24 -0
  130. package/deps/zlib/contrib/iostream3/test.cc +50 -0
  131. package/deps/zlib/contrib/iostream3/zfstream.cc +479 -0
  132. package/deps/zlib/contrib/iostream3/zfstream.h +466 -0
  133. package/deps/zlib/contrib/minizip/CMakeLists.txt +387 -0
  134. package/deps/zlib/contrib/minizip/LICENSE.Info-Zip +58 -0
  135. package/deps/zlib/contrib/minizip/Makefile +33 -0
  136. package/deps/zlib/contrib/minizip/Makefile.am +45 -0
  137. package/deps/zlib/contrib/minizip/MiniZip64_Changes.txt +6 -0
  138. package/deps/zlib/contrib/minizip/MiniZip64_info.txt +69 -0
  139. package/deps/zlib/contrib/minizip/configure.ac +32 -0
  140. package/deps/zlib/contrib/minizip/crypt.h +125 -0
  141. package/deps/zlib/contrib/minizip/ints.h +57 -0
  142. package/deps/zlib/contrib/minizip/ioapi.c +231 -0
  143. package/deps/zlib/contrib/minizip/ioapi.h +183 -0
  144. package/deps/zlib/contrib/minizip/iowin32.c +447 -0
  145. package/deps/zlib/contrib/minizip/iowin32.h +27 -0
  146. package/deps/zlib/contrib/minizip/make_vms.com +25 -0
  147. package/deps/zlib/contrib/minizip/miniunz.c +647 -0
  148. package/deps/zlib/contrib/minizip/miniunzip.1 +63 -0
  149. package/deps/zlib/contrib/minizip/minizip.1 +46 -0
  150. package/deps/zlib/contrib/minizip/minizip.c +511 -0
  151. package/deps/zlib/contrib/minizip/minizip.pc.in +13 -0
  152. package/deps/zlib/contrib/minizip/minizip.pc.txt +13 -0
  153. package/deps/zlib/contrib/minizip/minizipConfig.cmake.in +27 -0
  154. package/deps/zlib/contrib/minizip/mztools.c +294 -0
  155. package/deps/zlib/contrib/minizip/mztools.h +37 -0
  156. package/deps/zlib/contrib/minizip/skipset.h +366 -0
  157. package/deps/zlib/contrib/minizip/test/CMakeLists.txt +176 -0
  158. package/deps/zlib/contrib/minizip/test/add_subdirectory_exclude_test.cmake.in +29 -0
  159. package/deps/zlib/contrib/minizip/test/add_subdirectory_test.cmake.in +28 -0
  160. package/deps/zlib/contrib/minizip/test/find_package_no_components_test.cmake.in +26 -0
  161. package/deps/zlib/contrib/minizip/test/find_package_test.cmake.in +26 -0
  162. package/deps/zlib/contrib/minizip/test/find_package_wrong_components_test.cmake.in +26 -0
  163. package/deps/zlib/contrib/minizip/test/test_helper.cm +32 -0
  164. package/deps/zlib/contrib/minizip/unzip.c +1984 -0
  165. package/deps/zlib/contrib/minizip/unzip.h +442 -0
  166. package/deps/zlib/contrib/minizip/zip.c +2246 -0
  167. package/deps/zlib/contrib/minizip/zip.h +371 -0
  168. package/deps/zlib/contrib/nuget/nuget.csproj +45 -0
  169. package/deps/zlib/contrib/nuget/nuget.sln +22 -0
  170. package/deps/zlib/contrib/pascal/example.pas +599 -0
  171. package/deps/zlib/contrib/pascal/readme.txt +76 -0
  172. package/deps/zlib/contrib/pascal/zlibd32.mak +99 -0
  173. package/deps/zlib/contrib/pascal/zlibpas.pas +276 -0
  174. package/deps/zlib/contrib/puff/CMakeLists.txt +154 -0
  175. package/deps/zlib/contrib/puff/Makefile +42 -0
  176. package/deps/zlib/contrib/puff/README +63 -0
  177. package/deps/zlib/contrib/puff/bin-writer.c +26 -0
  178. package/deps/zlib/contrib/puff/puff.c +840 -0
  179. package/deps/zlib/contrib/puff/puff.h +35 -0
  180. package/deps/zlib/contrib/puff/puffConfig.cmake.in +18 -0
  181. package/deps/zlib/contrib/puff/pufftest.c +168 -0
  182. package/deps/zlib/contrib/puff/test/CMakeLists.txt +262 -0
  183. package/deps/zlib/contrib/puff/test/add_subdirectory_exclude_test.cmake.in +26 -0
  184. package/deps/zlib/contrib/puff/test/add_subdirectory_test.cmake.in +25 -0
  185. package/deps/zlib/contrib/puff/test/find_package_no_components_test.cmake.in +24 -0
  186. package/deps/zlib/contrib/puff/test/find_package_test.cmake.in +24 -0
  187. package/deps/zlib/contrib/puff/test/find_package_wrong_components_test.cmake.in +24 -0
  188. package/deps/zlib/contrib/puff/test/tester-cov.cmake +58 -0
  189. package/deps/zlib/contrib/puff/test/tester.cmake +16 -0
  190. package/deps/zlib/contrib/puff/zeros.raw +0 -0
  191. package/deps/zlib/contrib/testzlib/CMakeLists.txt +44 -0
  192. package/deps/zlib/contrib/testzlib/testzlib.c +275 -0
  193. package/deps/zlib/contrib/testzlib/testzlib.txt +10 -0
  194. package/deps/zlib/contrib/vstudio/readme.txt +22 -0
  195. package/deps/zlib/contrib/zlib1-dll/CMakeLists.txt +196 -0
  196. package/deps/zlib/contrib/zlib1-dll/readme.txt +21 -0
  197. package/deps/zlib/crc32.c +983 -0
  198. package/deps/zlib/crc32.h +9446 -0
  199. package/deps/zlib/deflate.c +2185 -0
  200. package/deps/zlib/deflate.h +383 -0
  201. package/deps/zlib/doc/algorithm.txt +209 -0
  202. package/deps/zlib/doc/crc-doc.1.0.pdf +0 -0
  203. package/deps/zlib/doc/rfc1950.txt +619 -0
  204. package/deps/zlib/doc/rfc1951.txt +955 -0
  205. package/deps/zlib/doc/rfc1952.txt +675 -0
  206. package/deps/zlib/doc/txtvsbin.txt +107 -0
  207. package/deps/zlib/examples/README.examples +54 -0
  208. package/deps/zlib/examples/enough.c +597 -0
  209. package/deps/zlib/examples/fitblk.c +233 -0
  210. package/deps/zlib/examples/gun.c +702 -0
  211. package/deps/zlib/examples/gzappend.c +504 -0
  212. package/deps/zlib/examples/gzjoin.c +449 -0
  213. package/deps/zlib/examples/gzlog.c +1061 -0
  214. package/deps/zlib/examples/gzlog.h +91 -0
  215. package/deps/zlib/examples/gznorm.c +474 -0
  216. package/deps/zlib/examples/zlib_how.html +550 -0
  217. package/deps/zlib/examples/zpipe.c +206 -0
  218. package/deps/zlib/examples/zran.c +546 -0
  219. package/deps/zlib/examples/zran.h +53 -0
  220. package/deps/zlib/gzclose.c +23 -0
  221. package/deps/zlib/gzguts.h +216 -0
  222. package/deps/zlib/gzlib.c +609 -0
  223. package/deps/zlib/gzread.c +668 -0
  224. package/deps/zlib/gzwrite.c +700 -0
  225. package/deps/zlib/infback.c +581 -0
  226. package/deps/zlib/inffast.c +321 -0
  227. package/deps/zlib/inffast.h +11 -0
  228. package/deps/zlib/inffixed.h +94 -0
  229. package/deps/zlib/inflate.c +1413 -0
  230. package/deps/zlib/inflate.h +126 -0
  231. package/deps/zlib/inftrees.c +424 -0
  232. package/deps/zlib/inftrees.h +64 -0
  233. package/deps/zlib/make_vms.com +867 -0
  234. package/deps/zlib/msdos/Makefile.bor +115 -0
  235. package/deps/zlib/msdos/Makefile.dj2 +104 -0
  236. package/deps/zlib/msdos/Makefile.emx +69 -0
  237. package/deps/zlib/msdos/Makefile.msc +112 -0
  238. package/deps/zlib/msdos/Makefile.tc +100 -0
  239. package/deps/zlib/os400/README400 +48 -0
  240. package/deps/zlib/os400/bndsrc +144 -0
  241. package/deps/zlib/os400/make.sh +383 -0
  242. package/deps/zlib/os400/zlibfixed.rpgle +578 -0
  243. package/deps/zlib/os400/zlibfree.rpgle +634 -0
  244. package/deps/zlib/qnx/package.qpg +141 -0
  245. package/deps/zlib/test/CMakeLists.txt +318 -0
  246. package/deps/zlib/test/add_subdirectory_exclude_test.cmake.in +29 -0
  247. package/deps/zlib/test/add_subdirectory_test.cmake.in +28 -0
  248. package/deps/zlib/test/example.c +552 -0
  249. package/deps/zlib/test/find_package_no_components_test.cmake.in +27 -0
  250. package/deps/zlib/test/find_package_test.cmake.in +27 -0
  251. package/deps/zlib/test/find_package_wrong_components_test.cmake.in +27 -0
  252. package/deps/zlib/test/infcover.c +672 -0
  253. package/deps/zlib/test/minigzip.c +592 -0
  254. package/deps/zlib/treebuild.xml +116 -0
  255. package/deps/zlib/trees.c +1119 -0
  256. package/deps/zlib/trees.h +128 -0
  257. package/deps/zlib/uncompr.c +101 -0
  258. package/deps/zlib/watcom/watcom_f.mak +43 -0
  259. package/deps/zlib/watcom/watcom_l.mak +43 -0
  260. package/deps/zlib/win32/DLL_FAQ.txt +381 -0
  261. package/deps/zlib/win32/Makefile.bor +109 -0
  262. package/deps/zlib/win32/Makefile.gcc +177 -0
  263. package/deps/zlib/win32/Makefile.msc +159 -0
  264. package/deps/zlib/win32/README-WIN32.txt +103 -0
  265. package/deps/zlib/win32/VisualC.txt +3 -0
  266. package/deps/zlib/win32/zlib.def +104 -0
  267. package/deps/zlib/win32/zlib1.rc +37 -0
  268. package/deps/zlib/zconf.h.in +551 -0
  269. package/deps/zlib/zlib.3 +149 -0
  270. package/deps/zlib/zlib.3.pdf +0 -0
  271. package/deps/zlib/zlib.h +2057 -0
  272. package/deps/zlib/zlib.map +116 -0
  273. package/deps/zlib/zlib.pc.cmakein +14 -0
  274. package/deps/zlib/zlib.pc.in +14 -0
  275. package/deps/zlib/zlibConfig.cmake.in +18 -0
  276. package/deps/zlib/zutil.c +313 -0
  277. package/deps/zlib/zutil.h +331 -0
  278. package/dist/index.d.ts +266 -0
  279. package/dist/index.js +1146 -0
  280. package/dist/libwz.js +5632 -0
  281. package/dist/libwz.wasm +0 -0
  282. package/include/wz/CRC32.h +182 -0
  283. package/include/wz/PngUtility.h +72 -0
  284. package/include/wz/PortalType.h +124 -0
  285. package/include/wz/Properties/WzBinaryProperty.h +70 -0
  286. package/include/wz/Properties/WzCanvasProperty.h +55 -0
  287. package/include/wz/Properties/WzConvexProperty.h +34 -0
  288. package/include/wz/Properties/WzDoubleProperty.h +32 -0
  289. package/include/wz/Properties/WzFloatProperty.h +30 -0
  290. package/include/wz/Properties/WzIntProperty.h +30 -0
  291. package/include/wz/Properties/WzLongProperty.h +30 -0
  292. package/include/wz/Properties/WzLuaProperty.h +31 -0
  293. package/include/wz/Properties/WzNullProperty.h +15 -0
  294. package/include/wz/Properties/WzPngProperty.h +53 -0
  295. package/include/wz/Properties/WzRawDataProperty.h +46 -0
  296. package/include/wz/Properties/WzShortProperty.h +31 -0
  297. package/include/wz/Properties/WzStringProperty.h +32 -0
  298. package/include/wz/Properties/WzSubProperty.h +35 -0
  299. package/include/wz/Properties/WzUOLProperty.h +44 -0
  300. package/include/wz/Properties/WzVectorProperty.h +40 -0
  301. package/include/wz/Properties/WzVideoProperty.h +43 -0
  302. package/include/wz/Result.h +58 -0
  303. package/include/wz/Util/Defines.h +16 -0
  304. package/include/wz/Util/ListFileParser.h +20 -0
  305. package/include/wz/Util/WzBinaryReader.h +95 -0
  306. package/include/wz/Util/WzBinaryWriter.h +72 -0
  307. package/include/wz/Util/WzBlobDataSource.h +30 -0
  308. package/include/wz/Util/WzDataSource.h +49 -0
  309. package/include/wz/Util/WzKeyGenerator.h +28 -0
  310. package/include/wz/Util/WzMutableKey.h +39 -0
  311. package/include/wz/Util/WzPath.h +37 -0
  312. package/include/wz/Util/WzStream.h +86 -0
  313. package/include/wz/Util/WzTool.h +42 -0
  314. package/include/wz/WzAESConstant.h +17 -0
  315. package/include/wz/WzDirectory.h +97 -0
  316. package/include/wz/WzEnums.h +76 -0
  317. package/include/wz/WzFile.h +99 -0
  318. package/include/wz/WzHeader.h +47 -0
  319. package/include/wz/WzImage.h +97 -0
  320. package/include/wz/WzImageProperty.h +92 -0
  321. package/include/wz/WzObject.h +55 -0
  322. package/include/wz/WzPropertyCollection.h +115 -0
  323. package/include/wz/wz.h +41 -0
  324. package/include/wz/wz_api.h +432 -0
  325. package/package.json +93 -0
  326. package/src/PngUtility.cpp +328 -0
  327. package/src/Properties/WzBinaryProperty.cpp +183 -0
  328. package/src/Properties/WzCanvasProperty.cpp +262 -0
  329. package/src/Properties/WzConvexProperty.cpp +159 -0
  330. package/src/Properties/WzDoubleProperty.cpp +12 -0
  331. package/src/Properties/WzFloatProperty.cpp +17 -0
  332. package/src/Properties/WzIntProperty.cpp +12 -0
  333. package/src/Properties/WzLongProperty.cpp +12 -0
  334. package/src/Properties/WzLuaProperty.cpp +37 -0
  335. package/src/Properties/WzNullProperty.cpp +11 -0
  336. package/src/Properties/WzPngProperty.cpp +637 -0
  337. package/src/Properties/WzRawDataProperty.cpp +116 -0
  338. package/src/Properties/WzShortProperty.cpp +12 -0
  339. package/src/Properties/WzStringProperty.cpp +44 -0
  340. package/src/Properties/WzSubProperty.cpp +129 -0
  341. package/src/Properties/WzUOLProperty.cpp +136 -0
  342. package/src/Properties/WzVectorProperty.cpp +22 -0
  343. package/src/Properties/WzVideoProperty.cpp +115 -0
  344. package/src/Util/ListFileParser.cpp +48 -0
  345. package/src/Util/WzBinaryReader.cpp +368 -0
  346. package/src/Util/WzBinaryWriter.cpp +305 -0
  347. package/src/Util/WzBlobDataSource.cpp +47 -0
  348. package/src/Util/WzDataSource.cpp +61 -0
  349. package/src/Util/WzKeyGenerator.cpp +43 -0
  350. package/src/Util/WzMutableKey.cpp +59 -0
  351. package/src/Util/WzStream.cpp +196 -0
  352. package/src/Util/WzTool.cpp +266 -0
  353. package/src/WzAESConstant.cpp +12 -0
  354. package/src/WzDirectory.cpp +669 -0
  355. package/src/WzEnums.cpp +20 -0
  356. package/src/WzFile.cpp +450 -0
  357. package/src/WzImage.cpp +350 -0
  358. package/src/WzImageProperty.cpp +469 -0
  359. package/src/WzObject.cpp +174 -0
  360. package/src/WzPropertyCollection.cpp +84 -0
  361. package/src/capi/wz_api.cpp +1996 -0
  362. package/src/node/binding.cpp +1776 -0
@@ -0,0 +1,572 @@
1
+ /*
2
+
3
+ This is an implementation of the AES algorithm, specifically ECB, CTR and CBC mode.
4
+ Block size can be chosen in aes.h - available choices are AES128, AES192, AES256.
5
+
6
+ The implementation is verified against the test vectors in:
7
+ National Institute of Standards and Technology Special Publication 800-38A 2001 ED
8
+
9
+ ECB-AES128
10
+ ----------
11
+
12
+ plain-text:
13
+ 6bc1bee22e409f96e93d7e117393172a
14
+ ae2d8a571e03ac9c9eb76fac45af8e51
15
+ 30c81c46a35ce411e5fbc1191a0a52ef
16
+ f69f2445df4f9b17ad2b417be66c3710
17
+
18
+ key:
19
+ 2b7e151628aed2a6abf7158809cf4f3c
20
+
21
+ resulting cipher
22
+ 3ad77bb40d7a3660a89ecaf32466ef97
23
+ f5d3d58503b9699de785895a96fdbaaf
24
+ 43b1cd7f598ece23881b00e3ed030688
25
+ 7b0c785e27e8ad3f8223207104725dd4
26
+
27
+
28
+ NOTE: String length must be evenly divisible by 16byte (str_len % 16 == 0)
29
+ You should pad the end of the string with zeros if this is not the case.
30
+ For AES192/256 the key size is proportionally larger.
31
+
32
+ */
33
+
34
+
35
+ /*****************************************************************************/
36
+ /* Includes: */
37
+ /*****************************************************************************/
38
+ #include <string.h> // CBC mode, for memset
39
+ #include "aes.h"
40
+
41
+ /*****************************************************************************/
42
+ /* Defines: */
43
+ /*****************************************************************************/
44
+ // The number of columns comprising a state in AES. This is a constant in AES. Value=4
45
+ #define Nb 4
46
+
47
+ #if defined(AES256) && (AES256 == 1)
48
+ #define Nk 8
49
+ #define Nr 14
50
+ #elif defined(AES192) && (AES192 == 1)
51
+ #define Nk 6
52
+ #define Nr 12
53
+ #else
54
+ #define Nk 4 // The number of 32 bit words in a key.
55
+ #define Nr 10 // The number of rounds in AES Cipher.
56
+ #endif
57
+
58
+ // jcallan@github points out that declaring Multiply as a function
59
+ // reduces code size considerably with the Keil ARM compiler.
60
+ // See this link for more information: https://github.com/kokke/tiny-AES-C/pull/3
61
+ #ifndef MULTIPLY_AS_A_FUNCTION
62
+ #define MULTIPLY_AS_A_FUNCTION 0
63
+ #endif
64
+
65
+
66
+
67
+
68
+ /*****************************************************************************/
69
+ /* Private variables: */
70
+ /*****************************************************************************/
71
+ // state - array holding the intermediate results during decryption.
72
+ typedef uint8_t state_t[4][4];
73
+
74
+
75
+
76
+ // The lookup-tables are marked const so they can be placed in read-only storage instead of RAM
77
+ // The numbers below can be computed dynamically trading ROM for RAM -
78
+ // This can be useful in (embedded) bootloader applications, where ROM is often limited.
79
+ static const uint8_t sbox[256] = {
80
+ //0 1 2 3 4 5 6 7 8 9 A B C D E F
81
+ 0x63, 0x7c, 0x77, 0x7b, 0xf2, 0x6b, 0x6f, 0xc5, 0x30, 0x01, 0x67, 0x2b, 0xfe, 0xd7, 0xab, 0x76,
82
+ 0xca, 0x82, 0xc9, 0x7d, 0xfa, 0x59, 0x47, 0xf0, 0xad, 0xd4, 0xa2, 0xaf, 0x9c, 0xa4, 0x72, 0xc0,
83
+ 0xb7, 0xfd, 0x93, 0x26, 0x36, 0x3f, 0xf7, 0xcc, 0x34, 0xa5, 0xe5, 0xf1, 0x71, 0xd8, 0x31, 0x15,
84
+ 0x04, 0xc7, 0x23, 0xc3, 0x18, 0x96, 0x05, 0x9a, 0x07, 0x12, 0x80, 0xe2, 0xeb, 0x27, 0xb2, 0x75,
85
+ 0x09, 0x83, 0x2c, 0x1a, 0x1b, 0x6e, 0x5a, 0xa0, 0x52, 0x3b, 0xd6, 0xb3, 0x29, 0xe3, 0x2f, 0x84,
86
+ 0x53, 0xd1, 0x00, 0xed, 0x20, 0xfc, 0xb1, 0x5b, 0x6a, 0xcb, 0xbe, 0x39, 0x4a, 0x4c, 0x58, 0xcf,
87
+ 0xd0, 0xef, 0xaa, 0xfb, 0x43, 0x4d, 0x33, 0x85, 0x45, 0xf9, 0x02, 0x7f, 0x50, 0x3c, 0x9f, 0xa8,
88
+ 0x51, 0xa3, 0x40, 0x8f, 0x92, 0x9d, 0x38, 0xf5, 0xbc, 0xb6, 0xda, 0x21, 0x10, 0xff, 0xf3, 0xd2,
89
+ 0xcd, 0x0c, 0x13, 0xec, 0x5f, 0x97, 0x44, 0x17, 0xc4, 0xa7, 0x7e, 0x3d, 0x64, 0x5d, 0x19, 0x73,
90
+ 0x60, 0x81, 0x4f, 0xdc, 0x22, 0x2a, 0x90, 0x88, 0x46, 0xee, 0xb8, 0x14, 0xde, 0x5e, 0x0b, 0xdb,
91
+ 0xe0, 0x32, 0x3a, 0x0a, 0x49, 0x06, 0x24, 0x5c, 0xc2, 0xd3, 0xac, 0x62, 0x91, 0x95, 0xe4, 0x79,
92
+ 0xe7, 0xc8, 0x37, 0x6d, 0x8d, 0xd5, 0x4e, 0xa9, 0x6c, 0x56, 0xf4, 0xea, 0x65, 0x7a, 0xae, 0x08,
93
+ 0xba, 0x78, 0x25, 0x2e, 0x1c, 0xa6, 0xb4, 0xc6, 0xe8, 0xdd, 0x74, 0x1f, 0x4b, 0xbd, 0x8b, 0x8a,
94
+ 0x70, 0x3e, 0xb5, 0x66, 0x48, 0x03, 0xf6, 0x0e, 0x61, 0x35, 0x57, 0xb9, 0x86, 0xc1, 0x1d, 0x9e,
95
+ 0xe1, 0xf8, 0x98, 0x11, 0x69, 0xd9, 0x8e, 0x94, 0x9b, 0x1e, 0x87, 0xe9, 0xce, 0x55, 0x28, 0xdf,
96
+ 0x8c, 0xa1, 0x89, 0x0d, 0xbf, 0xe6, 0x42, 0x68, 0x41, 0x99, 0x2d, 0x0f, 0xb0, 0x54, 0xbb, 0x16 };
97
+
98
+ #if (defined(CBC) && CBC == 1) || (defined(ECB) && ECB == 1)
99
+ static const uint8_t rsbox[256] = {
100
+ 0x52, 0x09, 0x6a, 0xd5, 0x30, 0x36, 0xa5, 0x38, 0xbf, 0x40, 0xa3, 0x9e, 0x81, 0xf3, 0xd7, 0xfb,
101
+ 0x7c, 0xe3, 0x39, 0x82, 0x9b, 0x2f, 0xff, 0x87, 0x34, 0x8e, 0x43, 0x44, 0xc4, 0xde, 0xe9, 0xcb,
102
+ 0x54, 0x7b, 0x94, 0x32, 0xa6, 0xc2, 0x23, 0x3d, 0xee, 0x4c, 0x95, 0x0b, 0x42, 0xfa, 0xc3, 0x4e,
103
+ 0x08, 0x2e, 0xa1, 0x66, 0x28, 0xd9, 0x24, 0xb2, 0x76, 0x5b, 0xa2, 0x49, 0x6d, 0x8b, 0xd1, 0x25,
104
+ 0x72, 0xf8, 0xf6, 0x64, 0x86, 0x68, 0x98, 0x16, 0xd4, 0xa4, 0x5c, 0xcc, 0x5d, 0x65, 0xb6, 0x92,
105
+ 0x6c, 0x70, 0x48, 0x50, 0xfd, 0xed, 0xb9, 0xda, 0x5e, 0x15, 0x46, 0x57, 0xa7, 0x8d, 0x9d, 0x84,
106
+ 0x90, 0xd8, 0xab, 0x00, 0x8c, 0xbc, 0xd3, 0x0a, 0xf7, 0xe4, 0x58, 0x05, 0xb8, 0xb3, 0x45, 0x06,
107
+ 0xd0, 0x2c, 0x1e, 0x8f, 0xca, 0x3f, 0x0f, 0x02, 0xc1, 0xaf, 0xbd, 0x03, 0x01, 0x13, 0x8a, 0x6b,
108
+ 0x3a, 0x91, 0x11, 0x41, 0x4f, 0x67, 0xdc, 0xea, 0x97, 0xf2, 0xcf, 0xce, 0xf0, 0xb4, 0xe6, 0x73,
109
+ 0x96, 0xac, 0x74, 0x22, 0xe7, 0xad, 0x35, 0x85, 0xe2, 0xf9, 0x37, 0xe8, 0x1c, 0x75, 0xdf, 0x6e,
110
+ 0x47, 0xf1, 0x1a, 0x71, 0x1d, 0x29, 0xc5, 0x89, 0x6f, 0xb7, 0x62, 0x0e, 0xaa, 0x18, 0xbe, 0x1b,
111
+ 0xfc, 0x56, 0x3e, 0x4b, 0xc6, 0xd2, 0x79, 0x20, 0x9a, 0xdb, 0xc0, 0xfe, 0x78, 0xcd, 0x5a, 0xf4,
112
+ 0x1f, 0xdd, 0xa8, 0x33, 0x88, 0x07, 0xc7, 0x31, 0xb1, 0x12, 0x10, 0x59, 0x27, 0x80, 0xec, 0x5f,
113
+ 0x60, 0x51, 0x7f, 0xa9, 0x19, 0xb5, 0x4a, 0x0d, 0x2d, 0xe5, 0x7a, 0x9f, 0x93, 0xc9, 0x9c, 0xef,
114
+ 0xa0, 0xe0, 0x3b, 0x4d, 0xae, 0x2a, 0xf5, 0xb0, 0xc8, 0xeb, 0xbb, 0x3c, 0x83, 0x53, 0x99, 0x61,
115
+ 0x17, 0x2b, 0x04, 0x7e, 0xba, 0x77, 0xd6, 0x26, 0xe1, 0x69, 0x14, 0x63, 0x55, 0x21, 0x0c, 0x7d };
116
+ #endif
117
+
118
+ // The round constant word array, Rcon[i], contains the values given by
119
+ // x to the power (i-1) being powers of x (x is denoted as {02}) in the field GF(2^8)
120
+ static const uint8_t Rcon[11] = {
121
+ 0x8d, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1b, 0x36 };
122
+
123
+ /*
124
+ * Jordan Goulder points out in PR #12 (https://github.com/kokke/tiny-AES-C/pull/12),
125
+ * that you can remove most of the elements in the Rcon array, because they are unused.
126
+ *
127
+ * From Wikipedia's article on the Rijndael key schedule @ https://en.wikipedia.org/wiki/Rijndael_key_schedule#Rcon
128
+ *
129
+ * "Only the first some of these constants are actually used – up to rcon[10] for AES-128 (as 11 round keys are needed),
130
+ * up to rcon[8] for AES-192, up to rcon[7] for AES-256. rcon[0] is not used in AES algorithm."
131
+ */
132
+
133
+
134
+ /*****************************************************************************/
135
+ /* Private functions: */
136
+ /*****************************************************************************/
137
+ /*
138
+ static uint8_t getSBoxValue(uint8_t num)
139
+ {
140
+ return sbox[num];
141
+ }
142
+ */
143
+ #define getSBoxValue(num) (sbox[(num)])
144
+
145
+ // This function produces Nb(Nr+1) round keys. The round keys are used in each round to decrypt the states.
146
+ static void KeyExpansion(uint8_t* RoundKey, const uint8_t* Key)
147
+ {
148
+ unsigned i, j, k;
149
+ uint8_t tempa[4]; // Used for the column/row operations
150
+
151
+ // The first round key is the key itself.
152
+ for (i = 0; i < Nk; ++i)
153
+ {
154
+ RoundKey[(i * 4) + 0] = Key[(i * 4) + 0];
155
+ RoundKey[(i * 4) + 1] = Key[(i * 4) + 1];
156
+ RoundKey[(i * 4) + 2] = Key[(i * 4) + 2];
157
+ RoundKey[(i * 4) + 3] = Key[(i * 4) + 3];
158
+ }
159
+
160
+ // All other round keys are found from the previous round keys.
161
+ for (i = Nk; i < Nb * (Nr + 1); ++i)
162
+ {
163
+ {
164
+ k = (i - 1) * 4;
165
+ tempa[0]=RoundKey[k + 0];
166
+ tempa[1]=RoundKey[k + 1];
167
+ tempa[2]=RoundKey[k + 2];
168
+ tempa[3]=RoundKey[k + 3];
169
+
170
+ }
171
+
172
+ if (i % Nk == 0)
173
+ {
174
+ // This function shifts the 4 bytes in a word to the left once.
175
+ // [a0,a1,a2,a3] becomes [a1,a2,a3,a0]
176
+
177
+ // Function RotWord()
178
+ {
179
+ const uint8_t u8tmp = tempa[0];
180
+ tempa[0] = tempa[1];
181
+ tempa[1] = tempa[2];
182
+ tempa[2] = tempa[3];
183
+ tempa[3] = u8tmp;
184
+ }
185
+
186
+ // SubWord() is a function that takes a four-byte input word and
187
+ // applies the S-box to each of the four bytes to produce an output word.
188
+
189
+ // Function Subword()
190
+ {
191
+ tempa[0] = getSBoxValue(tempa[0]);
192
+ tempa[1] = getSBoxValue(tempa[1]);
193
+ tempa[2] = getSBoxValue(tempa[2]);
194
+ tempa[3] = getSBoxValue(tempa[3]);
195
+ }
196
+
197
+ tempa[0] = tempa[0] ^ Rcon[i/Nk];
198
+ }
199
+ #if defined(AES256) && (AES256 == 1)
200
+ if (i % Nk == 4)
201
+ {
202
+ // Function Subword()
203
+ {
204
+ tempa[0] = getSBoxValue(tempa[0]);
205
+ tempa[1] = getSBoxValue(tempa[1]);
206
+ tempa[2] = getSBoxValue(tempa[2]);
207
+ tempa[3] = getSBoxValue(tempa[3]);
208
+ }
209
+ }
210
+ #endif
211
+ j = i * 4; k=(i - Nk) * 4;
212
+ RoundKey[j + 0] = RoundKey[k + 0] ^ tempa[0];
213
+ RoundKey[j + 1] = RoundKey[k + 1] ^ tempa[1];
214
+ RoundKey[j + 2] = RoundKey[k + 2] ^ tempa[2];
215
+ RoundKey[j + 3] = RoundKey[k + 3] ^ tempa[3];
216
+ }
217
+ }
218
+
219
+ void AES_init_ctx(struct AES_ctx* ctx, const uint8_t* key)
220
+ {
221
+ KeyExpansion(ctx->RoundKey, key);
222
+ }
223
+ #if (defined(CBC) && (CBC == 1)) || (defined(CTR) && (CTR == 1))
224
+ void AES_init_ctx_iv(struct AES_ctx* ctx, const uint8_t* key, const uint8_t* iv)
225
+ {
226
+ KeyExpansion(ctx->RoundKey, key);
227
+ memcpy (ctx->Iv, iv, AES_BLOCKLEN);
228
+ }
229
+ void AES_ctx_set_iv(struct AES_ctx* ctx, const uint8_t* iv)
230
+ {
231
+ memcpy (ctx->Iv, iv, AES_BLOCKLEN);
232
+ }
233
+ #endif
234
+
235
+ // This function adds the round key to state.
236
+ // The round key is added to the state by an XOR function.
237
+ static void AddRoundKey(uint8_t round, state_t* state, const uint8_t* RoundKey)
238
+ {
239
+ uint8_t i,j;
240
+ for (i = 0; i < 4; ++i)
241
+ {
242
+ for (j = 0; j < 4; ++j)
243
+ {
244
+ (*state)[i][j] ^= RoundKey[(round * Nb * 4) + (i * Nb) + j];
245
+ }
246
+ }
247
+ }
248
+
249
+ // The SubBytes Function Substitutes the values in the
250
+ // state matrix with values in an S-box.
251
+ static void SubBytes(state_t* state)
252
+ {
253
+ uint8_t i, j;
254
+ for (i = 0; i < 4; ++i)
255
+ {
256
+ for (j = 0; j < 4; ++j)
257
+ {
258
+ (*state)[j][i] = getSBoxValue((*state)[j][i]);
259
+ }
260
+ }
261
+ }
262
+
263
+ // The ShiftRows() function shifts the rows in the state to the left.
264
+ // Each row is shifted with different offset.
265
+ // Offset = Row number. So the first row is not shifted.
266
+ static void ShiftRows(state_t* state)
267
+ {
268
+ uint8_t temp;
269
+
270
+ // Rotate first row 1 columns to left
271
+ temp = (*state)[0][1];
272
+ (*state)[0][1] = (*state)[1][1];
273
+ (*state)[1][1] = (*state)[2][1];
274
+ (*state)[2][1] = (*state)[3][1];
275
+ (*state)[3][1] = temp;
276
+
277
+ // Rotate second row 2 columns to left
278
+ temp = (*state)[0][2];
279
+ (*state)[0][2] = (*state)[2][2];
280
+ (*state)[2][2] = temp;
281
+
282
+ temp = (*state)[1][2];
283
+ (*state)[1][2] = (*state)[3][2];
284
+ (*state)[3][2] = temp;
285
+
286
+ // Rotate third row 3 columns to left
287
+ temp = (*state)[0][3];
288
+ (*state)[0][3] = (*state)[3][3];
289
+ (*state)[3][3] = (*state)[2][3];
290
+ (*state)[2][3] = (*state)[1][3];
291
+ (*state)[1][3] = temp;
292
+ }
293
+
294
+ static uint8_t xtime(uint8_t x)
295
+ {
296
+ return ((x<<1) ^ (((x>>7) & 1) * 0x1b));
297
+ }
298
+
299
+ // MixColumns function mixes the columns of the state matrix
300
+ static void MixColumns(state_t* state)
301
+ {
302
+ uint8_t i;
303
+ uint8_t Tmp, Tm, t;
304
+ for (i = 0; i < 4; ++i)
305
+ {
306
+ t = (*state)[i][0];
307
+ Tmp = (*state)[i][0] ^ (*state)[i][1] ^ (*state)[i][2] ^ (*state)[i][3] ;
308
+ Tm = (*state)[i][0] ^ (*state)[i][1] ; Tm = xtime(Tm); (*state)[i][0] ^= Tm ^ Tmp ;
309
+ Tm = (*state)[i][1] ^ (*state)[i][2] ; Tm = xtime(Tm); (*state)[i][1] ^= Tm ^ Tmp ;
310
+ Tm = (*state)[i][2] ^ (*state)[i][3] ; Tm = xtime(Tm); (*state)[i][2] ^= Tm ^ Tmp ;
311
+ Tm = (*state)[i][3] ^ t ; Tm = xtime(Tm); (*state)[i][3] ^= Tm ^ Tmp ;
312
+ }
313
+ }
314
+
315
+ // Multiply is used to multiply numbers in the field GF(2^8)
316
+ // Note: The last call to xtime() is unneeded, but often ends up generating a smaller binary
317
+ // The compiler seems to be able to vectorize the operation better this way.
318
+ // See https://github.com/kokke/tiny-AES-c/pull/34
319
+ #if MULTIPLY_AS_A_FUNCTION
320
+ static uint8_t Multiply(uint8_t x, uint8_t y)
321
+ {
322
+ return (((y & 1) * x) ^
323
+ ((y>>1 & 1) * xtime(x)) ^
324
+ ((y>>2 & 1) * xtime(xtime(x))) ^
325
+ ((y>>3 & 1) * xtime(xtime(xtime(x)))) ^
326
+ ((y>>4 & 1) * xtime(xtime(xtime(xtime(x)))))); /* this last call to xtime() can be omitted */
327
+ }
328
+ #else
329
+ #define Multiply(x, y) \
330
+ ( ((y & 1) * x) ^ \
331
+ ((y>>1 & 1) * xtime(x)) ^ \
332
+ ((y>>2 & 1) * xtime(xtime(x))) ^ \
333
+ ((y>>3 & 1) * xtime(xtime(xtime(x)))) ^ \
334
+ ((y>>4 & 1) * xtime(xtime(xtime(xtime(x)))))) \
335
+
336
+ #endif
337
+
338
+ #if (defined(CBC) && CBC == 1) || (defined(ECB) && ECB == 1)
339
+ /*
340
+ static uint8_t getSBoxInvert(uint8_t num)
341
+ {
342
+ return rsbox[num];
343
+ }
344
+ */
345
+ #define getSBoxInvert(num) (rsbox[(num)])
346
+
347
+ // MixColumns function mixes the columns of the state matrix.
348
+ // The method used to multiply may be difficult to understand for the inexperienced.
349
+ // Please use the references to gain more information.
350
+ static void InvMixColumns(state_t* state)
351
+ {
352
+ int i;
353
+ uint8_t a, b, c, d;
354
+ for (i = 0; i < 4; ++i)
355
+ {
356
+ a = (*state)[i][0];
357
+ b = (*state)[i][1];
358
+ c = (*state)[i][2];
359
+ d = (*state)[i][3];
360
+
361
+ (*state)[i][0] = Multiply(a, 0x0e) ^ Multiply(b, 0x0b) ^ Multiply(c, 0x0d) ^ Multiply(d, 0x09);
362
+ (*state)[i][1] = Multiply(a, 0x09) ^ Multiply(b, 0x0e) ^ Multiply(c, 0x0b) ^ Multiply(d, 0x0d);
363
+ (*state)[i][2] = Multiply(a, 0x0d) ^ Multiply(b, 0x09) ^ Multiply(c, 0x0e) ^ Multiply(d, 0x0b);
364
+ (*state)[i][3] = Multiply(a, 0x0b) ^ Multiply(b, 0x0d) ^ Multiply(c, 0x09) ^ Multiply(d, 0x0e);
365
+ }
366
+ }
367
+
368
+
369
+ // The SubBytes Function Substitutes the values in the
370
+ // state matrix with values in an S-box.
371
+ static void InvSubBytes(state_t* state)
372
+ {
373
+ uint8_t i, j;
374
+ for (i = 0; i < 4; ++i)
375
+ {
376
+ for (j = 0; j < 4; ++j)
377
+ {
378
+ (*state)[j][i] = getSBoxInvert((*state)[j][i]);
379
+ }
380
+ }
381
+ }
382
+
383
+ static void InvShiftRows(state_t* state)
384
+ {
385
+ uint8_t temp;
386
+
387
+ // Rotate first row 1 columns to right
388
+ temp = (*state)[3][1];
389
+ (*state)[3][1] = (*state)[2][1];
390
+ (*state)[2][1] = (*state)[1][1];
391
+ (*state)[1][1] = (*state)[0][1];
392
+ (*state)[0][1] = temp;
393
+
394
+ // Rotate second row 2 columns to right
395
+ temp = (*state)[0][2];
396
+ (*state)[0][2] = (*state)[2][2];
397
+ (*state)[2][2] = temp;
398
+
399
+ temp = (*state)[1][2];
400
+ (*state)[1][2] = (*state)[3][2];
401
+ (*state)[3][2] = temp;
402
+
403
+ // Rotate third row 3 columns to right
404
+ temp = (*state)[0][3];
405
+ (*state)[0][3] = (*state)[1][3];
406
+ (*state)[1][3] = (*state)[2][3];
407
+ (*state)[2][3] = (*state)[3][3];
408
+ (*state)[3][3] = temp;
409
+ }
410
+ #endif // #if (defined(CBC) && CBC == 1) || (defined(ECB) && ECB == 1)
411
+
412
+ // Cipher is the main function that encrypts the PlainText.
413
+ static void Cipher(state_t* state, const uint8_t* RoundKey)
414
+ {
415
+ uint8_t round = 0;
416
+
417
+ // Add the First round key to the state before starting the rounds.
418
+ AddRoundKey(0, state, RoundKey);
419
+
420
+ // There will be Nr rounds.
421
+ // The first Nr-1 rounds are identical.
422
+ // These Nr rounds are executed in the loop below.
423
+ // Last one without MixColumns()
424
+ for (round = 1; ; ++round)
425
+ {
426
+ SubBytes(state);
427
+ ShiftRows(state);
428
+ if (round == Nr) {
429
+ break;
430
+ }
431
+ MixColumns(state);
432
+ AddRoundKey(round, state, RoundKey);
433
+ }
434
+ // Add round key to last round
435
+ AddRoundKey(Nr, state, RoundKey);
436
+ }
437
+
438
+ #if (defined(CBC) && CBC == 1) || (defined(ECB) && ECB == 1)
439
+ static void InvCipher(state_t* state, const uint8_t* RoundKey)
440
+ {
441
+ uint8_t round = 0;
442
+
443
+ // Add the First round key to the state before starting the rounds.
444
+ AddRoundKey(Nr, state, RoundKey);
445
+
446
+ // There will be Nr rounds.
447
+ // The first Nr-1 rounds are identical.
448
+ // These Nr rounds are executed in the loop below.
449
+ // Last one without InvMixColumn()
450
+ for (round = (Nr - 1); ; --round)
451
+ {
452
+ InvShiftRows(state);
453
+ InvSubBytes(state);
454
+ AddRoundKey(round, state, RoundKey);
455
+ if (round == 0) {
456
+ break;
457
+ }
458
+ InvMixColumns(state);
459
+ }
460
+
461
+ }
462
+ #endif // #if (defined(CBC) && CBC == 1) || (defined(ECB) && ECB == 1)
463
+
464
+ /*****************************************************************************/
465
+ /* Public functions: */
466
+ /*****************************************************************************/
467
+ #if defined(ECB) && (ECB == 1)
468
+
469
+
470
+ void AES_ECB_encrypt(const struct AES_ctx* ctx, uint8_t* buf)
471
+ {
472
+ // The next function call encrypts the PlainText with the Key using AES algorithm.
473
+ Cipher((state_t*)buf, ctx->RoundKey);
474
+ }
475
+
476
+ void AES_ECB_decrypt(const struct AES_ctx* ctx, uint8_t* buf)
477
+ {
478
+ // The next function call decrypts the PlainText with the Key using AES algorithm.
479
+ InvCipher((state_t*)buf, ctx->RoundKey);
480
+ }
481
+
482
+
483
+ #endif // #if defined(ECB) && (ECB == 1)
484
+
485
+
486
+
487
+
488
+
489
+ #if defined(CBC) && (CBC == 1)
490
+
491
+
492
+ static void XorWithIv(uint8_t* buf, const uint8_t* Iv)
493
+ {
494
+ uint8_t i;
495
+ for (i = 0; i < AES_BLOCKLEN; ++i) // The block in AES is always 128bit no matter the key size
496
+ {
497
+ buf[i] ^= Iv[i];
498
+ }
499
+ }
500
+
501
+ void AES_CBC_encrypt_buffer(struct AES_ctx *ctx, uint8_t* buf, size_t length)
502
+ {
503
+ size_t i;
504
+ uint8_t *Iv = ctx->Iv;
505
+ for (i = 0; i < length; i += AES_BLOCKLEN)
506
+ {
507
+ XorWithIv(buf, Iv);
508
+ Cipher((state_t*)buf, ctx->RoundKey);
509
+ Iv = buf;
510
+ buf += AES_BLOCKLEN;
511
+ }
512
+ /* store Iv in ctx for next call */
513
+ memcpy(ctx->Iv, Iv, AES_BLOCKLEN);
514
+ }
515
+
516
+ void AES_CBC_decrypt_buffer(struct AES_ctx* ctx, uint8_t* buf, size_t length)
517
+ {
518
+ size_t i;
519
+ uint8_t storeNextIv[AES_BLOCKLEN];
520
+ for (i = 0; i < length; i += AES_BLOCKLEN)
521
+ {
522
+ memcpy(storeNextIv, buf, AES_BLOCKLEN);
523
+ InvCipher((state_t*)buf, ctx->RoundKey);
524
+ XorWithIv(buf, ctx->Iv);
525
+ memcpy(ctx->Iv, storeNextIv, AES_BLOCKLEN);
526
+ buf += AES_BLOCKLEN;
527
+ }
528
+
529
+ }
530
+
531
+ #endif // #if defined(CBC) && (CBC == 1)
532
+
533
+
534
+
535
+ #if defined(CTR) && (CTR == 1)
536
+
537
+ /* Symmetrical operation: same function for encrypting as for decrypting. Note any IV/nonce should never be reused with the same key */
538
+ void AES_CTR_xcrypt_buffer(struct AES_ctx* ctx, uint8_t* buf, size_t length)
539
+ {
540
+ uint8_t buffer[AES_BLOCKLEN];
541
+
542
+ size_t i;
543
+ int bi;
544
+ for (i = 0, bi = AES_BLOCKLEN; i < length; ++i, ++bi)
545
+ {
546
+ if (bi == AES_BLOCKLEN) /* we need to regen xor compliment in buffer */
547
+ {
548
+
549
+ memcpy(buffer, ctx->Iv, AES_BLOCKLEN);
550
+ Cipher((state_t*)buffer,ctx->RoundKey);
551
+
552
+ /* Increment Iv and handle overflow */
553
+ for (bi = (AES_BLOCKLEN - 1); bi >= 0; --bi)
554
+ {
555
+ /* inc will overflow */
556
+ if (ctx->Iv[bi] == 255)
557
+ {
558
+ ctx->Iv[bi] = 0;
559
+ continue;
560
+ }
561
+ ctx->Iv[bi] += 1;
562
+ break;
563
+ }
564
+ bi = 0;
565
+ }
566
+
567
+ buf[i] = (buf[i] ^ buffer[bi]);
568
+ }
569
+ }
570
+
571
+ #endif // #if defined(CTR) && (CTR == 1)
572
+
@@ -0,0 +1,91 @@
1
+ #ifndef _AES_H_
2
+ #define _AES_H_
3
+
4
+ #include <stdint.h>
5
+ #include <stddef.h>
6
+
7
+ // #define the macros below to 1/0 to enable/disable the mode of operation.
8
+ //
9
+ // CBC enables AES encryption in CBC-mode of operation.
10
+ // CTR enables encryption in counter-mode.
11
+ // ECB enables the basic ECB 16-byte block algorithm. All can be enabled simultaneously.
12
+
13
+ // The #ifndef-guard allows it to be configured before #include'ing or at compile time.
14
+ #ifndef CBC
15
+ #define CBC 1
16
+ #endif
17
+
18
+ #ifndef ECB
19
+ #define ECB 1
20
+ #endif
21
+
22
+ #ifndef CTR
23
+ #define CTR 1
24
+ #endif
25
+
26
+
27
+ #define AES128 1
28
+ //#define AES192 1
29
+ //#define AES256 1
30
+
31
+ #define AES_BLOCKLEN 16 // Block length in bytes - AES is 128b block only
32
+
33
+ #if defined(AES256) && (AES256 == 1)
34
+ #define AES_KEYLEN 32
35
+ #define AES_keyExpSize 240
36
+ #elif defined(AES192) && (AES192 == 1)
37
+ #define AES_KEYLEN 24
38
+ #define AES_keyExpSize 208
39
+ #else
40
+ #define AES_KEYLEN 16 // Key length in bytes
41
+ #define AES_keyExpSize 176
42
+ #endif
43
+
44
+ struct AES_ctx
45
+ {
46
+ uint8_t RoundKey[AES_keyExpSize];
47
+ #if (defined(CBC) && (CBC == 1)) || (defined(CTR) && (CTR == 1))
48
+ uint8_t Iv[AES_BLOCKLEN];
49
+ #endif
50
+ };
51
+
52
+ void AES_init_ctx(struct AES_ctx* ctx, const uint8_t* key);
53
+ #if (defined(CBC) && (CBC == 1)) || (defined(CTR) && (CTR == 1))
54
+ void AES_init_ctx_iv(struct AES_ctx* ctx, const uint8_t* key, const uint8_t* iv);
55
+ void AES_ctx_set_iv(struct AES_ctx* ctx, const uint8_t* iv);
56
+ #endif
57
+
58
+ #if defined(ECB) && (ECB == 1)
59
+ // buffer size is exactly AES_BLOCKLEN bytes;
60
+ // you need only AES_init_ctx as IV is not used in ECB
61
+ // NB: ECB is considered insecure for most uses
62
+ void AES_ECB_encrypt(const struct AES_ctx* ctx, uint8_t* buf);
63
+ void AES_ECB_decrypt(const struct AES_ctx* ctx, uint8_t* buf);
64
+
65
+ #endif // #if defined(ECB) && (ECB == !)
66
+
67
+
68
+ #if defined(CBC) && (CBC == 1)
69
+ // buffer size MUST be mutile of AES_BLOCKLEN;
70
+ // Suggest https://en.wikipedia.org/wiki/Padding_(cryptography)#PKCS7 for padding scheme
71
+ // NOTES: you need to set IV in ctx via AES_init_ctx_iv() or AES_ctx_set_iv()
72
+ // no IV should ever be reused with the same key
73
+ void AES_CBC_encrypt_buffer(struct AES_ctx* ctx, uint8_t* buf, size_t length);
74
+ void AES_CBC_decrypt_buffer(struct AES_ctx* ctx, uint8_t* buf, size_t length);
75
+
76
+ #endif // #if defined(CBC) && (CBC == 1)
77
+
78
+
79
+ #if defined(CTR) && (CTR == 1)
80
+
81
+ // Same function for encrypting as for decrypting.
82
+ // IV is incremented for every block, and used after encryption as XOR-compliment for output
83
+ // Suggesting https://en.wikipedia.org/wiki/Padding_(cryptography)#PKCS7 for padding scheme
84
+ // NOTES: you need to set IV in ctx with AES_init_ctx_iv() or AES_ctx_set_iv()
85
+ // no IV should ever be reused with the same key
86
+ void AES_CTR_xcrypt_buffer(struct AES_ctx* ctx, uint8_t* buf, size_t length);
87
+
88
+ #endif // #if defined(CTR) && (CTR == 1)
89
+
90
+
91
+ #endif // _AES_H_
@@ -0,0 +1,12 @@
1
+ #ifndef _AES_HPP_
2
+ #define _AES_HPP_
3
+
4
+ #ifndef __cplusplus
5
+ #error Do not include the hpp header in a c project!
6
+ #endif //__cplusplus
7
+
8
+ extern "C" {
9
+ #include "aes.h"
10
+ }
11
+
12
+ #endif //_AES_HPP_