Artifact
d43b49b05a3b3fc166997484d1f12c6dacc08b77:
- File
net2o-keys.fs
— part of check-in
[96a0b26980]
at
2012-12-10 00:12:36
on branch trunk
— Use pre-generated keys for tests
(user:
bernd
size: 2435)
0000: 5c 20 6b 65 79 20 68 61 6e 64 6c 69 6e 67 0a 0a \ key handling..
0010: 72 65 71 75 69 72 65 20 6d 6b 64 69 72 2e 66 73 require mkdir.fs
0020: 0a 0a 3a 20 61 63 63 65 70 74 2a 20 28 20 61 64 ..: accept* ( ad
0030: 64 72 20 75 20 2d 2d 20 75 27 20 29 0a 20 20 20 dr u -- u' ).
0040: 20 5c 20 61 63 63 65 70 74 2d 6c 69 6b 65 20 69 \ accept-like i
0050: 6e 70 75 74 2c 20 62 75 74 20 74 79 70 65 73 20 nput, but types
0060: 2a 20 69 6e 73 74 65 61 64 20 6f 66 20 74 68 65 * instead of the
0070: 20 63 68 61 72 61 63 74 65 72 0a 20 20 20 20 64 character. d
0080: 75 70 20 3e 72 0a 20 20 20 20 42 45 47 49 4e 20 up >r. BEGIN
0090: 20 78 6b 65 79 20 64 75 70 20 23 63 72 20 3c 3e xkey dup #cr <>
00a0: 20 57 48 49 4c 45 0a 09 20 20 20 20 64 75 70 20 WHILE.. dup
00b0: 23 62 73 20 3d 20 6f 76 65 72 20 23 64 65 6c 20 #bs = over #del
00c0: 3d 20 6f 72 20 49 46 0a 09 09 64 72 6f 70 20 64 = or IF...drop d
00d0: 75 70 20 72 40 20 75 3c 20 49 46 0a 09 09 20 20 up r@ u< IF...
00e0: 20 20 6f 76 65 72 20 2b 20 3e 72 20 78 63 68 61 over + >r xcha
00f0: 72 2d 20 72 3e 20 6f 76 65 72 20 2d 0a 09 09 20 r- r> over -...
0100: 20 20 20 31 20 62 61 63 6b 73 70 61 63 65 73 20 1 backspaces
0110: 73 70 61 63 65 20 31 20 62 61 63 6b 73 70 61 63 space 1 backspac
0120: 65 73 0a 09 09 45 4c 53 45 0a 09 09 20 20 20 20 es...ELSE...
0130: 62 65 6c 6c 0a 09 09 54 48 45 4e 0a 09 20 20 20 bell...THEN..
0140: 20 45 4c 53 45 0a 09 09 2d 72 6f 74 20 78 63 21 ELSE...-rot xc!
0150: 2b 3f 20 30 3d 20 49 46 20 20 62 65 6c 6c 20 20 +? 0= IF bell
0160: 45 4c 53 45 20 20 27 2a 27 20 65 6d 69 74 20 20 ELSE '*' emit
0170: 54 48 45 4e 0a 09 20 20 20 20 54 48 45 4e 0a 20 THEN.. THEN.
0180: 20 20 20 52 45 50 45 41 54 20 20 64 72 6f 70 20 REPEAT drop
0190: 20 6e 69 70 20 72 3e 20 73 77 61 70 20 2d 20 3b nip r> swap - ;
01a0: 0a 0a 3a 20 3f 2e 6e 65 74 32 6f 20 28 20 2d 2d ..: ?.net2o ( --
01b0: 20 29 0a 20 20 20 20 73 22 20 7e 2f 2e 6e 65 74 ). s" ~/.net
01c0: 32 6f 22 20 72 2f 6f 20 6f 70 65 6e 2d 66 69 6c 2o" r/o open-fil
01d0: 65 20 6e 69 70 20 49 46 0a 09 73 22 20 7e 2f 2e e nip IF..s" ~/.
01e0: 6e 65 74 32 6f 22 20 24 31 43 30 20 6d 6b 64 69 net2o" $1C0 mkdi
01f0: 72 2d 70 61 72 65 6e 74 73 20 74 68 72 6f 77 0a r-parents throw.
0200: 20 20 20 20 54 48 45 4e 20 3b 0a 0a 3a 20 6b 65 THEN ;..: ke
0210: 79 73 2d 69 6e 20 28 20 70 6b 63 20 73 6b 63 20 ys-in ( pkc skc
0220: 61 64 64 72 20 75 20 2d 2d 20 29 0a 20 20 20 20 addr u -- ).
0230: 72 2f 6f 20 6f 70 65 6e 2d 66 69 6c 65 20 74 68 r/o open-file th
0240: 72 6f 77 20 7b 20 66 64 20 7d 20 73 77 61 70 0a row { fd } swap.
0250: 20 20 20 20 6b 65 79 73 69 7a 65 20 66 64 20 72 keysize fd r
0260: 65 61 64 2d 66 69 6c 65 20 74 68 72 6f 77 20 6b ead-file throw k
0270: 65 79 73 69 7a 65 20 3c 3e 20 21 21 6e 6f 6b 65 eysize <> !!noke
0280: 79 21 21 0a 20 20 20 20 6b 65 79 73 69 7a 65 20 y!!. keysize
0290: 66 64 20 72 65 61 64 2d 66 69 6c 65 20 74 68 72 fd read-file thr
02a0: 6f 77 20 6b 65 79 73 69 7a 65 20 3c 3e 20 21 21 ow keysize <> !!
02b0: 6e 6f 6b 65 79 21 21 0a 20 20 20 20 66 64 20 63 nokey!!. fd c
02c0: 6c 6f 73 65 2d 66 69 6c 65 20 74 68 72 6f 77 20 lose-file throw
02d0: 3b 0a 0a 3a 20 6b 65 79 73 2d 6f 75 74 20 28 20 ;..: keys-out (
02e0: 70 6b 63 20 73 6b 63 20 61 64 64 72 20 75 20 2d pkc skc addr u -
02f0: 2d 20 29 0a 20 20 20 20 72 2f 77 20 63 72 65 61 - ). r/w crea
0300: 74 65 2d 66 69 6c 65 20 74 68 72 6f 77 20 7b 20 te-file throw {
0310: 66 64 20 7d 20 73 77 61 70 0a 20 20 20 20 6b 65 fd } swap. ke
0320: 79 73 69 7a 65 20 66 64 20 77 72 69 74 65 2d 66 ysize fd write-f
0330: 69 6c 65 20 74 68 72 6f 77 0a 20 20 20 20 6b 65 ile throw. ke
0340: 79 73 69 7a 65 20 66 64 20 77 72 69 74 65 2d 66 ysize fd write-f
0350: 69 6c 65 20 74 68 72 6f 77 0a 20 20 20 20 66 64 ile throw. fd
0360: 20 63 6c 6f 73 65 2d 66 69 6c 65 20 74 68 72 6f close-file thro
0370: 77 20 3b 0a 0a 6b 65 79 73 69 7a 65 20 62 75 66 w ;..keysize buf
0380: 66 65 72 3a 20 74 65 73 74 6b 65 79 0a 6b 65 79 fer: testkey.key
0390: 73 69 7a 65 20 62 75 66 66 65 72 3a 20 74 65 73 size buffer: tes
03a0: 74 73 6b 63 0a 6b 65 79 73 69 7a 65 20 62 75 66 tskc.keysize buf
03b0: 66 65 72 3a 20 70 61 73 73 73 6b 63 0a 0a 3a 20 fer: passskc..:
03c0: 63 68 65 63 6b 2d 6b 65 79 3f 20 28 20 61 64 64 check-key? ( add
03d0: 72 20 2d 2d 20 66 6c 61 67 20 29 20 20 3e 72 0a r -- flag ) >r.
03e0: 20 20 20 20 74 65 73 74 6b 65 79 20 72 40 20 62 testkey r@ b
03f0: 61 73 65 39 20 63 72 79 70 74 6f 5f 73 63 61 6c ase9 crypto_scal
0400: 61 72 6d 75 6c 74 0a 20 20 20 20 74 65 73 74 6b armult. testk
0410: 65 79 20 6b 65 79 73 69 7a 65 20 70 6b 63 20 6f ey keysize pkc o
0420: 76 65 72 20 73 74 72 3d 20 49 46 20 20 72 40 20 ver str= IF r@
0430: 73 6b 63 20 6b 65 79 73 69 7a 65 20 6d 6f 76 65 skc keysize move
0440: 20 20 74 72 75 65 0a 20 20 20 20 45 4c 53 45 20 true. ELSE
0450: 20 66 61 6c 73 65 20 20 54 48 45 4e 20 20 72 64 false THEN rd
0460: 72 6f 70 20 3b 0a 0a 33 20 56 61 6c 75 65 20 70 rop ;..3 Value p
0470: 61 73 73 70 68 72 61 73 65 2d 72 65 74 72 79 23 assphrase-retry#
0480: 0a 24 31 30 30 20 56 61 6c 75 65 20 70 61 73 73 .$100 Value pass
0490: 70 68 72 61 73 65 2d 64 69 66 66 75 73 65 23 0a phrase-diffuse#.
04a0: 0a 3a 20 67 65 74 2d 70 61 73 73 70 68 72 61 73 .: get-passphras
04b0: 65 20 28 20 61 64 64 72 69 6e 20 2d 2d 20 61 64 e ( addrin -- ad
04c0: 64 72 6f 75 74 20 29 0a 20 20 20 20 70 61 73 73 drout ). pass
04d0: 73 6b 63 20 6b 65 79 73 69 7a 65 20 6d 6f 76 65 skc keysize move
04e0: 20 20 20 77 75 72 73 74 2d 73 6f 75 72 63 65 20 wurst-source
04f0: 21 6b 65 79 0a 20 20 20 20 6d 65 73 73 61 67 65 !key. message
0500: 20 73 74 61 74 65 23 20 38 20 2a 20 32 64 75 70 state# 8 * 2dup
0510: 20 61 63 63 65 70 74 2a 20 64 75 70 20 3e 72 20 accept* dup >r
0520: 73 61 66 65 2f 73 74 72 69 6e 67 20 65 72 61 73 safe/string eras
0530: 65 0a 20 20 20 20 72 3e 20 49 46 0a 09 73 6f 75 e. r> IF..sou
0540: 72 63 65 2d 69 6e 69 74 20 77 75 72 73 74 2d 6b rce-init wurst-k
0550: 65 79 20 68 61 73 68 2d 69 6e 69 74 0a 09 6d 65 ey hash-init..me
0560: 73 73 61 67 65 20 72 6f 75 6e 64 73 68 23 20 72 ssage roundsh# r
0570: 6f 75 6e 64 73 0a 09 70 61 73 73 70 68 72 61 73 ounds..passphras
0580: 65 2d 64 69 66 66 75 73 65 23 20 30 20 3f 44 4f e-diffuse# 0 ?DO
0590: 20 20 73 74 61 72 74 2d 64 69 66 66 75 73 65 20 start-diffuse
05a0: 20 4c 4f 4f 50 20 5c 20 6a 75 73 74 20 74 6f 20 LOOP \ just to
05b0: 77 61 73 74 65 20 74 69 6d 65 20 3b 2d 29 0a 09 waste time ;-)..
05c0: 77 75 72 73 74 2d 73 74 61 74 65 20 70 61 73 73 wurst-state pass
05d0: 73 6b 63 20 6b 65 79 73 69 7a 65 20 78 6f 72 73 skc keysize xors
05e0: 0a 09 77 75 72 73 74 2d 73 74 61 74 65 20 6b 65 ..wurst-state ke
05f0: 79 73 69 7a 65 20 2b 20 70 61 73 73 73 6b 63 20 ysize + passskc
0600: 6b 65 79 73 69 7a 65 20 78 6f 72 73 0a 20 20 20 keysize xors.
0610: 20 54 48 45 4e 20 20 70 61 73 73 73 6b 63 20 3b THEN passskc ;
0620: 0a 0a 56 61 72 69 61 62 6c 65 20 6b 65 79 66 69 ..Variable keyfi
0630: 6c 65 0a 0a 3a 20 3e 6b 65 79 2d 6e 61 6d 65 20 le..: >key-name
0640: 28 20 61 64 64 72 20 75 20 2d 2d 20 29 0a 20 20 ( addr u -- ).
0650: 20 20 73 22 20 7e 2f 2e 6e 65 74 32 6f 2f 22 20 s" ~/.net2o/"
0660: 6b 65 79 66 69 6c 65 20 24 21 20 0a 20 20 20 20 keyfile $! .
0670: 6b 65 79 66 69 6c 65 20 24 2b 21 20 73 22 20 2e keyfile $+! s" .
0680: 65 63 63 22 20 6b 65 79 66 69 6c 65 20 24 2b 21 ecc" keyfile $+!
0690: 20 3b 0a 0a 3a 20 6b 65 79 2d 6e 61 6d 65 20 28 ;..: key-name (
06a0: 20 2d 2d 20 29 20 20 6b 65 79 66 69 6c 65 20 40 -- ) keyfile @
06b0: 20 3f 45 58 49 54 0a 20 20 20 20 2e 22 20 49 44 ?EXIT. ." ID
06c0: 20 6e 61 6d 65 3a 20 22 20 70 61 64 20 31 30 30 name: " pad 100
06d0: 20 61 63 63 65 70 74 20 70 61 64 20 73 77 61 70 accept pad swap
06e0: 20 3e 6b 65 79 2d 6e 61 6d 65 20 3b 0a 0a 3a 20 >key-name ;..:
06f0: 72 65 61 64 2d 6b 65 79 73 20 28 20 2d 2d 20 29 read-keys ( -- )
0700: 20 20 3f 2e 6e 65 74 32 6f 20 6b 65 79 2d 6e 61 ?.net2o key-na
0710: 6d 65 0a 20 20 20 20 70 6b 63 20 74 65 73 74 73 me. pkc tests
0720: 6b 63 20 6b 65 79 66 69 6c 65 20 24 40 20 6b 65 kc keyfile $@ ke
0730: 79 73 2d 69 6e 0a 20 20 20 20 74 65 73 74 73 6b ys-in. testsk
0740: 63 20 63 68 65 63 6b 2d 6b 65 79 3f 20 3f 45 58 c check-key? ?EX
0750: 49 54 0a 20 20 20 20 70 61 73 73 70 68 72 61 73 IT. passphras
0760: 65 2d 72 65 74 72 79 23 20 30 20 3f 44 4f 0a 09 e-retry# 0 ?DO..
0770: 63 72 20 2e 22 20 50 61 73 73 70 68 72 61 73 65 cr ." Passphrase
0780: 3a 20 22 0a 09 74 65 73 74 73 6b 63 20 67 65 74 : "..testskc get
0790: 2d 70 61 73 73 70 68 72 61 73 65 20 63 68 65 63 -passphrase chec
07a0: 6b 2d 6b 65 79 3f 20 49 46 20 20 75 6e 6c 6f 6f k-key? IF unloo
07b0: 70 20 20 45 58 49 54 20 20 54 48 45 4e 0a 20 20 p EXIT THEN.
07c0: 20 20 4c 4f 4f 50 20 20 21 21 6e 6f 6b 65 79 21 LOOP !!nokey!
07d0: 21 20 3b 0a 0a 3a 20 6e 65 77 2d 70 61 73 73 70 ! ;..: new-passp
07e0: 68 72 61 73 65 20 28 20 2d 2d 20 29 0a 20 20 20 hrase ( -- ).
07f0: 20 70 61 73 73 70 68 72 61 73 65 2d 72 65 74 72 passphrase-retr
0800: 79 23 20 30 20 3f 44 4f 0a 09 63 72 20 2e 22 20 y# 0 ?DO..cr ."
0810: 45 6e 74 65 72 20 50 61 73 73 70 68 72 61 73 65 Enter Passphrase
0820: 3a 20 22 20 20 20 20 20 20 20 73 6b 63 20 67 65 : " skc ge
0830: 74 2d 70 61 73 73 70 68 72 61 73 65 0a 09 74 65 t-passphrase..te
0840: 73 74 73 6b 63 20 6b 65 79 73 69 7a 65 20 6d 6f stskc keysize mo
0850: 76 65 0a 09 63 72 20 2e 22 20 52 65 65 6e 74 65 ve..cr ." Reente
0860: 72 20 50 61 73 73 70 68 72 61 73 65 3a 20 22 20 r Passphrase: "
0870: 20 20 20 20 73 6b 63 20 67 65 74 2d 70 61 73 73 skc get-pass
0880: 70 68 72 61 73 65 0a 09 74 65 73 74 73 6b 63 20 phrase..testskc
0890: 6b 65 79 73 69 7a 65 20 74 75 63 6b 20 73 74 72 keysize tuck str
08a0: 3d 20 49 46 20 20 75 6e 6c 6f 6f 70 20 20 45 58 = IF unloop EX
08b0: 49 54 20 20 54 48 45 4e 0a 20 20 20 20 4c 4f 4f IT THEN. LOO
08c0: 50 20 20 21 21 6e 6f 6b 65 79 21 21 20 3b 0a 0a P !!nokey!! ;..
08d0: 3a 20 77 72 69 74 65 2d 6b 65 79 73 20 28 20 2d : write-keys ( -
08e0: 2d 20 29 20 20 3f 2e 6e 65 74 32 6f 20 6b 65 79 - ) ?.net2o key
08f0: 2d 6e 61 6d 65 0a 20 20 20 20 6e 65 77 2d 70 61 -name. new-pa
0900: 73 73 70 68 72 61 73 65 0a 20 20 20 20 70 6b 63 ssphrase. pkc
0910: 20 74 65 73 74 73 6b 63 20 6b 65 79 66 69 6c 65 testskc keyfile
0920: 20 24 40 20 6b 65 79 73 2d 6f 75 74 20 3b 0a 0a $@ keys-out ;..
0930: 3a 20 3f 6b 65 79 70 61 69 72 20 28 20 2d 2d 20 : ?keypair ( --
0940: 29 0a 20 20 20 20 5b 27 5d 20 72 65 61 64 2d 6b ). ['] read-k
0950: 65 79 73 20 63 61 74 63 68 20 49 46 20 20 6e 6f eys catch IF no
0960: 74 68 72 6f 77 20 67 65 6e 2d 6b 65 79 73 20 77 throw gen-keys w
0970: 72 69 74 65 2d 6b 65 79 73 20 20 54 48 45 4e 20 rite-keys THEN
0980: 3b 0a 0a ;..