PersistenceService

The Persistence service melds new IRCUsers (from post-processing new IRCEvents) with old records of themselves.

Sometimes the only bit of information about a sender (or target) embedded in an IRCEvent may be his/her nickname, even though the event before detailed everything, even including their account name. With this service we aim to complete such IRCUser entries as the union of everything we know from previous events.

It only needs part of UserAwareness for minimal bookkeeping, not the full package, so we only copy/paste the relevant bits to stay slim.

Members

Enums

Placeholder
enum Placeholder

Placeholder values.

Variables

channelUsers
RehashingAA!(IRCUser.Class[string])[string] channelUsers;

Associative array of permanent user classifications, per account and channel name.

hostmaskNicknameAccountCache
RehashingAA!(string[string]) hostmaskNicknameAccountCache;

Cached nicknames matched to defined hostmasks.

hostmaskUsers
IRCUser[] hostmaskUsers;

Hostmask definitions as read from file. Should be considered read-only.

hostmasksFile
string hostmasksFile;

File with user hostmasks.

userClassChannelCache
RehashingAA!(string[string]) userClassChannelCache;

Associative array of which channel the latest class lookup for an account related to.

userFile
string userFile;

File with user definitions.

users
RehashingAA!(IRCUser[string]) users;

Associative array of users. Replaces IRCPluginState.users.

Mixed In Members

From mixin IRCPluginImpl

isEnabled
bool isEnabled()

Introspects the current plugin, looking for a Settings-annotated struct member that has a bool annotated with Enabler, which denotes it as the bool that toggles a plugin on and off.

onEvent
void onEvent(IRCEvent event)

Forwards the supplied IRCEvent to IRCPluginImpl.onEventImpl.

this
this(IRCPluginState state)

Basic constructor for a plugin.

postprocess
void postprocess(IRCEvent event)

Lets a plugin modify an IRCEvent while it's begin constructed, before it's finalised and passed on to be handled.

initResources
void initResources()

Writes plugin resources to disk, creating them if they don't exist.

deserialiseConfigFrom
void deserialiseConfigFrom(string configFile, string[][string] missingEntries, string[][string] invalidEntries)

Loads configuration for this plugin from disk.

setSettingByName
bool setSettingByName(string setting, string value)

Change a plugin's Settings-annotated settings struct member by their string name.

printSettings
void printSettings()

Prints the plugin's Settings-annotated settings struct.

serialiseConfigInto
bool serialiseConfigInto(Appender!(char[]) sink)

Gathers the configuration text the plugin wants to contribute to the configuration file.

tick
bool tick(Duration elapsed)

Tick function. Called once every main loop iteration.

selftest
Ternary selftest(Selftester tester)

Self-test function.

name
string name()

Returns the name of the plugin. (Technically it's the name of the module.)

channelSpecificCommands
IRCPlugin.CommandMetadata[string] channelSpecificCommands(string channelName)

Compile a list of our a plugin's oneliner commands.

commands
IRCPlugin.CommandMetadata[string] commands()

Forwards to IRCPluginImpl.commandsImpl.

onBusMessage
void onBusMessage(string header, Sendable content)

Proxies a bus message to the plugin, to let it handle it (or not).

Inherited Members

From IRCPlugin

CommandMetadata
struct CommandMetadata

Metadata about a IRCEventHandler.Command- and/or IRCEventHandler.Regex-annotated event handler.

state
IRCPluginState state;

An IRCPluginState instance containing variables and arrays that represent the current state of the plugin. Should generally be passed by reference.

postprocess
void postprocess(IRCEvent event)

Allows a plugin to modify an event post-parsing.

onEvent
void onEvent(IRCEvent event)

Called to let the plugin react to a new event, parsed from the server.

initResources
void initResources()

Called when the plugin is requested to initialise its disk resources.

deserialiseConfigFrom
void deserialiseConfigFrom(string configFile, string[][string] missingEntries, string[][string] invalidEntries)

Reads serialised configuration text into the plugin's settings struct.

serialiseConfigInto
bool serialiseConfigInto(Appender!(char[]) sink)

Called to let the plugin contribute settings when writing the configuration file.

setSettingByName
bool setSettingByName(string setting, string value)

Called when we want to change a setting by its string name.

setup
void setup()

Called at program start but before connection has been established.

printSettings
void printSettings()

Called when we want a plugin to print its Settings-annotated struct of settings.

teardown
void teardown()

Called during shutdown of a connection; a plugin's would-be destructor.

name
string name()

Returns the name of the plugin.

commands
CommandMetadata[string] commands()

Returns an array of the descriptions of the commands a plugin offers.

channelSpecificCommands
CommandMetadata[string] channelSpecificCommands(string channelName)

Returns an array of the descriptions of the channel-specific commands a plugin offers.

reload
void reload()

Reloads the plugin, where such is applicable.

onBusMessage
void onBusMessage(string header, Sendable content)

Called when a bus message arrives from another plugin.

isEnabled
bool isEnabled()

Returns whether or not the plugin is enabled in its settings.

tick
bool tick(Duration elapsed)

Called on each iteration of the main loop.

initialise
void initialise()

Called when the plugin is first loaded.

Ternary (from std.typecons)
public import std.typecons : Ternary;
Undocumented in source.
selftest
Ternary selftest(Selftester )

Performs self-tests against another bot.