summaryrefslogtreecommitdiff
path: root/appl/cmd/ssh/cipherrc4.b
diff options
context:
space:
mode:
Diffstat (limited to 'appl/cmd/ssh/cipherrc4.b')
-rw-r--r--appl/cmd/ssh/cipherrc4.b41
1 files changed, 41 insertions, 0 deletions
diff --git a/appl/cmd/ssh/cipherrc4.b b/appl/cmd/ssh/cipherrc4.b
new file mode 100644
index 00000000..fc6378ef
--- /dev/null
+++ b/appl/cmd/ssh/cipherrc4.b
@@ -0,0 +1,41 @@
+implement Cipher;
+
+include "sys.m";
+
+include "keyring.m";
+ kr: Keyring;
+ RC4state: import kr;
+
+include "sshio.m";
+
+Cipherstate: adt
+{
+ enc: ref RC4state;
+ dec: ref RC4state;
+};
+
+cs: ref Cipherstate;
+
+id(): int
+{
+ return SSH_CIPHER_RC4;
+}
+
+init(key: array of byte, isserver: int)
+{
+ kr = load Keyring Keyring->PATH;
+ if(isserver)
+ cs = ref Cipherstate(kr->rc4setup(key[0:16]), kr->rc4setup(key[16:32]));
+ else
+ cs = ref Cipherstate(kr->rc4setup(key[16:32]), kr->rc4setup(key[0:16]));
+}
+
+encrypt(buf: array of byte, nbuf: int)
+{
+ kr->rc4(cs.enc, buf, nbuf);
+}
+
+decrypt(buf: array of byte, nbuf: int)
+{
+ kr->rc4(cs.dec, buf, nbuf);
+}