Mastodon
In light of recent events with Twitter, you may have heard about a different micro-blogging site called Mastodon. It has been around for a few years, 2016 to be exact, so it’s definitely not new.
And it’s technically not a site, as the heart and possibly the main draw of Mastodon is that it has multiple instances all run by individuals, typically not large corporations. Each instance can establish its own Code of Conduct and Terms of Services. Some instances require an invite, others do not. They are connected through federation to what’s know as the Fediverse.
This explanation definitely falls short in describing Mastodon’s history and capabilities. It is meant to be a brief introduction as there have been many bloggers writing about Mastodon over the last month. I don’t want to waste any more time explaining what it is, how to create an account, or whatever.
Enter BluebirdPS
 
Many Twitter users are creating accounts on various Mastodon instances. With Twitter all of your followers and following and content is/was in one place which makes/made it easier to find and share with communities that focus on your interests.
With Mastodon, even though there is federation between (most) instances,
you need to know the instance name to follow anyone.
For instance (pun intended), my Mastodon account is @thedavecarroll@fosstodon.org
which can also be represented as https://fosstodon.org/@thedavecarroll.
Users that are creating accounts have been providing their Mastodon account references in their Twitter user profiles and in tweets. Anecdotally, it’s best practice to leave a forwarding address as doing so will help others find you.
But what if you wanted to find your followers in the Mastodon federation? BluebirdPS can help with that.
In BluebirdPS v0.8.0, I included a command called Find-TwitterMastodonLinks that will find Mastodon account references for you.
For Users, matches will be discovered in any part of the Name, Description, or included Url entities.
For Tweets, matches will be discovered in the Tweet Text or included Url entities.
I want to show you how you can use the command to make custom queries as your filtering criteria.
PowerShell Community Discovery
In order to find which Mastodon instances PowerShell community members have been using the most, we need to first find the community members. We can do this several ways.
Users
The quickest set of data that you can use would be your followers or those you follow.
|  |  | 

And that produced a few lines of red. The errors are for tweets that may have been deleted or from account that protects their tweets (prevents public access).

Let’s try again.
|  |  | 
And that yielded 1395 objects for me.
However, since we used the IncludeExpansions switch, we also retrieved tweets the users may have pinned to their profiles.
|  |  | 
So, this is all of my followers and (unfortunately?) I know that some of them are not part of the PowerShell community.
|  |  | 
By adding a match for PowerShell or pwsh for Description for users, we see that out of 1147 users,
only 234 seem to focus on PowerShell enough to include it in their profile description.
Now, using the same criteria to search the pinned tweets, we find 35 (out of 248).
|  |  | 
Now we can combine the two and see that the count matches from the two previous filters.
|  |  | 
I’m going to add friends, which is those users that I follow and include them in the searches.
|  |  | 
Next, we will use Find-TwitterMastodonLinks to search through those 615 users and tweets for any Mastodon account references.
However, we do need to think about filtering out false positives.
That is to say, there are some domains and sites that use the same @account@domain.tld or https://domain.tld/@account scheme.
Here is the list that have been identified so far: youtube.com, medium.com, withkoji.com, counter.social, and twitter.com
counter.social domain, is a closed Mastodon instance.
Unless you are on that instance, you won’t be able to follow users on that instance.
        |  |  | 
And that gives us 34 Twitter users that have PowerShell or pwsh in their profile description, display name, urls, or in their pinned tweets text or urls. Ideally, we would need a larger sample but based on what we do have, here is a list of the Mastodon instances that have at least one PowerShell community member.
|  |  | 
|  |  | 
If you were to look at $MastodonAccounts, there may appear to be duplicates.
There is a property in the [BluebirdPS.TwitterMastodonReference] class, TwitterElement,
that contains what matched on the Twitter side.
For the Twitter user, sassdawe, you see below that they matched on Name and a UrlEntity.
|  |  | 
|  |  | 
Recent Tweets
We can use a similar method, though perhaps more direct, to search the last 7 days of tweets for Mastodon account references.
|  |  | 
Almost 5000 tweets and users (by using the IncludeExpansions switch), so that should be a better sample.
And less than 5 seconds later, we find a disappointing 66 (still better than 35 when we searched users).
|  |  | 
We combine the two lists, drop any duplications, and group by the instance name to get the number of PowerShell community members on that instance.
|  |  | 
Lists
You can also search any curated lists you own or public lists that others curate. I won’t get into detail for these as the basics will be the same.
You would use these commands to discover lists and get their memberships.
- Get-TwitterList
- Get-TwitterListMember
- Get-TwitterListSubscriber
Create Export File
Once you have a list, you need to save it as a CSV file with specific headers.
You will need to have Account address and Show boosts at minimum.
The easiest way to create this is by using calculated properties for Select-Object.
|  |  | 
The two variables could contain identical entries.
To only get the unique entries, we can use the Sort-Object command and its Unique switch.
Show boosts is a boolean and allows you to see when the user boosts others’ toots/posts.
Beginning with Mastodon version 4 and higher, there are other fields that will be present
if you were to export your follows on an instance with that version.
They are not required for a successful import.
        Your Own Criteria
Here are the basic steps that you would need to perform in order to generate your own CSV.
- Get Users or Tweets from which ever command as appropriate.
- Filter on your own criteria.
- Use Find-TwitterMastodonLinksto discover the Mastodon accounts.
- Create CSV file.
- Login into your instance and use the import tool.
GitHub Actions
If that seems like a lot of trouble to go through, Chrissy LeMaire has worked on a few GitHub Actions that will help in the automated discovery, import, and export.
- Exodus
- Searches lists, hashtags, account followers and more for Mastodon links in their name, bio or pinned tweet.
- Saves information as CSV that can be imported.
- Powered by BluebirdPS.
 
- Influx
- Imports CSV files into your Mastodon account.
- Categories imported - follows, mutes, account blocks, lists, bookmarks, and domain blocks.
 
- Fossilize
- Automated backup of your Mastodon account items.
- Categories exported - follows, mutes, account blocks, lists, bookmarks, domain blocks, followers, posts.
 
Summary
Hopefully this article has been helpful to you, whether learning how to use BluebirdPS to find Mastodon accounts or learning about Exodus and Fossilize. The latter can help you migrate to a new Mastodon instance should you discover one you prefer over your current one.
In any case, I hope to see you around the Mastodon neighborhood.
Thank you for reading this article. I really would like to hear your thoughts on it.
If you have any comments or questions, please post them below.