mirror of
				https://github.com/spantaleev/matrix-docker-ansible-deploy.git
				synced 2025-10-25 01:23:24 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			397 lines
		
	
	
		
			20 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
			
		
		
	
	
			397 lines
		
	
	
		
			20 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
| # Matrix Appservice IRC is a Matrix <-> IRC bridge
 | |
| # See: https://github.com/matrix-org/matrix-appservice-irc
 | |
| 
 | |
| matrix_appservice_irc_enabled: true
 | |
| 
 | |
| matrix_appservice_irc_docker_image: "docker.io/matrixdotorg/matrix-appservice-irc:release-0.17.1"
 | |
| matrix_appservice_irc_docker_image_force_pull: "{{ matrix_appservice_irc_docker_image.endswith(':latest') }}"
 | |
| 
 | |
| matrix_appservice_irc_base_path: "{{ matrix_base_data_path }}/appservice-irc"
 | |
| matrix_appservice_irc_config_path: "{{ matrix_appservice_irc_base_path }}/config"
 | |
| matrix_appservice_irc_data_path: "{{ matrix_appservice_irc_base_path }}/data"
 | |
| 
 | |
| matrix_appservice_irc_homeserver_url: 'http://matrix-synapse:8008'
 | |
| matrix_appservice_irc_homeserver_media_url: 'https://{{ matrix_server_fqn_matrix }}'
 | |
| matrix_appservice_irc_homeserver_domain: '{{ matrix_domain }}'
 | |
| matrix_appservice_irc_homeserver_enablePresence: true
 | |
| matrix_appservice_irc_appservice_address: 'http://matrix-appservice-irc:9999'
 | |
| 
 | |
| matrix_appservice_irc_database_engine: nedb
 | |
| matrix_appservice_irc_database_username: matrix_appservice_irc
 | |
| matrix_appservice_irc_database_password: ~
 | |
| matrix_appservice_irc_database_hostname: 'matrix-postgres'
 | |
| matrix_appservice_irc_database_port: 5432
 | |
| matrix_appservice_irc_database_name: matrix_appservice_irc
 | |
| 
 | |
| # This is just the Postgres connection string, if Postgres is used.
 | |
| # Naming clashes with `matrix_appservice_irc_database_connectionString` somewhat.
 | |
| matrix_appservice_irc_database_connection_string: 'postgresql://{{ matrix_appservice_irc_database_username }}:{{ matrix_appservice_irc_database_password }}@{{ matrix_appservice_irc_database_hostname }}:{{ matrix_appservice_irc_database_port }}/{{ matrix_appservice_irc_database_name }}?sslmode=disable'
 | |
| 
 | |
| # This is what actually goes into `database.connectionString` for the bridge.
 | |
| matrix_appservice_irc_database_connectionString: "{{
 | |
| 	{
 | |
| 		'nedb': 'nedb:///data',
 | |
| 		'postgres': matrix_appservice_irc_database_connection_string,
 | |
| 	}[matrix_appservice_irc_database_engine]
 | |
| }}"
 | |
| 
 | |
| matrix_appservice_irc_ircService_servers: []
 | |
| 
 | |
| # Example of `matrix_appservice_irc_ircService_servers` with one server (and all its options):
 | |
| #
 | |
| # matrix_appservice_irc_ircService_servers:
 | |
| #   # The address of the server to connect to.
 | |
| #   irc.example.com:
 | |
| #     # A human-readable short name. This is used to label IRC status rooms
 | |
| #     # where matrix users control their connections.
 | |
| #     # E.g. 'ExampleNet IRC Bridge status'.
 | |
| #     # It is also used in the Third Party Lookup API as the instance `desc`
 | |
| #     # property, where each server is an instance.
 | |
| #     name: "ExampleNet"
 | |
| 
 | |
| #     additionalAddresses: [ "irc2.example.com" ]
 | |
| #     #
 | |
| #     # [DEPRECATED] Use `name`, above, instead.
 | |
| #     # A human-readable description string
 | |
| #     # description: "Example.com IRC network"
 | |
| 
 | |
| #     # An ID for uniquely identifying this server amongst other servers being bridged.
 | |
| #     # 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
 | |
| 
 | |
| #     # The port to connect to. Optional.
 | |
| #     port: 6697
 | |
| #     # Whether to use SSL or not. Default: false.
 | |
| #     ssl: true
 | |
| #     # Whether or not IRC server is using a self-signed cert or not providing CA Chain
 | |
| #     sslselfsign: false
 | |
