PhoenixKitUserConnections
Social relationships module for PhoenixKit — follows, mutual connections, and blocking.
Features
- Follows — One-way relationships (User A follows User B, no consent needed)
- Connections — Two-way mutual relationships (both users must accept)
- Blocking — Prevents all interaction, removes existing follows/connections
- History logging — Full audit trail for all relationship actions
- Admin dashboard — Statistics overview and module toggle
- User LiveView — Tabbed interface for managing personal connections
Installation
Add to your mix.exs dependencies:
{:phoenix_kit_user_connections, "~> 0.1.0"}The module is auto-discovered by PhoenixKit at startup — no additional configuration needed.
Usage
# Follow a user
PhoenixKitUserConnections.follow(current_user, other_user)
# Request a mutual connection
PhoenixKitUserConnections.request_connection(current_user, other_user)
# Accept a connection request
PhoenixKitUserConnections.accept_connection(connection)
# Block a user (removes existing follows/connections)
PhoenixKitUserConnections.block(current_user, other_user, "reason")
# Get full relationship status
PhoenixKitUserConnections.get_relationship(current_user, other_user)
# => %{following: true, followed_by: false, connected: false, ...}Business Rules
- Cannot follow/connect with yourself
- Cannot follow/connect if blocked (either direction)
- If A requests B while B has pending request to A, both are auto-accepted
- Blocking removes all existing follows and connections between the users
License
MIT — see LICENSE.