2021-01-18 13:20:06 +01:00
|
|
|
// Copyright (c) 2019-2021 Alexander Medvednikov. All rights reserved.
|
2019-07-26 16:48:49 +02: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 13:20:06 +01:00
|
|
|
fn test_crypto_rc4() {
|
2019-07-26 16:48:49 +02:00
|
|
|
key := 'tthisisourrc4key'.bytes()
|
2021-01-18 13:20:06 +01:00
|
|
|
|
2019-08-07 13:37:07 +02:00
|
|
|
mut c := rc4.new_cipher(key) or {
|
2019-07-26 16:48:49 +02:00
|
|
|
println(err)
|
|
|
|
return
|
|
|
|
}
|
2021-01-18 13:20:06 +01:00
|
|
|
|
2019-07-26 16:48:49 +02:00
|
|
|
mut src := 'toencrypt'.bytes()
|
2021-01-18 13:20:06 +01:00
|
|
|
|
2019-07-26 16:48:49 +02:00
|
|
|
// src & dst same, encrypt in place
|
2020-09-27 10:18:55 +02:00
|
|
|
c.xor_key_stream(mut src, mut src) // encrypt data
|
2021-01-18 13:20:06 +01:00
|
|
|
|
2019-07-26 16:48:49 +02:00
|
|
|
c.reset()
|
|
|
|
|
2019-08-03 07:48:58 +02:00
|
|
|
assert src.hex() == '189a39a91aea8afa65'
|
2019-07-26 16:48:49 +02:00
|
|
|
}
|