2023-03-28 23:55:57 +03:00
|
|
|
// Copyright (c) 2019-2023 Alexander Medvednikov. All rights reserved.
|
2019-07-26 17:48:49 +03:00
|
|
|
// Use of this source code is governed by an MIT license
|
|
|
|
// that can be found in the LICENSE file.
|
|
|
|
import crypto.rc4
|
|
|
|
|
2021-01-18 15:20:06 +03:00
|
|
|
fn test_crypto_rc4() {
|
2019-07-26 17:48:49 +03:00
|
|
|
key := 'tthisisourrc4key'.bytes()
|
2021-01-18 15:20:06 +03:00
|
|
|
|
2019-08-07 14:37:07 +03:00
|
|
|
mut c := rc4.new_cipher(key) or {
|
2019-07-26 17:48:49 +03:00
|
|
|
println(err)
|
|
|
|
return
|
|
|
|
}
|
2021-01-18 15:20:06 +03:00
|
|
|
|
2019-07-26 17:48:49 +03:00
|
|
|
mut src := 'toencrypt'.bytes()
|
2021-01-18 15:20:06 +03:00
|
|
|
|
2019-07-26 17:48:49 +03:00
|
|
|
// src & dst same, encrypt in place
|
2020-09-27 11:18:55 +03:00
|
|
|
c.xor_key_stream(mut src, mut src) // encrypt data
|
2021-01-18 15:20:06 +03:00
|
|
|
|
2019-07-26 17:48:49 +03:00
|
|
|
c.reset()
|
|
|
|
|
2019-08-03 08:48:58 +03:00
|
|
|
assert src.hex() == '189a39a91aea8afa65'
|
2019-07-26 17:48:49 +03:00
|
|
|
}
|