Files
adler32
aho_corasick
approx
arrayvec
ascii
backtrace
backtrace_sys
base64
bitflags
brotli2
brotli_sys
bstr
byteset
search
unicode
buf_redux
byteorder
bytes
cfg_if
chrono
format
naive
offset
chunked_transfer
color_quant
cookie
cookie_store
crc32fast
crossbeam_deque
crossbeam_epoch
crossbeam_queue
crossbeam_utils
csv
csv_core
csv_user_import
deflate
diesel
associations
connection
expression
functions
ops
expression_methods
macros
migration
mysql
connection
query_builder
types
query_builder
delete_statement
insert_statement
nodes
select_statement
update_statement
query_dsl
query_source
sql_types
type_impls
types
diesel_derives
diesel_migrations
dirs
dotenv
dtoa
either
encoding_rs
error_chain
failure
failure_derive
filetime
flate2
deflate
gz
zlib
fnv
foreign_types
foreign_types_shared
futures
future
sink
stream
and_then.rsbuffer_unordered.rsbuffered.rscatch_unwind.rschain.rschannel.rschunks.rscollect.rsconcat.rsempty.rsfilter.rsfilter_map.rsflatten.rsfold.rsfor_each.rsforward.rsfrom_err.rsfuse.rsfuture.rsfutures_ordered.rsfutures_unordered.rsinspect.rsinspect_err.rsiter.rsiter_ok.rsiter_result.rsmap.rsmap_err.rsmerge.rsmod.rsonce.rsor_else.rspeek.rspoll_fn.rsrepeat.rsselect.rsskip.rsskip_while.rssplit.rstake.rstake_while.rsthen.rsunfold.rswait.rszip.rs
sync
task_impl
unsync
futures_cpupool
gif
google_signin
gzip_header
h2
codec
frame
hpack
proto
http
http_body
httparse
hyper
body
client
common
proto
server
service
hyper_rustls
hyper_tls
idna
image
bmp
hdr
ico
imageops
jpeg
math
pnm
tga
utils
webp
indexmap
inflate
iovec
itoa
jpeg_decoder
language_tags
lazy_static
libc
unix
lock_api
log
lzw
matches
memchr
memoffset
migrations_internals
migrations_macros
mime
mime_guess
miniz_oxide
mio
deprecated
net
sys
multipart
mysqlclient_sys
native_tls
net2
nodrop
num_cpus
num_derive
num_integer
num_iter
num_rational
num_traits
openssl
openssl_probe
openssl_sys
ordered_float
owning_ref
parking_lot
parking_lot_core
percent_encoding
phf
phf_shared
png
proc_macro2
publicsuffix
quick_error
quote
r2d2
rand
distributions
prng
rngs
seq
rand_chacha
rand_core
rand_hc
rand_isaac
rand_jitter
rand_os
rand_pcg
rand_xorshift
rayon
collections
compile_fail
iter
chain.rschunks.rscloned.rscopied.rsempty.rsenumerate.rsextend.rsfilter.rsfilter_map.rsfind.rsflat_map.rsflatten.rsfold.rsfor_each.rsfrom_par_iter.rsinspect.rsinterleave.rsinterleave_shortest.rsintersperse.rslen.rsmap.rsmap_with.rsmod.rsnoop.rsonce.rspanic_fuse.rspar_bridge.rsproduct.rsreduce.rsrepeat.rsrev.rsskip.rssplitter.rssum.rstake.rstry_fold.rstry_reduce.rstry_reduce_with.rsunzip.rsupdate.rswhile_some.rszip.rszip_eq.rs
slice
rayon_core
compile_fail
join
scope
sleep
spawn
thread_pool
regex
regex_automata
regex_syntax
ast
hir
unicode_tables
remove_dir_all
reqwest
ring
aead
arithmetic
digest
ec
curve25519
suite_b
rsa
rouille
input
websocket
rustc_demangle
rustls
client
msgs
server
rusttype
ryu
safemem
scheduled_thread_pool
scoped_threadpool
scopeguard
sct
serde
de
private
ser
serde_derive
serde_json
serde_urlencoded
sha1
simplelog
siphasher
slab
smallvec
stable_deref_trait
stb_truetype
string
syn
attr.rsbuffer.rscustom_keyword.rscustom_punctuation.rsdata.rsderive.rsdiscouraged.rserror.rsexport.rsexpr.rsext.rsfile.rsgenerics.rsgroup.rsident.rsitem.rslib.rslifetime.rslit.rslookahead.rsmac.rsmacros.rsop.rsparse.rsparse_macro_input.rsparse_quote.rspath.rsprint.rspunctuated.rssealed.rsspan.rsspanned.rsthread.rstoken.rstt.rsty.rs
synom
synstructure
tempdir
term
terminfo
thread_local
threadpool
tiff
time
tiny_http
util
tokio
executor
reactor
runtime
util
tokio_buf
tokio_current_thread
tokio_executor
tokio_io
_tokio_codec
codec
io
tokio_reactor
tokio_sync
tokio_tcp
tokio_threadpool
park
pool
task
worker
tokio_timer
clock
timer
wheel
traitobject
try_from
try_lock
twoway
typeable
unicase
unicode_bidi
unicode_normalization
unicode_xid
untrusted
url
uuid
want
webdev_lib
chemicals
permissions
tests
question_categories
questions
test_sessions
tests
users
webpki
webpki_roots
>
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76
use ring::digest; use ring::hmac; use std::io::Write; fn concat_sign(key: &hmac::SigningKey, a: &[u8], b: &[u8]) -> hmac::Signature { let mut ctx = hmac::SigningContext::with_key(key); ctx.update(a); ctx.update(b); ctx.sign() } fn p(out: &mut [u8], hashalg: &'static digest::Algorithm, secret: &[u8], seed: &[u8]) { let hmac_key = hmac::SigningKey::new(hashalg, secret); // A(1) let mut current_a = hmac::sign(&hmac_key, seed); let mut offs = 0; while offs < out.len() { // P_hash[i] = HMAC_hash(secret, A(i) + seed) let p_term = concat_sign(&hmac_key, current_a.as_ref(), seed); offs += out[offs..].as_mut().write(p_term.as_ref()).unwrap(); // A(i+1) = HMAC_hash(secret, A(i)) current_a = hmac::sign(&hmac_key, current_a.as_ref()); } } fn concat(a: &[u8], b: &[u8]) -> Vec<u8> { let mut ret = Vec::new(); ret.extend_from_slice(a); ret.extend_from_slice(b); ret } pub fn prf(out: &mut [u8], hashalg: &'static digest::Algorithm, secret: &[u8], label: &[u8], seed: &[u8]) { let joined_seed = concat(label, seed); p(out, hashalg, secret, &joined_seed); } #[cfg(test)] mod tests { use ring::digest::{SHA256, SHA512}; #[test] fn check_sha256() { let secret = b"\x9b\xbe\x43\x6b\xa9\x40\xf0\x17\xb1\x76\x52\x84\x9a\x71\xdb\x35"; let seed = b"\xa0\xba\x9f\x93\x6c\xda\x31\x18\x27\xa6\xf7\x96\xff\xd5\x19\x8c"; let label = b"test label"; let expect = include_bytes!("testdata/prf-result.1.bin"); let mut output = [0u8; 100]; super::prf(&mut output, &SHA256, secret, label, seed); assert_eq!(expect.len(), output.len()); assert_eq!(expect.to_vec(), output.to_vec()); } #[test] fn check_sha512() { let secret = b"\xb0\x32\x35\x23\xc1\x85\x35\x99\x58\x4d\x88\x56\x8b\xbb\x05\xeb"; let seed = b"\xd4\x64\x0e\x12\xe4\xbc\xdb\xfb\x43\x7f\x03\xe6\xae\x41\x8e\xe5"; let label = b"test label"; let expect = include_bytes!("testdata/prf-result.2.bin"); let mut output = [0u8; 196]; super::prf(&mut output, &SHA512, secret, label, seed); assert_eq!(expect.len(), output.len()); assert_eq!(expect.to_vec(), output.to_vec()); } }