| #     # Should the connection attempt to identify via SASL (if a server or user password is given)
 | |
| #     # If false, this will use PASS instead. If SASL fails, we do not fallback to PASS.
 | |
| #     sasl: false
 | |
| #     # Whether to allow expired certs when connecting to the IRC server.
 | |
| #     # Usually this should be off. Default: false.
 | |
| #     allowExpiredCerts: false
 | |
| #     # A specific CA to trust instead of the default CAs. Optional.
 | |
| #     #ca: |
 | |
| #     #  -----BEGIN CERTIFICATE-----
 | |
| #     #  ...
 | |
| #     #  -----END CERTIFICATE-----
 | |
| 
 | |
| #     #
 | |
| #     # The connection password to send for all clients as a PASS (or SASL, if enabled above) command. Optional.
 | |
| #     # password: 'pa$$w0rd'
 | |
| #     #
 | |
| #     # Whether or not to send connection/error notices to real Matrix users. Default: true.
 | |
| #     sendConnectionMessages: true
 | |
| 
 | |
| #     quitDebounce:
 | |
| #       # 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
 | |
| #       # a QUIT rate higher than quitsPerSecond. Default: false.
 | |
| #       enabled: false
 | |
| #       # The maximum number of quits per second acceptable above which a netsplit is
 | |
| #       # considered ongoing. Default: 5.
 | |
| #       quitsPerSecond: 5
 | |
| #       # The time window in which to wait before bridging a QUIT to Matrix that occurred during
 | |
| #       # a netsplit. Debouncing is jittered randomly between delayMinMs and delayMaxMs so that the HS
 | |
| #       # is not sent many requests to leave rooms all at once if a netsplit occurs and many
 | |
| #       # people to not rejoin.
 | |
| #       # If the user with the same IRC nick as the one who sent the quit rejoins a channel
 | |
| #       # they are considered back online and the quit is not bridged, so long as the rejoin
 | |
| #       # occurs before the randomly-jittered timeout is not reached.
 | |
| #       # Default: 3600000, = 1h
 | |
| #       delayMinMs: 3600000 # 1h
 | |
| #       # Default: 7200000, = 2h
 | |
| #       delayMaxMs: 7200000 # 2h
 | |
| 
 | |
| #     # 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
 | |
| #     # been given multiple modes, the one that maps to the highest power level will be used.
 | |
| #     modePowerMap:
 | |
| #       o: 50
 | |
| 
 | |
| #     botConfig:
 | |
| #       # 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
 | |
| #       # means IRC -> Matrix chat will be shared by active "M-Nick" connections
 | |
| #       # in the room. If there are no users in the room (or if there are users
 | |
| #       # but their connections are not on IRC) then nothing will be bridged to
 | |
| #       # Matrix. If you're concerned about the bot being treated as a "logger"
 | |
| #       # entity, then you may want to disable the bot. If you want IRC->Matrix
 | |
| #       # but don't want to have TCP connections to IRC unless a Matrix user speaks
 | |
| #       # (because your client connection limit is low), then you may want to keep
 | |
| #       # the bot enabled. Default: true.
 | |
| #       # NB: If the bot is disabled, you SHOULD have matrix-to-IRC syncing turned
 | |
| #       #     on, else there will be no users and no bot in a channel (meaning no
 | |
| #       #     messages to Matrix!) until a Matrix user speaks which makes a client
 | |
| #       #     join the target IRC channel.
 | |
| #       # NBB: The bridge bot IRC client will still join the target IRC network so
 | |
| #       #      it can service bridge-specific queries from the IRC-side e.g. so
 | |
| #       #      real IRC clients have a way to change their Matrix display name.
 | |
| #       #      See https://github.com/matrix-org/matrix-appservice-irc/issues/55
 | |
| #       enabled: true
 | |
| #       # The nickname to give the AS bot.
 | |
| #       nick: "MatrixBot"
 | |
| #       # The password to give to NickServ or IRC Server for this nick. Optional.
 | |
| #       # password: "helloworld"
 | |
| #       #
 | |
| #       # Join channels even if there are no Matrix users on the other side of
 | |
| #       # the bridge. Set to false to prevent the bot from joining channels which have no
 | |
| #       # real matrix users in them, even if there is a mapping for the channel.
 | |
| #       # Default: true
 | |
| #       joinChannelsIfNoUsers: true
 | |
| 
 | |
| #     # Configuration for PMs / private 1:1 communications between users.
 | |
| #     privateMessages:
 | |
