| @@ -86,20 +86,25 @@ matrix_appservice_irc_ircService_servers: [] # noqa var-naming | |||||
| # # It is also used in the Third Party Lookup API as the instance `desc` | # # It is also used in the Third Party Lookup API as the instance `desc` | ||||
| # # property, where each server is an instance. | # # property, where each server is an instance. | ||||
| # name: "ExampleNet" | # name: "ExampleNet" | ||||
| # # Additional addresses to connect to, used for load balancing between IRCDs. | |||||
| # additionalAddresses: [ "irc2.example.com" ] | # additionalAddresses: [ "irc2.example.com" ] | ||||
| # # Typically additionalAddresses would be in addition to the address key given above, | |||||
| # # but some configurations wish to exclusively use additional addresses while reserving | |||||
| # # the top key for identification purposes. Set this to true to exclusively use the | |||||
| # # additionalAddresses array when connecting to servers. | |||||
| # onlyAdditionalAddresses: false | |||||
| # # | # # | ||||
| # # [DEPRECATED] Use `name`, above, instead. | # # [DEPRECATED] Use `name`, above, instead. | ||||
| # # A human-readable description string | # # A human-readable description string | ||||
| # # description: "Example.com IRC network" | # # description: "Example.com IRC network" | ||||
| # | |||||
| # # An ID for uniquely identifying this server amongst other servers being bridged. | # # An ID for uniquely identifying this server amongst other servers being bridged. | ||||
| # # networkId: "example" | # # networkId: "example" | ||||
| # # URL to an icon used as the network icon whenever this network appear in | |||||
| # # a network list. (Like in the Riot room directory, for instance.) | |||||
| # # icon: https://example.com/images/hash.png | |||||
| # | |||||
| # # MXC URL to an icon used as the network icon whenever this network appear in | |||||
| # # a network list. (Like in the Element room directory, for instance.) | |||||
| # # icon: mxc://matrix.org/LpsSLrbANVrEIEOgEaVteItf | |||||
| # | |||||
| # # The port to connect to. Optional. | # # The port to connect to. Optional. | ||||
| # port: 6697 | # port: 6697 | ||||
| # # Whether to use SSL or not. Default: false. | # # Whether to use SSL or not. Default: false. | ||||
| @@ -112,19 +117,26 @@ matrix_appservice_irc_ircService_servers: [] # noqa var-naming | |||||
| # # Whether to allow expired certs when connecting to the IRC server. | # # Whether to allow expired certs when connecting to the IRC server. | ||||
| # # Usually this should be off. Default: false. | # # Usually this should be off. Default: false. | ||||
| # allowExpiredCerts: false | # allowExpiredCerts: false | ||||
| # # A specific CA to trust instead of the default CAs. Optional. | |||||
| # #ca: | | |||||
| # # -----BEGIN CERTIFICATE----- | |||||
| # # … | |||||
| # # -----END CERTIFICATE----- | |||||
| # | |||||
| # # Set additional TLS options for the connections to the IRC server. | |||||
| # #tlsOptions: | |||||
| # # A specific CA to trust instead of the default CAs. Optional. | |||||
| # #ca: | | |||||
| # # -----BEGIN CERTIFICATE----- | |||||
| # # ... | |||||
| # # -----END CERTIFICATE----- | |||||
| # # Server name for the SNI (Server Name Indication) TLS extension. If the address you | |||||
| # # are using does not report the correct certificate name, you can override it here. | |||||
| # # servername: real.server.name | |||||
| # # ...or any options in https://nodejs.org/api/tls.html#tls_tls_connect_options_callback | |||||
| # | |||||
| # # | # # | ||||
| # # The connection password to send for all clients as a PASS (or SASL, if enabled above) command. Optional. | # # The connection password to send for all clients as a PASS (or SASL, if enabled above) command. Optional. | ||||
| # # password: 'pa$$w0rd' | # # password: 'pa$$w0rd' | ||||
| # # | # # | ||||
| # # Whether or not to send connection/error notices to real Matrix users. Default: true. | # # Whether or not to send connection/error notices to real Matrix users. Default: true. | ||||
| # sendConnectionMessages: true | # sendConnectionMessages: true | ||||
| # | |||||
| # quitDebounce: | # quitDebounce: | ||||
| # # Whether parts due to net-splits are debounced for delayMs, to allow | # # Whether parts due to net-splits are debounced for delayMs, to allow | ||||
| # # time for the netsplit to resolve itself. A netsplit is detected as being | # # time for the netsplit to resolve itself. A netsplit is detected as being | ||||
| @@ -144,13 +156,13 @@ matrix_appservice_irc_ircService_servers: [] # noqa var-naming | |||||
| # delayMinMs: 3600000 # 1h | # delayMinMs: 3600000 # 1h | ||||
| # # Default: 7200000, = 2h | # # Default: 7200000, = 2h | ||||
| # delayMaxMs: 7200000 # 2h | # delayMaxMs: 7200000 # 2h | ||||
| # | |||||
| # # A map for conversion of IRC user modes to Matrix power levels. This enables bridging | # # A map for conversion of IRC user modes to Matrix power levels. This enables bridging | ||||
| # # of IRC ops to Matrix power levels only, it does not enable the reverse. If a user has | # # of IRC ops to Matrix power levels only, it does not enable the reverse. If a user has | ||||
| # # been given multiple modes, the one that maps to the highest power level will be used. | # # been given multiple modes, the one that maps to the highest power level will be used. | ||||
| # modePowerMap: | # modePowerMap: | ||||
| # o: 50 | # o: 50 | ||||
| # v: 1 | |||||
| # botConfig: | # botConfig: | ||||
| # # Enable the presence of the bot in IRC channels. The bot serves as the entity | # # Enable the presence of the bot in IRC channels. The bot serves as the entity | ||||
| # # which maps from IRC -> Matrix. You can disable the bot entirely which | # # which maps from IRC -> Matrix. You can disable the bot entirely which | ||||
| @@ -173,6 +185,8 @@ matrix_appservice_irc_ircService_servers: [] # noqa var-naming | |||||
| # enabled: true | # enabled: true | ||||
| # # The nickname to give the AS bot. | # # The nickname to give the AS bot. | ||||
| # nick: "MatrixBot" | # nick: "MatrixBot" | ||||
| # # The username to give to the AS bot. Defaults to "matrixbot" | |||||
| # username: "matrixbot" | |||||
| # # The password to give to NickServ or IRC Server for this nick. Optional. | # # The password to give to NickServ or IRC Server for this nick. Optional. | ||||
| # # password: "helloworld" | # # password: "helloworld" | ||||
| # # | # # | ||||
| @@ -181,7 +195,7 @@ matrix_appservice_irc_ircService_servers: [] # noqa var-naming | |||||
| # # real Matrix users in them, even if there is a mapping for the channel. | # # real Matrix users in them, even if there is a mapping for the channel. | ||||
| # # Default: true | # # Default: true | ||||
| # joinChannelsIfNoUsers: true | # joinChannelsIfNoUsers: true | ||||
| # | |||||
| # # Configuration for PMs / private 1:1 communications between users. | # # Configuration for PMs / private 1:1 communications between users. | ||||
| # privateMessages: | # privateMessages: | ||||
| # # Enable the ability for PMs to be sent to/from IRC/Matrix. | # # Enable the ability for PMs to be sent to/from IRC/Matrix. | ||||
| @@ -190,12 +204,12 @@ matrix_appservice_irc_ircService_servers: [] # noqa var-naming | |||||
| # # Prevent Matrix users from sending PMs to the following IRC nicks. | # # Prevent Matrix users from sending PMs to the following IRC nicks. | ||||
| # # Optional. Default: []. | # # Optional. Default: []. | ||||
| # # exclude: ["Alice", "Bob"] # NOT YET IMPLEMENTED | # # exclude: ["Alice", "Bob"] # NOT YET IMPLEMENTED | ||||
| # | |||||
| # # Should created Matrix PM rooms be federated? If false, only users on the | # # Should created Matrix PM rooms be federated? If false, only users on the | ||||
| # # HS attached to this AS will be able to interact with this room. | # # HS attached to this AS will be able to interact with this room. | ||||
| # # Optional. Default: true. | # # Optional. Default: true. | ||||
| # federate: true | # federate: true | ||||
| # | |||||
| # # Configuration for mappings not explicitly listed in the 'mappings' | # # Configuration for mappings not explicitly listed in the 'mappings' | ||||
| # # section. | # # section. | ||||
| # dynamicChannels: | # dynamicChannels: | ||||
| @@ -209,27 +223,34 @@ matrix_appservice_irc_ircService_servers: [] # noqa var-naming | |||||
| # # Should the AS publish the new Matrix room to the public room list so | # # Should the AS publish the new Matrix room to the public room list so | ||||
| # # anyone can see it? Default: true. | # # anyone can see it? Default: true. | ||||
| # published: true | # published: true | ||||
| # # Publish the rooms to the homeserver directory, as oppose to the appservice | |||||
| # # room directory. Only used if `published` is on. | |||||
| # # Default: false | |||||
| # useHomeserverDirectory: true | |||||
| # # What should the join_rule be for the new Matrix room? If 'public', | # # What should the join_rule be for the new Matrix room? If 'public', | ||||
| # # anyone can join the room. If 'invite', only users with an invite can | # # anyone can join the room. If 'invite', only users with an invite can | ||||
| # # join the room. Note that if an IRC channel has +k or +i set on it, | # # join the room. Note that if an IRC channel has +k or +i set on it, | ||||
| # # join_rules will be set to 'invite' until these modes are removed. | # # join_rules will be set to 'invite' until these modes are removed. | ||||
| # # Default: "public". | # # Default: "public". | ||||
| # joinRule: public | # joinRule: public | ||||
| # # This will set the m.room.related_groups state event in newly created rooms | |||||
| # # with the given groupId. This means flares will show up on IRC users in those rooms. | |||||
| # # This should be set to the same thing as namespaces.users.group_id in irc_registration. | |||||
| # # This does not alter existing rooms. | |||||
| # # Leaving this option empty will not set the event. | |||||
| # groupId: +myircnetwork:localhost | |||||
| # # Should created Matrix rooms be federated? If false, only users on the | # # Should created Matrix rooms be federated? If false, only users on the | ||||
| # # HS attached to this AS will be able to interact with this room. | # # HS attached to this AS will be able to interact with this room. | ||||
| # # Default: true. | # # Default: true. | ||||
| # federate: true | # federate: true | ||||
| # # Force this room version when creating IRC channels. Beware if the homeserver doesn't | |||||
| # # support the room version then the request will fail. By default, no version is requested. | |||||
| # # roomVersion: "1" | |||||
| # # The room alias template to apply when creating new aliases. This only | # # The room alias template to apply when creating new aliases. This only | ||||
| # # applies if createAlias is 'true'. The following variables are exposed: | # # applies if createAlias is 'true'. The following variables are exposed: | ||||
| # # $SERVER => The IRC server address (e.g. "irc.example.com") | # # $SERVER => The IRC server address (e.g. "irc.example.com") | ||||
| # # $CHANNEL => The IRC channel (e.g. "#python") | # # $CHANNEL => The IRC channel (e.g. "#python") | ||||
| # # This MUST have $CHANNEL somewhere in it. | # # This MUST have $CHANNEL somewhere in it. | ||||
| # # | |||||
| # # In certain circumstances you might want to bridge your whole IRC network as a | |||||
| # # homeserver (e.g. #matrix:libera.chat). For these use cases, you can set the | |||||
| # # template to just be $CHANNEL. Doing so will preclude you from supporting | |||||
| # # other prefix characters though. | |||||
| # # | |||||
| # # Default: '#irc_$SERVER_$CHANNEL' | # # Default: '#irc_$SERVER_$CHANNEL' | ||||
| # aliasTemplate: "#irc_$CHANNEL" | # aliasTemplate: "#irc_$CHANNEL" | ||||
| # # A list of user IDs which the AS bot will send invites to in response | # # A list of user IDs which the AS bot will send invites to in response | ||||
| @@ -241,7 +262,11 @@ matrix_appservice_irc_ircService_servers: [] # noqa var-naming | |||||
| # # Prevent the given list of channels from being mapped under any | # # Prevent the given list of channels from being mapped under any | ||||
| # # circumstances. | # # circumstances. | ||||
| # # exclude: ["#foo", "#bar"] | # # exclude: ["#foo", "#bar"] | ||||
| # | |||||
| # # excludedUsers: | |||||
| # # - regex: "@.*:evilcorp.com" | |||||
| # # kickReason: "We don't like Evilcorp" | |||||
| # | |||||
| # # Configuration for controlling how Matrix and IRC membership lists are | # # Configuration for controlling how Matrix and IRC membership lists are | ||||
| # # synced. | # # synced. | ||||
| # membershipLists: | # membershipLists: | ||||
| @@ -250,12 +275,12 @@ matrix_appservice_irc_ircService_servers: [] # noqa var-naming | |||||
| # # synced. This must be enabled for anything else in this section to take | # # synced. This must be enabled for anything else in this section to take | ||||
| # # effect. Default: false. | # # effect. Default: false. | ||||
| # enabled: false | # enabled: false | ||||
| # | |||||
| # # Syncing membership lists at startup can result in hundreds of members to | # # Syncing membership lists at startup can result in hundreds of members to | ||||
| # # process all at once. This timer drip feeds membership entries at the | # # process all at once. This timer drip feeds membership entries at the | ||||
| # # specified rate. Default: 10000. (10s) | # # specified rate. Default: 10000. (10s) | ||||
| # floodDelayMs: 10000 | # floodDelayMs: 10000 | ||||
| # | |||||
| # global: | # global: | ||||
| # ircToMatrix: | # ircToMatrix: | ||||
| # # Get a snapshot of all real IRC users on a channel (via NAMES) and | # # Get a snapshot of all real IRC users on a channel (via NAMES) and | ||||
| @@ -264,7 +289,14 @@ matrix_appservice_irc_ircService_servers: [] # noqa var-naming | |||||
| # # Make virtual Matrix clients join and leave rooms as their real IRC | # # Make virtual Matrix clients join and leave rooms as their real IRC | ||||
| # # counterparts join/part channels. Default: false. | # # counterparts join/part channels. Default: false. | ||||
| # incremental: false | # incremental: false | ||||
| # # Should the bridge check if all Matrix users are connected to IRC and | |||||
| # # joined to the channel before relaying messages into the room. | |||||
| # # | |||||
| # # This is considered a safety net to avoid any leakages by the bridge to | |||||
| # # unconnected users, but given it ignores all IRC messages while users | |||||
| # # are still connecting it may be overkill. | |||||
| # requireMatrixJoined: false | |||||
| # | |||||
| # matrixToIrc: | # matrixToIrc: | ||||
| # # Get a snapshot of all real Matrix users in the room and join all of | # # Get a snapshot of all real Matrix users in the room and join all of | ||||
| # # them to the mapped IRC channel on startup. Default: false. | # # them to the mapped IRC channel on startup. Default: false. | ||||
| @@ -273,21 +305,32 @@ matrix_appservice_irc_ircService_servers: [] # noqa var-naming | |||||
| # # counterparts join/leave rooms. Make sure your 'maxClients' value is | # # counterparts join/leave rooms. Make sure your 'maxClients' value is | ||||
| # # high enough! Default: false. | # # high enough! Default: false. | ||||
| # incremental: false | # incremental: false | ||||
| # | |||||
| # # Apply specific rules to Matrix rooms. Only matrix-to-IRC takes effect. | # # Apply specific rules to Matrix rooms. Only matrix-to-IRC takes effect. | ||||
| # rooms: | # rooms: | ||||
| # - room: "!qporfwt:localhost" | # - room: "!qporfwt:localhost" | ||||
| # matrixToIrc: | # matrixToIrc: | ||||
| # initial: false | # initial: false | ||||
| # incremental: false | # incremental: false | ||||
| # | |||||
| # # Apply specific rules to IRC channels. Only IRC-to-matrix takes effect. | # # Apply specific rules to IRC channels. Only IRC-to-matrix takes effect. | ||||
| # channels: | # channels: | ||||
| # - channel: "#foo" | # - channel: "#foo" | ||||
| # ircToMatrix: | # ircToMatrix: | ||||
| # initial: false | # initial: false | ||||
| # incremental: false | # incremental: false | ||||
| # requireMatrixJoined: false | |||||
| # | |||||
| # # Should the bridge ignore users which are not considered active on the bridge | |||||
| # # during startup | |||||
| # ignoreIdleUsersOnStartup: | |||||
| # enabled: true | |||||
| # # How many hours can a user be considered idle for before they are considered | |||||
| # # ignoreable | |||||
| # idleForHours: 720 | |||||
| # # A regex which will exclude matching MXIDs from this check. | |||||
| # exclude: "foobar" | |||||
| # | |||||
| # mappings: | # mappings: | ||||
| # # 1:many mappings from IRC channels to room IDs on this IRC server. | # # 1:many mappings from IRC channels to room IDs on this IRC server. | ||||
| # # The Matrix room must already exist. Your Matrix client should expose | # # The Matrix room must already exist. Your Matrix client should expose | ||||
| @@ -297,27 +340,27 @@ matrix_appservice_irc_ircService_servers: [] # noqa var-naming | |||||
| # # Channel key/password to use. Optional. If provided, Matrix users do | # # Channel key/password to use. Optional. If provided, Matrix users do | ||||
| # # not need to know the channel key in order to join the channel. | # # not need to know the channel key in order to join the channel. | ||||
| # # key: "secret" | # # key: "secret" | ||||
| # | |||||
| # # Configuration for virtual Matrix users. The following variables are | # # Configuration for virtual Matrix users. The following variables are | ||||
| # # exposed: | # # exposed: | ||||
| # # $NICK => The IRC nick | # # $NICK => The IRC nick | ||||
| # # $SERVER => The IRC server address (e.g. "irc.example.com") | # # $SERVER => The IRC server address (e.g. "irc.example.com") | ||||
| # matrixClients: | # matrixClients: | ||||
| # # The user ID template to use when creating virtual Matrix users. This | # # The user ID template to use when creating virtual Matrix users. This | ||||
| # # MUST have $NICK somewhere in it. | |||||
| # # MUST start with an @ and have $NICK somewhere in it. | |||||
| # # Optional. Default: "@$SERVER_$NICK". | # # Optional. Default: "@$SERVER_$NICK". | ||||
| # # Example: "@irc.example.com_Alice:example.com" | # # Example: "@irc.example.com_Alice:example.com" | ||||
| # userTemplate: "@irc_$NICK" | # userTemplate: "@irc_$NICK" | ||||
| # # The display name to use for created Matrix clients. This should have | # # The display name to use for created Matrix clients. This should have | ||||
| # # $NICK somewhere in it if it is specified. Can also use $SERVER to | # # $NICK somewhere in it if it is specified. Can also use $SERVER to | ||||
| # # insert the IRC domain. | # # insert the IRC domain. | ||||
| # # Optional. Default: "$NICK (IRC)". Example: "Alice (IRC)" | |||||
| # displayName: "$NICK (IRC)" | |||||
| # # Optional. Default: "$NICK". Example: "Alice" | |||||
| # displayName: "$NICK" | |||||
| # # Number of tries a client can attempt to join a room before the request | # # Number of tries a client can attempt to join a room before the request | ||||
| # # is discarded. You can also use -1 to never retry or 0 to never give up. | # # is discarded. You can also use -1 to never retry or 0 to never give up. | ||||
| # # Optional. Default: -1 | # # Optional. Default: -1 | ||||
| # joinAttempts: -1 | # joinAttempts: -1 | ||||
| # | |||||
| # # Configuration for virtual IRC users. The following variables are exposed: | # # Configuration for virtual IRC users. The following variables are exposed: | ||||
| # # $LOCALPART => The user ID localpart ("alice" in @alice:localhost) | # # $LOCALPART => The user ID localpart ("alice" in @alice:localhost) | ||||
| # # $USERID => The user ID | # # $USERID => The user ID | ||||
| @@ -346,9 +389,20 @@ matrix_appservice_irc_ircService_servers: [] # noqa var-naming | |||||
| # # connected user. If not specified, all users will connect from the same | # # connected user. If not specified, all users will connect from the same | ||||
| # # (default) address. This may require additional OS-specific work to allow | # # (default) address. This may require additional OS-specific work to allow | ||||
| # # for the node process to bind to multiple different source addresses | # # for the node process to bind to multiple different source addresses | ||||
| # # e.g IP_FREEBIND on Linux, which requires an LD_PRELOAD with the library | |||||
| # # Linux kernels 4.3+ support sysctl net.ipv6.ip_nonlocal_bind=1 | |||||
| # # Older kernels will need IP_FREEBIND, which requires an LD_PRELOAD with the library | |||||
| # # https://github.com/matrix-org/freebindfree as Node does not expose setsockopt. | # # https://github.com/matrix-org/freebindfree as Node does not expose setsockopt. | ||||
| # # prefix: "2001:0db8:85a3::" # modify appropriately | # # prefix: "2001:0db8:85a3::" # modify appropriately | ||||
| # | |||||
| # # Optional. Define blocks of IPv6 addresses for different homeservers | |||||
| # # which can be used to restrict users of those homeservers to a given | |||||
| # # IP. These blocks should be considered immutable once set, as changing | |||||
| # # the startFrom value will NOT adjust existing IP addresses. | |||||
| # # Changing the startFrom value to a lower value may conflict with existing clients. | |||||
| # # Multiple homeservers may NOT share blocks. | |||||
| # blocks: | |||||
| # - homeserver: another-server.org | |||||
| # startFrom: '10:0000' | |||||
| # # | # # | ||||
| # # The maximum amount of time in seconds that the client can exist | # # The maximum amount of time in seconds that the client can exist | ||||
| # # without sending another message before being disconnected. Use 0 to | # # without sending another message before being disconnected. Use 0 to | ||||
| @@ -385,6 +439,25 @@ matrix_appservice_irc_ircService_servers: [] # noqa var-naming | |||||
| # # through the bridge e.g. caller ID as there is no way to /ACCEPT. | # # through the bridge e.g. caller ID as there is no way to /ACCEPT. | ||||
| # # Default: "" (no user modes) | # # Default: "" (no user modes) | ||||
| # # userModes: "R" | # # userModes: "R" | ||||
| # # The format of the realname defined for users, either mxid or reverse-mxid | |||||
| # realnameFormat: "mxid" | |||||
| # # The minimum time to wait between connection attempts if we were disconnected | |||||
| # # due to throttling. | |||||
| # # pingTimeoutMs: 600000 | |||||
| # # The rate at which to send pings to the IRCd if the client is being quiet for a while. | |||||
| # # Whilst the IRCd *should* be sending pings to us to keep the connection alive, it appears | |||||
| # # that sometimes they don't get around to it and end up ping timing us out. | |||||
| # # pingRateMs: 60000 | |||||
| # # Choose which conditions the IRC bridge should kick Matrix users for. Decisions to this from | |||||
| # # defaults should be taken with care as it may dishonestly repesent Matrix users on the IRC | |||||
| # # network, and cause your bridge to be banned. | |||||
| # kickOn: | |||||
| # # Kick a Matrix user from a bridged room if they fail to join the IRC channel. | |||||
| # channelJoinFailure: true | |||||
| # # Kick a Matrix user from ALL rooms if they are unable to get connected to IRC. | |||||
| # ircConnectionFailure: true | |||||
| # # Kick a Matrix user from ALL rooms if they choose to QUIT the IRC network. | |||||
| # userQuit: true | |||||
| # Controls whether the matrix-appservice-discord container exposes its HTTP port (tcp/9999 in the container). | # Controls whether the matrix-appservice-discord container exposes its HTTP port (tcp/9999 in the container). | ||||
| # | # | ||||