1
0
mirror of https://github.com/vlang/v.git synced 2023-08-10 21:13:21 +03:00
v/vlib/crypto/aes/cypher_generic.v

23 lines
557 B
V
Raw Normal View History

2020-02-03 07:00:36 +03:00
// Copyright (c) 2019-2020 Alexander Medvednikov. All rights reserved.
2019-07-25 18:49:57 +03:00
// Use of this source code is governed by an MIT license
// that can be found in the LICENSE file.
module aes
import (
2019-09-23 13:42:20 +03:00
// crypto.cipher
// crypto.internal.subtle
2019-07-25 18:49:57 +03:00
)
// new_cipher_generic creates and returns a new cipher.Block
// this is the generiv v version, no arch optimisations
fn new_cipher_generic(key []byte) AesCipher {
n := key.len + 28
2019-08-07 14:37:07 +03:00
mut c := AesCipher{
enc: [u32(0)].repeat(n)
dec: [u32(0)].repeat(n)
2019-07-25 18:49:57 +03:00
}
2019-08-07 14:37:07 +03:00
expand_key_generic(key, mut c.enc, mut c.dec)
2019-07-25 18:49:57 +03:00
return c
}