| #       # Enable the ability for PMs to be sent to/from IRC/Matrix.
 | |
| #       # Default: true.
 | |
| #       enabled: true
 | |
| #       # Prevent Matrix users from sending PMs to the following IRC nicks.
 | |
| #       # Optional. Default: [].
 | |
| #       # exclude: ["Alice", "Bob"] # NOT YET IMPLEMENTED
 | |
| 
 | |
| #       # 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.
 | |
| #       # Optional. Default: true.
 | |
| #       federate: true
 | |
| 
 | |
| #     # Configuration for mappings not explicitly listed in the 'mappings'
 | |
| #     # section.
 | |
| #     dynamicChannels:
 | |
| #       # Enable the ability for Matrix users to join *any* channel on this IRC
 | |
| #       # network.
 | |
| #       # Default: false.
 | |
| #       enabled: true
 | |
| #       # Should the AS create a room alias for the new Matrix room? The form of
 | |
| #       # the alias can be modified via 'aliasTemplate'. Default: true.
 | |
| #       createAlias: true
 | |
| #       # Should the AS publish the new Matrix room to the public room list so
 | |
| #       # anyone can see it? Default: true.
 | |
| #       published: true
 | |
| #       # 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
 | |
| #       # 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.
 | |
| #       # Default: "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
 | |
| #       # HS attached to this AS will be able to interact with this room.
 | |
| #       # Default: true.
 | |
| #       federate: true
 | |
| #       # The room alias template to apply when creating new aliases. This only
 | |
| #       # applies if createAlias is 'true'. The following variables are exposed:
 | |
| #       # $SERVER => The IRC server address (e.g. "irc.example.com")
 | |
| #       # $CHANNEL => The IRC channel (e.g. "#python")
 | |
| #       # This MUST have $CHANNEL somewhere in it.
 | |
| #       # Default: '#irc_$SERVER_$CHANNEL'
 | |
| #       aliasTemplate: "#irc_$CHANNEL"
 | |
| #       # A list of user IDs which the AS bot will send invites to in response
 | |
| #       # to a !join. Only applies if joinRule is 'invite'. Default: []
 | |
| #       # whitelist:
 | |
| #       #   - "@foo:example.com"
 | |
| #       #   - "@bar:example.com"
 | |
| #       #
 | |
| #       # Prevent the given list of channels from being mapped under any
 | |
| #       # circumstances.
 | |
| #       # exclude: ["#foo", "#bar"]
 | |
| 
 | |
| #     # Configuration for controlling how Matrix and IRC membership lists are
 | |
| #     # synced.
 | |
| #     membershipLists:
 | |
| #       # Enable the syncing of membership lists between IRC and Matrix. This
 | |
| #       # can have a significant effect on performance on startup as the lists are
 | |
| #       # synced. This must be enabled for anything else in this section to take
 | |
| #       # effect. Default: false.
 | |
| #       enabled: false
 | |
| 
 | |
| #       # Syncing membership lists at startup can result in hundreds of members to
 | |
| #       # process all at once. This timer drip feeds membership entries at the
 | |
| #       # specified rate. Default: 10000. (10s)
 | |
| #       floodDelayMs: 10000
 | |
| 
 | |
| #       global:
 | |
| #         ircToMatrix:
 | |
| #           # Get a snapshot of all real IRC users on a channel (via NAMES) and
 | |
| #           # join their virtual matrix clients to the room.
 | |
| #           initial: false
 | |
| #           # Make virtual matrix clients join and leave rooms as their real IRC
 | |
| #           # counterparts join/part channels. Default: false.
 | |
| #           incremental: false
 | |
| 
 | |
| #         matrixToIrc:
 | |
| #           # 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.
 | |
| #           initial: false
 | |
| #           # Make virtual IRC clients join and leave channels as their real Matrix
 | |
| #           # counterparts join/leave rooms. Make sure your 'maxClients' value is
 | |
| #           # high enough! Default: false.
 | |
| #           incremental: false
 | |
| 
 | |
| #       # Apply specific rules to Matrix rooms. Only matrix-to-IRC takes effect.
 | |
| #       rooms:
 | |
| #         - room: "!fuasirouddJoxtwfge:localhost"
 | |
| #           matrixToIrc:
 | |
| #             initial: false
 | |
| #             incremental: false
 | |
| 
 | |
| #       # Apply specific rules to IRC channels. Only IRC-to-matrix takes effect.
 | |
| #       channels:
 | |
| #         - channel: "#foo"
 | |
| #           ircToMatrix:
 | |
