Table: mastodon_relationship - Query Mastodon Relationships using SQL
Mastodon is a federated social network, with similar features to Twitter, but based on open web protocols and free, open-source software. It is decentralized like e-mail, with different independent communities running their own servers, known as "instances". A relationship in Mastodon refers to the status between the authenticated user and a given account, which could be 'following', 'followed_by', 'blocking', 'muting', 'muting_notifications', 'requested', or 'domain_blocking'.
Table Usage Guide
The mastodon_relationship
table provides insights into the relationship status between the authenticated user and other accounts on Mastodon. As a social media analyst or a community moderator, you can use this table to explore and monitor the relationship statuses, including whether the authenticated user is following or blocking a given account, or if a follow request has been made. This can be utilized to better understand the interaction patterns and community dynamics within your Mastodon instance.
Important Notes
- You must specify the
id
column in thewhere
orjoin
clause to query this table.
Examples
My relationships to a particular account ID
Explore the nature of your interactions with a specific account on Mastodon. This allows you to understand the various ways in which you are connected to that account, such as whether you follow them, whether they follow you, if you have blocked or muted them, and more.
select following, followed_by, showing_reblogs, blocking, muting, muting_notifications, requested, domain_blocking, endorsedfrom mastodon_relationshipwhere id = '1';
select following, followed_by, showing_reblogs, blocking, muting, muting_notifications, requested, domain_blocking, endorsedfrom mastodon_relationshipwhere id = '1';
Relationship details for the earliest accounts I follow
Explore the earliest accounts you follow on Mastodon to understand their relationship details. This can help you track your engagement history and assess your social network's evolution over time.
with following as ( select * from mastodon_my_following where created_at < date('2017-01-01'))select f.url, f.created_at, f.display_name, m.followed_byfrom following f join mastodon_relationship m on f.id = m.idorder by created_at;
with following as ( select * from mastodon_my_following where created_at < date('2017-01-01'))select f.url, f.created_at, f.display_name, m.followed_byfrom following f join mastodon_relationship m on f.id = m.idorder by created_at;
Schema for mastodon_relationship
Name | Type | Operators | Description |
---|---|---|---|
_ctx | jsonb | Steampipe context in JSON form, e.g. connection_name. | |
blocking | boolean | Are you blocking this person? | |
domain_blocking | boolean | Are you blocking this person's domain? | |
endorsed | boolean | Are you featuring this person on your profile? | |
followed_by | boolean | Are you followed by this person? | |
following | boolean | Are you following this person? | |
id | text | = | ID of the target accounts. |
muting | boolean | Are you muting this person? | |
muting_notifications | boolean | Toots from this account. | |
requested | boolean | Do you have a pending follow request from this person? | |
showing_reblogs | boolean | Are you receiving this person's boosts in your home timeline? |
Export
This table is available as a standalone Exporter CLI. Steampipe exporters are stand-alone binaries that allow you to extract data using Steampipe plugins without a database.
You can download the tarball for your platform from the Releases page, but it is simplest to install them with the steampipe_export_installer.sh
script:
/bin/sh -c "$(curl -fsSL https://steampipe.io/install/export.sh)" -- mastodon
You can pass the configuration to the command with the --config
argument:
steampipe_export_mastodon --config '<your_config>' mastodon_relationship