AES.Cryptors.swift 1.8 KB

1234567891011121314151617181920212223242526272829303132333435
  1. //
  2. // CryptoSwift
  3. //
  4. // Copyright (C) 2014-2017 Marcin Krzyżanowski <marcin@krzyzanowskim.com>
  5. // This software is provided 'as-is', without any express or implied warranty.
  6. //
  7. // In no event will the authors be held liable for any damages arising from the use of this software.
  8. //
  9. // Permission is granted to anyone to use this software for any purpose,including commercial applications, and to alter it and redistribute it freely, subject to the following restrictions:
  10. //
  11. // - The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation is required.
  12. // - Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
  13. // - This notice may not be removed or altered from any source or binary distribution.
  14. //
  15. // MARK: Cryptors
  16. extension AES: Cryptors {
  17. public func makeEncryptor() throws -> Cryptor & Updatable {
  18. let worker = try blockMode.worker(blockSize: AES.blockSize, cipherOperation: encrypt)
  19. if worker is StreamModeWorker {
  20. return try StreamEncryptor(blockSize: AES.blockSize, padding: padding, worker)
  21. }
  22. return try BlockEncryptor(blockSize: AES.blockSize, padding: padding, worker)
  23. }
  24. public func makeDecryptor() throws -> Cryptor & Updatable {
  25. let cipherOperation: CipherOperationOnBlock = blockMode.options.contains(.useEncryptToDecrypt) == true ? encrypt : decrypt
  26. let worker = try blockMode.worker(blockSize: AES.blockSize, cipherOperation: cipherOperation)
  27. if worker is StreamModeWorker {
  28. return try StreamDecryptor(blockSize: AES.blockSize, padding: padding, worker)
  29. }
  30. return try BlockDecryptor(blockSize: AES.blockSize, padding: padding, worker)
  31. }
  32. }