| #             initial: false
 | |
| #             incremental: false
 | |
| 
 | |
| #     mappings:
 | |
| #       # 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 room ID in a "settings" page for the room.
 | |
| #       "#thepub":
 | |
| #         roomIds: ["!kieouiJuedJoxtVdaG:localhost"]
 | |
| #         # Channel key/password to use. Optional. If provided, matrix users do
 | |
| #         # not need to know the channel key in order to join the channel.
 | |
| #         # key: "secret"
 | |
| 
 | |
| #     # Configuration for virtual matrix users. The following variables are
 | |
| #     # exposed:
 | |
| #     # $NICK => The IRC nick
 | |
| #     # $SERVER => The IRC server address (e.g. "irc.example.com")
 | |
| #     matrixClients:
 | |
| #       # The user ID template to use when creating virtual matrix users. This
 | |
| #       # MUST have $NICK somewhere in it.
 | |
| #       # Optional. Default: "@$SERVER_$NICK".
 | |
| #       # Example: "@irc.example.com_Alice:example.com"
 | |
| #       userTemplate: "@irc_$NICK"
 | |
| #       # 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
 | |
| #       # insert the IRC domain.
 | |
| #       # Optional. Default: "$NICK (IRC)". Example: "Alice (IRC)"
 | |
| #       displayName: "$NICK (IRC)"
 | |
| #       # 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.
 | |
| #       # Optional. Default: -1
 | |
| #       joinAttempts: -1
 | |
| 
 | |
| #     # Configuration for virtual IRC users. The following variables are exposed:
 | |
| #     # $LOCALPART => The user ID localpart ("alice" in @alice:localhost)
 | |
| #     # $USERID => The user ID
 | |
| #     # $DISPLAY => The display name of this user, with excluded characters
 | |
| #     #             (e.g. space) removed. If the user has no display name, this
 | |
| #     #             falls back to $LOCALPART.
 | |
| #     ircClients:
 | |
| #       # The template to apply to every IRC client nick. This MUST have either
 | |
| #       # $DISPLAY or $USERID or $LOCALPART somewhere in it.
 | |
| #       # Optional. Default: "M-$DISPLAY". Example: "M-Alice".
 | |
| #       nickTemplate: "$DISPLAY[m]"
 | |
| #       # True to allow virtual IRC clients to change their nick on this server
 | |
| #       # by issuing !nick <server> <nick> commands to the IRC AS bot.
 | |
| #       # This is completely freeform: it will NOT follow the nickTemplate.
 | |
| #       allowNickChanges: true
 | |
| #       # The max number of IRC clients that will connect. If the limit is
 | |
| #       # reached, the client that spoke the longest time ago will be
 | |
| #       # disconnected and replaced.
 | |
| #       # Optional. Default: 30.
 | |
| #       maxClients: 30
 | |
| #       # IPv6 configuration.
 | |
| #       ipv6:
 | |
| #         # Optional. Set to true to force IPv6 for outgoing connections.
 | |
| #         only: false
 | |
| #         # Optional. The IPv6 prefix to use for generating unique addresses for each
 | |
| #         # connected user. If not specified, all users will connect from the same
 | |
| #         # (default) address. This may require additional OS-specific work to allow
 | |
| #         # 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
 | |
| #         # https://github.com/matrix-org/freebindfree as Node does not expose setsockopt.
 | |
| #         # prefix: "2001:0db8:85a3::"  # modify appropriately
 | |
| #       #
 | |
| #       # The maximum amount of time in seconds that the client can exist
 | |
| #       # without sending another message before being disconnected. Use 0 to
 | |
| #       # not apply an idle timeout. This value is ignored if this IRC server is
 | |
| #       # mirroring matrix membership lists to IRC. Default: 172800 (48 hours)
 | |
| #       idleTimeout: 10800
 | |
| #       # The number of millseconds to wait between consecutive reconnections if a
 | |
| #       # client gets disconnected. Setting to 0 will cause the scheduling to be
 | |
| #       # disabled, i.e. it will be scheduled immediately (with jitter.
 | |
| #       # Otherwise, the scheduling interval will be used such that one client
 | |
| #       # reconnect for this server will be handled every reconnectIntervalMs ms using
 | |
| #       # a FIFO queue.
 | |
| #       # Default: 5000 (5 seconds)
 | |
| #       reconnectIntervalMs: 5000
 | |
| #       # The number of concurrent reconnects if a user has been disconnected unexpectedly
 | |
| #       # (e.g. a netsplit). You should set this to a reasonably high number so that
 | |
