-------------- Agent.pm v3.20 -------------- Copyright (c) 1997-1998 Steve Purkis. All rights reserved. The Agent module can be distributed or modified under the 'Artistic License', as distributed with Perl. The author guarantees nothing about anything to do with this module; you use it at your own risk. Welcome to the 3.2 release of Agent Perl, the first full release of this module! This file contains a brief overview of Agent Perl, and some things that you'll need to know in order to get it up and running on your system. Overview -------- Agent Perl provides both a foundation for software agent developers, and a standardized API for the agent's users. Agent's two most prominent features are its support for agent transportation and abstract messaging over different mediums. [A transportable perl agent is Perl code that can communicate with other disparate entities, and can migrate between computers over a heterogeneous network to perform some task for a client.] Prerequisites ------------- Required Modules: Class::Tom 2.04+ (3.x not supported!) MD5 Optional module for *alpha* threads support: Thread Platforms: U*nix & Win32 Mac? OS/2? Using Agents ------------ First of all, make sure you know how to use an object (the perlobj manpage is a good place to start). Then read the Agent.pm's POD, and that of the agent you are trying to use. After that, you're on your own, unless there are any examples lying around :-). If you would like to use the security features of Agent Perl, browse through the Safe and Opcode PODs, and have a gander at 'Safe.readme'. Developing Agents ----------------- After you've read this, read the PODs for Agent.pm and all of its nested modules. Read *.readme in the root directory. Then have a look in the 'examples' sub-directory for some functional *sample* agents. Make *sure* you don't step on Agent.pm's toes by redefining the Message or Transport subclasses. An agent is simply an object. It inherits methods from the Agent package. So to define an agent, all you need to do is define its class. There are some rules you should adhere to, however: 1. An agent's class should be saved in a suitable <agentname>.pa file. 2. All agents should inherit from the 'Agent' package. 3. All agents must have an 'agent_main()' method. 4. An agent's state variables should be stored within the agent's object, and NOT within the class. 5. Document your agent, preferably with POD! Additional notes: The agent's class _should_ be a sub-class of Agent itself. Here's a good naming scheme for your agents: package Agent::YourAgentName; Because '.pa' files are not necessarily stored in a central place, they need not be unique. For example, if two different users define two different 'RWho.pa' agents in two different locations, the do not need to worry which .pa file will be used. PS: If you come up with a functional agent, I'd love to hear about it! Down the road... ---------------- If this release of Agent looks promising, I hope to include support for PGP encryption & signatures, the KQML/KIF communication standards (underway!), and more. Links ----- The Homepage: http://www.epn.ml.org/~spurkis/Agent The Mailing List: perl5-agents@daft.com Any questions, comments, bug reports, or suggestions you may have, I'd like to hear about. Enjoy! +--- Steve Purkis <spurkis@engsoc.carleton.ca> December 15, 1998