NAME

whatbot::Message - Wrapper class for whatbot message passing

SYNOPSIS

 use whatbot::Message;
 
 my $message = whatbot::Message->new(
	'from'    => $me,
	'to'      => 'a_user',
	'content' => 'test message'
 );

DESCRIPTION

whatbot::Message is a container class for incoming and outgoing messages. Each whatbot component, when sending or receiving a message via a whatbot::IO class will pass these objects, and messages sent through a whatbot::Command is encouraged to use these objects. Messages sent without this class will be converted during the IO transaction.

PUBLIC ACCESSORS

from

User or entity the message is from

to

User or entity the message is to

content

Content of the message

timestamp

Timestamp of the message, in unix time.

is_private

Boolean (1/0), if the message was private or posted in a public channel.

is_direct

Boolean (1/0), if the message called the bot out by name

invisible

Boolean (1/0), if this message should not be processed by seen or other monitors.

me

String value of the bot's username.

origin

String containing the IO target signature, name:to. So, for an IRC server called irc.example.org, channel #foo, this would be IRC_irc.example.org:#foo.

METHODS

content_utf8()

Return message content as converted by encode_utf8.

is_private()

Determine if message is a private message, by checking if "to" matches "me".

reply( \%overrides )

Generate a whatbot::Message in reply to the current message. If is_private is true, to will be set to the originator, otherwise, it will be set to the public context for public IO. Optionally handles an override hashref to preset fields, similar to the new constructor.

clone()

Return a new whatbot::Message with the same content as the current message. References inside the object are reused, not duplicated.

LICENSE/COPYRIGHT

Be excellent to each other and party on, dudes.