Sha256: 4511a1ac64b635a9e4cdcbf07a49a177458d50d942be85cd598b37d912a8c0b2
Contents?: true
Size: 1.16 KB
Versions: 19
Compression:
Stored size: 1.16 KB
Contents
/** * OFBMode * * An ActionScript 3 implementation of the OFB confidentiality mode * Copyright (c) 2007 Henri Torgemane * * See LICENSE.txt for full license information. */ package com.hurlant.crypto.symmetric { import flash.utils.ByteArray; public class OFBMode extends IVMode implements IMode { public function OFBMode(key:ISymmetricKey, padding:IPad=null) { super(key, null); } public function encrypt(src:ByteArray):void { var vector:ByteArray = getIV4e(); core(src, vector); } public function decrypt(src:ByteArray):void { var vector:ByteArray = getIV4d(); core(src, vector); } private function core(src:ByteArray, iv:ByteArray):void { var l:uint = src.length; var tmp:ByteArray = new ByteArray; for (var i:uint=0;i<src.length;i+=blockSize) { key.encrypt(iv); tmp.position=0; tmp.writeBytes(iv); var chunk:uint = (i+blockSize<l)?blockSize:l-i; for (var j:uint=0;j<chunk;j++) { src[i+j] ^= iv[j]; } iv.position=0; iv.writeBytes(tmp); } } public function toString():String { return key.toString()+"-ofb"; } } }
Version data entries
19 entries across 19 versions & 4 rubygems