|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES All Classes | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Objectptolemy.kernel.util.NamedObj
ptolemy.kernel.InstantiableNamedObj
ptolemy.kernel.Entity
ptolemy.kernel.ComponentEntity
ptolemy.actor.AtomicActor
ptolemy.actor.TypedAtomicActor
ptolemy.actor.lib.security.CryptographyActor
public abstract class CryptographyActor
A base class for cryptographic actors.
Cryptographic actors are actors that perform encryption or decryption or generate signatures of data.
Actors extending this class take in an unsigned byte array at the input, process the data based on the algorithm parameter and send an unsigned byte array to the output. The algorithms that maybe implemented are limited those that are implemented by "providers" following the Java Cryptography Extension (JCE) specifications and installed on the machine being run. If a provider specific instance of an algorithm is needed, the provider may be specified in the provider parameter. The keySize also allows implementations of algorithms using various key sizes.
Concrete actors derived from this base class must include a
_process(byte[])
method that processes the data appropriately.
The _process() method is called by CryptographyActor.fire().
This class takes care of basic initialization of the algorithm
and provider parameters for use by the subclasses.
This actor relies on the Java Cryptography Architecture (JCA) and Java
Cryptography Extension (JCE).
Information about JCA can be found at
http://java.sun.com/j2se/1.4.2/docs/guide/security/CryptoSpec.html.
Information about JCE can be found at
http://java.sun.com/products/jce/.
The Java 1.2 security tutorial can be found at
http://java.sun.com/docs/books/tutorial/security1.2/index.html
Another Java security tutorial can be found at
http://developer.java.sun.com/developer/onlineTraining/Security/Fundamentals/index.html
Yellow (cxh) |
Green (cxh) |
Nested Class Summary |
---|
Nested classes/interfaces inherited from class ptolemy.kernel.Entity |
---|
Entity.ContainedObjectsIterator |
Field Summary | |
---|---|
protected java.lang.String |
_algorithm
The name of the algorithm to be used. |
protected int |
_keySize
The key size to be used when processing information. |
protected java.lang.String |
_provider
The provider to be used for a provider specific implementation. |
StringParameter |
algorithm
Specify the algorithm to be used to process data. |
TypedIOPort |
input
The input port. |
Parameter |
keySize
Specify the size of the key to be created. |
TypedIOPort |
output
The output port. |
StringParameter |
provider
Specify a provider for the given algorithm. |
Fields inherited from class ptolemy.actor.AtomicActor |
---|
_actorFiringListeners, _initializables, _notifyingActorFiring, _stopRequested |
Fields inherited from class ptolemy.kernel.util.NamedObj |
---|
_changeListeners, _changeLock, _changeRequests, _debugging, _debugListeners, _elementName, _isPersistent, _verbose, _workspace, ATTRIBUTES, CLASSNAME, COMPLETE, CONTENTS, DEEP, FULLNAME, LINKS |
Fields inherited from interface ptolemy.actor.Executable |
---|
COMPLETED, NOT_READY, STOP_ITERATING |
Constructor Summary | |
---|---|
CryptographyActor(CompositeEntity container,
java.lang.String name)
Construct an actor with the given container and name. |
Method Summary | |
---|---|
protected abstract byte[] |
_process(byte[] dataBytes)
Process the input data based on parameter specifications. |
void |
attributeChanged(Attribute attribute)
Override the base class to reinitialize the state if the algorithm, keySize, or provider parameter is changed. |
void |
fire()
Read data from the from the input and process the data based on the algorithm, and provider by calling _process(byte []) . |
Methods inherited from class ptolemy.actor.TypedAtomicActor |
---|
_addPort, _fireAt, _fireAt, attributeTypeChanged, clone, newPort, typeConstraintList, typeConstraints |
Methods inherited from class ptolemy.kernel.ComponentEntity |
---|
_adjustDeferrals, _checkContainer, _getContainedObject, _propagateExistence, getContainer, instantiate, isAtomic, isOpaque, moveDown, moveToFirst, moveToIndex, moveToLast, moveUp, propagateExistence, setName |
Methods inherited from class ptolemy.kernel.Entity |
---|
_description, _exportMoMLContents, _removePort, _validateSettables, connectedPortList, connectedPorts, containedObjectsIterator, getAttribute, getPort, getPorts, linkedRelationList, linkedRelations, portList, removeAllPorts, setClassDefinition, uniqueName |
Methods inherited from class ptolemy.kernel.InstantiableNamedObj |
---|
_setParent, exportMoML, getChildren, getElementName, getParent, getPrototypeList, isClassDefinition, isWithinClassDefinition |
Methods inherited from class java.lang.Object |
---|
equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait |
Methods inherited from interface ptolemy.actor.Actor |
---|
createReceivers, getCausalityInterface, getDirector, getExecutiveDirector, getManager, inputPortList, newReceiver, outputPortList |
Methods inherited from interface ptolemy.actor.Executable |
---|
isFireFunctional, isStrict, iterate, postfire, prefire, stop, stopFire, terminate |
Methods inherited from interface ptolemy.actor.Initializable |
---|
addInitializable, initialize, preinitialize, removeInitializable, wrapup |
Methods inherited from interface ptolemy.kernel.util.Nameable |
---|
description, getContainer, getDisplayName, getFullName, getName, getName, setName |
Methods inherited from interface ptolemy.kernel.util.Derivable |
---|
getDerivedLevel, getDerivedList, propagateValue |
Field Detail |
---|
public StringParameter algorithm
public TypedIOPort input
public Parameter keySize
DSA is the most common algorithm that uses keySize, the Sun documentation says: "The length, in bits, of the modulus p. This must range from 512 to 1024, and must be a multiple of 64. The default keysize is 1024." Refer to http://java.sun.com/j2se/1.4.2/docs/guide/security/CryptoSpec.html#AppB for a list of possible key sizes for certain algorithms. The initial default is 1024.
public TypedIOPort output
public StringParameter provider
protected java.lang.String _algorithm
protected int _keySize
protected java.lang.String _provider
Constructor Detail |
---|
public CryptographyActor(CompositeEntity container, java.lang.String name) throws NameDuplicationException, IllegalActionException
container
- The container.name
- The name of this actor.
IllegalActionException
- If the actor cannot be contained
by the proposed container.
NameDuplicationException
- If the container already has an
actor with this name.Method Detail |
---|
public void attributeChanged(Attribute attribute) throws IllegalActionException
attributeChanged
in class NamedObj
attribute
- The attribute that changed.
IllegalActionException
- Not thrown in this base class.public void fire() throws IllegalActionException
_process(byte [])
. The transformed data is then sent to
the output port.
fire
in interface Executable
fire
in class AtomicActor
IllegalActionException
- If thrown by the base class or
if there is a problem processing the data.protected abstract byte[] _process(byte[] dataBytes) throws IllegalActionException
dataBytes
- The data to be processed.
IllegalActionException
- Not thrown in this base class
|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES All Classes | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |