Skip to main content

No project description provided

Project description

Famedly Control Synapse

PyPI - Version PyPI - Python Version


Table of Contents

Documentation

This repository contains a Synapse module which allows for creating and managing "managed rooms". Those rooms have the following properties: invite-only, non-federated, cannot be left. Users are associated to groups in an external service and those same groups are associated to rooms in this module. Users are then automatically added to the corresponding rooms. This module is only "half of the work", the other half being in the external service.

The openapi specification is available at openapi-spec.yaml. You can use tools like swagger.io for a more readable format.

Note for users being deactivated: Highly recommended to remove a user from a group before it is deactivated. Upon deactivation, the user will be removed from the room regardless of any group. If the user should be reactivated in the future, it will not automatically re-join any rooms its groups are in.

Worker routing

The HTTP endpoints exposed by this module are only registered on the background task synapse worker (or the main process if no dedicated worker is configured). Requests to these endpoints on any other worker will return 404 NOT_FOUND.

This must be taken into account when configuring a reverse proxy for example; all requests under /_famedlyControl/ must be routed to the background task worker.

Installation

pip install famedly-control-synapse

Configuration

Here are the available configuration options:

# the outer modules section is just provided for completeness, the config block is the actual module config.
modules:
  - module: "famedly_control_synapse.FamedlyControl"
    config:
        famedly_control:
          api_url: str = "", # Prefix of the current famedly control http API
          access_token: str = "", # Access token to authenticate against famedly control
        sync_enabled: bool = true, # Whether to run the background group membership sync loop
        sync_polling_interval_seconds: int = 30, # Interval in seconds between polling requests
        error_retry_queue_enabled: bool = true, # Enable retrying membership changes that previously errored
        error_retry_queue_interval_seconds: int = 30, # Interval in seconds between retrying a failed membership change
        error_retry_queue_log_after_retry_count: int = 3, # The count of error retry queue attempts to start logging warnings
        auth_provider: str = "", # The unique, internal ID of the external identity provider.

Testing

To create a virtual development environment and install dependencies:

hatch shell

The tests use pytest, with the development environment managed by Hatch. Running the tests can be done like this:

hatch test

Additional optional testing arguments:

Run the tests in parallel: -p

Collect coverage data (automatically output as lcov.info): -c

Running a specific test:

Selecting a specific test to run can be as easy as providing the path to the test. All tests start from the base test directory, tests. If running all tests, this can be left out. For specific tests, see the pytest usage docs for more information.

Code Quality

Use hatch fmt to automatically format code, enforce style rules, and check types using:

  • black and isort for formatting
  • ruff for linting
  • mypy for static type checking

Check Code Without Modifying It

To check code quality without modifying files:

  • Check formatting with isort and black:
    hatch fmt --check -f
    
  • Check types and linting with mypy and ruff:
    hatch fmt --check -l
    
  • Check all of above, formatting, linting, and typing:
    hatch fmt --check
    

Auto-formatting Code

To automatically fix issues in the code:

  • Format only using black and isort:
    hatch fmt -f
    
  • Type checks(mypy) and lint, fixing autofixable ruff issues:
    hatch fmt -l
    
  • Run all tools, format, lint, type-check:
    hatch fmt
    

License

famedly-control-synapse is distributed under the terms of the AGPL-3.0 license.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

famedly_control_synapse-0.0.3.tar.gz (99.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

famedly_control_synapse-0.0.3-py3-none-any.whl (41.8 kB view details)

Uploaded Python 3

File details

Details for the file famedly_control_synapse-0.0.3.tar.gz.

File metadata

  • Download URL: famedly_control_synapse-0.0.3.tar.gz
  • Upload date:
  • Size: 99.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for famedly_control_synapse-0.0.3.tar.gz
Algorithm Hash digest
SHA256 16aecd6ac8a30a4b13e673bb907d687b36eae12159fd9e08efe22ee580a007b7
MD5 2d9f642c3e3488b5ce4bbd2724f27fa1
BLAKE2b-256 941011d4dc193a5189a721db056989533be7062776b4ee44d8596d925c4fcce3

See more details on using hashes here.

Provenance

The following attestation bundles were made for famedly_control_synapse-0.0.3.tar.gz:

Publisher: publish.yml on famedly/famedly-control-synapse

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file famedly_control_synapse-0.0.3-py3-none-any.whl.

File metadata

File hashes

Hashes for famedly_control_synapse-0.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 79b100e697496be2860902557bea21078b29f650303c3a1531496fcccfbadb2a
MD5 3efc103c8d1728c4911e12c3e4e26d12
BLAKE2b-256 b31e4fcc614d49bb828712d8999cd80dbd9967219276d1e58e225bcc6ba7bd17

See more details on using hashes here.

Provenance

The following attestation bundles were made for famedly_control_synapse-0.0.3-py3-none-any.whl:

Publisher: publish.yml on famedly/famedly-control-synapse

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page