| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455 |
- // ChaCha20.swift
- // This file is part of KeePass.swift
- //
- // Copyright © 2021 Maxime Epain. All rights reserved.
- //
- // KeePass.swift is free software: you can redistribute it and/or modify
- // it under the terms of the GNU General Public License as published by
- // the Free Software Foundation, either version 3 of the License, or
- // (at your option) any later version.
- //
- // KeePass.swift is distributed in the hope that it will be useful,
- // but WITHOUT ANY WARRANTY; without even the implied warranty of
- // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- // GNU General Public License for more details.
- //
- // You should have received a copy of the GNU General Public License
- // along with KeePass.swift. If not, see <https://www.gnu.org/licenses/>.
- import Binary
- import Foundation
- import Sodium
- public final class ChaCha20 {
- public let key: Bytes
- public let nonce: Bytes
- public init(key: Bytes, iv nonce: Bytes) throws {
- guard key.lenght == crypto_stream_chacha20_ietf_KEYBYTES else {
- throw CryptoError.keyLenght(expecting: "Equal \(crypto_stream_chacha20_ietf_KEYBYTES)", got: key.lenght)
- }
- guard nonce.lenght == crypto_stream_chacha20_ietf_NONCEBYTES else {
- throw CryptoError.ivLenght(expecting: "Equal \(crypto_stream_chacha20_ietf_NONCEBYTES)", got: nonce.lenght)
- }
- self.key = key
- self.nonce = nonce
- }
- }
- extension ChaCha20: Cipher {
- public func encrypt(data: Bytes) throws -> Bytes {
- var out = Bytes(lenght: lenght(data))
- crypto_stream_chacha20_ietf_xor(&out.rawValue, data.rawValue, lenght(data), nonce.rawValue, key.rawValue)
- return out
- }
- public func decrypt(data: Bytes) throws -> Bytes {
- try encrypt(data: data)
- }
- }
|