| #       # bridges are not waiting an eternity to reconnect all its clients if
 | |
| #       # we see a massive number of disconnect. This is unrelated to the reconnectIntervalMs
 | |
| #       # setting above which is for connecting on restart of the bridge. Set to 0 to
 | |
| #       # immediately try to reconnect all users.
 | |
| #       # Default: 50
 | |
| #       concurrentReconnectLimit: 50
 | |
| #       # The number of lines to allow being sent by the IRC client that has received
 | |
| #       # a large block of text to send from matrix. If the number of lines that would
 | |
| #       # be sent is > lineLimit, the text will instead be uploaded to matrix and the
 | |
| #       # resulting URI is treated as a file. As such, a link will be sent to the IRC
 | |
| #       # side instead of potentially spamming IRC and getting the IRC client kicked.
 | |
| #       # Default: 3.
 | |
| #       lineLimit: 3
 | |
| #       # A list of user modes to set on every IRC client. For example, "RiG" would set
 | |
| #       # +R, +i and +G on every IRC connection when they have successfully connected.
 | |
| #       # User modes vary wildly depending on the IRC network you're connecting to,
 | |
| #       # so check before setting this value. Some modes may not work as intended
 | |
| #       # through the bridge e.g. caller ID as there is no way to /ACCEPT.
 | |
| #       # Default: "" (no user modes)
 | |
| #       # userModes: "R"
 | |
| 
 | |
| # Controls whether the matrix-appservice-discord container exposes its HTTP port (tcp/9999 in the container).
 | |
| #
 | |
| # Takes an "<ip>:<port>" or "<port>" value (e.g. "127.0.0.1:9999"), or empty string to not expose.
 | |
| matrix_appservice_irc_container_http_host_bind_port: ''
 | |
| 
 | |
| # A list of extra arguments to pass to the container
 | |
| matrix_appservice_irc_container_extra_arguments: []
 | |
| 
 | |
| # List of systemd services that matrix-appservice-irc.service depends on.
 | |
| matrix_appservice_irc_systemd_required_services_list: ['docker.service']
 | |
| 
 | |
| # List of systemd services that matrix-appservice-irc.service wants
 | |
| matrix_appservice_irc_systemd_wanted_services_list: []
 | |
| 
 | |
| matrix_appservice_irc_appservice_token: ''
 | |
| matrix_appservice_irc_homeserver_token: ''
 | |
| 
 | |
| matrix_appservice_irc_configuration_yaml: "{{ lookup('template', 'templates/config.yaml.j2') }}"
 | |
| 
 | |
| matrix_appservice_irc_configuration_extension_yaml: |
 | |
|   # Your custom YAML configuration for Appservice IRC servers goes here.
 | |
|   # This configuration extends the default starting configuration (`matrix_appservice_irc_configuration_yaml`).
 | |
|   #
 | |
|   # You can override individual variables from the default configuration, or introduce new ones.
 | |
|   #
 | |
|   # If you need something more special, you can take full control by
 | |
|   # completely redefining `matrix_appservice_irc_configuration_yaml`.
 | |
| 
 | |
| matrix_appservice_irc_configuration_extension: "{{ matrix_appservice_irc_configuration_extension_yaml|from_yaml if matrix_appservice_irc_configuration_extension_yaml|from_yaml is mapping else {} }}"
 | |
| 
 | |
| matrix_appservice_irc_configuration: "{{ matrix_appservice_irc_configuration_yaml|from_yaml|combine(matrix_appservice_irc_configuration_extension, recursive=True) }}"
 | |
| 
 | |
| # The original registration.yaml file generated by AppService IRC is merged with this config override,
 | |
| # to produce the final registration.yaml file ultimately used by both the bridge and the homeserver.
 | |
| #
 | |
| # We do this to ensure consistency:
 | |
| # - always having an up-to-date registration.yaml file (synced with the configuration file)
 | |
| # - always having the same AS/HS token and appservice id in the registration.yaml file
 | |
| #
 | |
| # Learn more about this in `setup_install.yml`
 | |
| matrix_appservice_irc_registration_override_yaml: |
 | |
|   id: appservice-irc
 | |
|   as_token: "{{ matrix_appservice_irc_appservice_token }}"
 | |
|   hs_token: "{{ matrix_appservice_irc_homeserver_token }}"
 | |
| 
 | |
| matrix_appservice_irc_registration_override: "{{ matrix_appservice_irc_registration_override_yaml|from_yaml }}"
 |