Skip to content

Latest commit

 

History

History
83 lines (66 loc) · 4.42 KB

README.md

File metadata and controls

83 lines (66 loc) · 4.42 KB

DalekIRC's UnrealIRCd Add-On

This module compliments UnrealIRCd with its keen compatibility and extended functionality with DalekIRC Services for WordPress.

Requires UnrealIRCd 6 or later.

Background

We're doing away with services bots, and moving their commands server-side!

So you'll just do /COMMAND instead of any /ns COMMAND or indeed /msg nickserv COMMAND.

Advantages

  • Configure who can do what using the UnrealIRCd configuration. This keeps configuration all in one place.
  • Use UnrealIRCd operclass blocks to fully customise who can do what. For example, you can choose which oper can use the /SUSPEND command by specifying it in the Operclass block. See below for how to set up your operblock.
  • A more native feel for clients, for example, proper numerics and standard replies (ircv3) regarding reasons /CREGISTER might have failed (Example, ERR_CHANOPRIVSNEEDED)
  • Sideswipes security issues pertaining to the many clients and scripts out there who assume it's okay to message a bot with sensitive information. An example of this is the fact that some networks do not use NickServ as their authentication mechanism, and instead could use something called "X" or something completely different.

This compliments other things that have moved to server commands for security reasons, and is, for example, the reason why SASL and Account Registration (both server-side commands) exists in IRC. It just makes sense.

Channel Modes Implemented By DalekIRC

Mode Name Params Description
y VoteBan 1-100 Indicates that regular channel users may vote a person out of the channel. Parameter is amount of votes required.

Commands Implemented By DalekIRC

Command Name Description
AJOIN Auto-Join This command lets you view and manage your auto-join list.
CREGISTER Channel Register This command lets you register a channel to your account.
MAIL Mail This command lets you send messages to users who are offline. They will see them as normal messages when they come back online.
SUSPEND Suspend This command lets privileged opers with operclass type services { can_suspend; } prevent a specific account from being used.
UNSUSPEND Unsuspend This command lets privileged opers with operclass type services { can_unsuspend; } unsuspend accounts.
CERTFP Certificate Fingerprint This command lets you view and manage your authentication fingerprints used in SASL
VOTEBAN Vote Ban This command lets non-ops in +y enabled channels vote to ban users

OperClass Permissions

In order to use certain commands, you'll need to give some permissions in your Operclass block.

This list is updated as and when things are added and required, but, as per the Work-In-Progress sign at the top, please expect changes. If you think this list looks incomplete, that will be why =]

operclass example-services-boss {
  permissions {
    // here is the important part
    services {
      can_suspend;
      can_unsuspend;
    }
  }

Command Restriction

It's really easy to restrict or limit commands to users who meet a certain criteria, or restrict them completely, using UnrealIRCd's set::restrict-commands block.

Here are some examples.

set { /* our set block */
  restrict-commands { /* the option we need */
  
    voteban { /* we are restricting voteban! */
      except { /* with the exception of */
        reputation-score 60; /* can use command when they are valid enough */
      }
    }
    
    cregister { /* also restricting channel registration! */
      except { /* with the exception of */
        connect-time 60; /* can use command after 60 seconds */
      }
    }
    
    mail { /* restricting mail! */
      except { /* with the exception of */
        webirc yes; /* restrict to web users */
      }
    }
  }
}