Introduction
The main learning goal of this tutorial is to enable historians and other humanists or social scientists to gather social media data that they can use as primary sources for research purposes or as teaching materials. It focuses on the Bluesky social media platform and shows how data can be extracted using Communalytic software, that also provides connectors to other social media platforms. The tutorial first introduces the audience to the Bluesky application programming interface (API), with a particular focus on its limitations. It then guides them through a first hashtag-based harvesting of Bluesky posts, with selected hashtags and examples that are relevant to historical memory. Finally, it outlines how the corpus of collected posts can be analysed with basic text mining operations and social network analysis.
Text mining can be defined as the process of deriving information from large corpora of texts through various computational operations. As such, it offers a range of methods and techniques to analyse content as data. But it can also be interesting to analyse the structure of a dataset of social media posts using social network analysis. Social network analysis (SNA) is “the process of investigating social structures through the use of networks and graph theory”. It sees social structures in terms of nodes (actors) and edges (relationships and interactions) that connect nodes. Text mining and SNA are two methods of analysis that are frequently used in digital humanities or digital history and can be applied to social media datasets in social sciences and humanities (SSH). Although Bluesky posts are short texts, analysing a dataset of thousands, hundreds of thousands or millions of these posts will require the use of text mining as it is not possible to read the whole dataset closely. Social media posts and their numerous metadata also contain many kinds of interactions that can serve as the basis for social network analysis.
Social media posts already represent valuable primary sources for historians, and their importance will continue to grow over the coming years. The two authors of this lesson, for instance, have used datasets of tweets to study echoes of the centenary of the First World War online from the angle of memory studies and the Irish Decade of Commemorations from a feminist perspective.
There are various ways to collect social media-related data; here we propose using Communalytic (formerly Netlytic), an online tool that does not require specific programming skills. For this tutorial, you need to have a Communalytic account. Note that, if you wish to collect data from other social media platforms connected to Communalytic (YouTube, Telegram and Reddit), you will have to open an account on those platforms. For X, you will also need to pay a subscription to use the platform’s API.
Overview of Communalytic
Communalytic, formerly Netlytic, is a cloud-based tool for collecting, visualising and analysing social media data from several platforms such as Bluesky, Mastodon, Reddit, Telegram, YouTube and X (formerly Twitter). It is a “no code” tool specifically designed for humanities and social sciences researchers and requires no knowledge of advanced computational techniques. There are two versions of Communalytic: Communalytic EDU is designed for educational use to introduce students to social media data analytics, while Communalytic PRO is designed for large-scale research projects involving media data analysis. The two versions of Communalytic are hosted on separate servers and have their own account creation and sign-in processes. EDU users can share datasets with other EDU users but not with PRO users, and similarly PRO users can share datasets with other PRO users but not with EDU users. Communalytic EDU is free, but it is much more limited than the PRO version: only three datasets can be created, and a maximum of 30,000 posts can be collected, stored and analysed. Communalytic PRO allows users to collect up to 3 million records in 30 datasets, with up to 1 million records per dataset (as of 11 July 2025). While both versions of Communalytic can be used to follow this lesson, we will use Communalytic EDU.
Once you have an account, you will be able to see which social media platforms you can collect data from and which types of data you can collect. For instance, you can harvest “historical posts”, “threads” or “user timelines” from Bluesky. We are particularly interested in collecting “historical posts”, including replies, through hashtags (#keyword) or simple keywords (not preceded by hashtags). To collect the data, the current version of Communalytic uses the Bluesky XRPC API, which is based on the AT Protocol, a protocol developed by Bluesky “for distributed social networking services” (see Wikipedia for more information). Once collected, the datasets are stored online by default, so users should consider whether this complies with their university’s ethical guidelines for social media research. The number of records and datasets a user can store at any one time is limited. However, datasets can be downloaded as CSV files for working offline with other programs and freeing up space for more data collection. After collecting the data, users can also carry out different types of analysis: civility analysis, sentiment analysis, topic analysis and different types of network analysis. Existing datasets can also be uploaded for analysis.
Setting the scene: what is Bluesky, the Bluesky API and how does it work?
Bluesky was initially a project to develop an open, decentralised protocol that could be used by different social media platforms (i.e. a set of rules that several platforms could adopt that would make them compatible), initiated by former Twitter CEO Jack Dorsey. It was launched as a social media platform in 2023 and was presented as the main “alternative” to Twitter after the latter was sold, turned into the current X platform and significantly changed its strategy. From a user point of view, Bluesky’s interface is relatively similar to Twitter’s. At the beginning of 2025, Bluesky had 30 million users. As of July 2025, Bluesky remains a young social media platform whose functionalities and design may change quickly.
One functionality that Bluesky offers to its users is access to and free use of its application programming interface (API). An API is “a connection between computers or between computer programs”. In simple terms, it is an interface that allows different computers to talk to each other and exchange flows of information. This enables the implementation of various features, such as the buttons from Facebook that you can see on many websites: these use the Facebook API. In this lesson, we are more interested in another kind of service that can be accessible through an API, namely the possibility of harvesting data and metadata. This allows researchers to obtain social media data they can use for research and teaching. If you have a tech brain, the following paragraph offers some technical insights into how the Bluesky API can be used to collect posts; if not, skip over it and read on to the end of this section to find out what you can obtain using this API.
The Bluesky API allows us to access one of the core primitives of the AT Protocol (for Authenticated Transfer Protocol) that Bluesky uses: the “firehose”. The firehose is “an authenticated stream of events used to efficiently sync user updates”. In other words, when you connect to a Bluesky account and read posts from other users, those posts are part of the firehose. Collecting posts from Bluesky means connecting to the firehose, through various endpoints which correspond with specific types of information you can receive or send. The firehose offers various possibilities including collecting public data from Bluesky, specifically posts and replies, threads and users’ timelines. For more information about the Bluesky API, please see the developer documentation.
Based on this API, the EDU version of Communalytic allows users to collect up to 30 000 Bluesky posts (including replies) in three datasets. Regardless of the version you use, Communalytic will take into account the Bluesky API rate limits, which are implemented to avoid service disruptions caused by intense data harvesting. This is all the more important with the rise of large language models and the urgent need for fresh data to train them, as more and more companies are now aggressively collecting content. This has led to a number of controversies, including some involving Bluesky. It is important to be aware of this issue, as it affects our privacy.
Your first harvest of posts
To create a free EDU account in Communalytic, you need to sign in through Google. (Researchers working on larger projects can also create a PRO account with an email address, but for this tutorial we use the free version of the software.) Once you are connected, you will be directed to “My Datasets” (or click “My Datasets” in the main menu bar). You do not need to have a Bluesky account to harvest posts using the Bluesky API, but please note that this may not be the case for other social media platforms.
Before you begin to collect data, you will need to choose a topic and find your hashtags. To choose a hashtag or a simple keyword, please go the the “Choose your hashtag” section below. Once you know what you are looking for, click on “My Datasets” and choose the “Historical Posts” option under the Bluesky tab.
As you see, you will be asked to:
- Choose a name for your dataset
- Provide a Search Query (up to 1024 characters)
- Define filters (start and end date, maximum number of posts, include replies)
You will have to fill in a form to register all this information.
You can use a very simple search query or something more complex (see below for more details). You might want to test this out manually first in the Bluesky interface, which offers advanced search options (Tips and Tricks for Bluesky Search), to get an idea of the results it generates. The option you choose to harvest posts, whether by thread, timeline or keyword-based search, will depend on your research. The thread or timeline options might be useful, for instance, to study the interactions between a museum and its audience. You might want to limit your query to posts published by the museum’s accounts and the replies to these posts using the timeline option and its filters.
Choose your hashtag and build your dataset
To build your dataset, you may want to study what is called a trending topic. Trending topics are theoretically a way to understand what people are discussing on Bluesky, but the way they are defined has evolved and become more complex over the years, depending on the context: for instance, if you are consulting Bluesky in the UK, you might see trending topics that are closely linked to this country. You can also go to Bluesky and use the search bar for specific hashtags, meaning words preceded by #
. Posts that appear in the search results might contain other hashtags beyond your initial search: you can then follow the chain of hashtag links to collect the most relevant ones for your query. This is known as the “snowballing” technique. Of course, you may already have a defined object of interest and look for specific keywords independently of trending topics.
You should also consider the expected size of your corpus of posts. How big should your corpus be? Another way to think about this is: how many posts do you need for your research to produce reliable results? The answer will depend on many factors such as your topic (what you want to study and how you want to study it), the number of posts that were produced on your chosen topic, and technical limitations (the tool you are using to collect the posts, limitations of the API, etc). This is not really a question that we can answer within this lesson, as each case is unique.
Some important points to understand to help you maximise your query:
- You can create complex queries using keyword and hashtag combinations. The Bluesky API specifies certain search operators that work similarly to Boolean operators and are not case sensitive: you can search for exact matches by “putting statements inside double quotation marks”; if you want to search for posts containing all the words or phrases in your query, simply use a space between them, e.g. 1916 commemoration; the Boolean OR statement is acheieved by using a vertical line between words, e.g.
commemoration | remembrance
. For example, if I want to find posts about the commemoration of the women involved in the 1916 Easter rebellion in Ireland, “women centenary” would not be specific enough; a better search query would be women centenary#1916rising | “easter rising”
. See more about writing Bluesky search queries here. - Depending on the topic you are working on, it may not suffice to follow a small set of hashtags to build your corpus. Topics like #Trump or #ukrainewar produce a large number of posts a day; however, with some exceptions, commemorations generate far fewer posts. If your preferred topic is likely to produce a very small corpus which might hinder a meaningful analysis, you may need to use keywords in addition to hashtags. This type of query can become complex, but still you can test it using the Bluesky search bar to make sure it returns the expected results before implementing it in Communalytic. To create the dataset in Communalytic, click on the “Start Data Collection” button. A new page will then be loaded while the data is being captured.
- You can build your corpus over a few days if necessary. You may, however, need to anticipate a major/annual commemoration or historic event. Some examples of annual “memorial” hashtags include: #WW1 #LestWeForget #Bloomsday #ArmisticeDay.
- If there are no posts that match your query, you will receive an error message.
Congratulations! You now have your first Bluesky dataset and can analyse it in various ways. A summary will appear at the bottom of the page. To begin analysing your data, click on the magnifying glass symbol under “Records” to access an overview of the dataset. From here, you can also download a spreadsheet containing the posts in Excel or CSV format if you wish to use another analysis tool. When you go to “Download Dataset”, you will also see a table of the posts that you have collected, with a search bar at the top if you want to search individual posts. You can export your data and analyse them with any method and tool that you prefer – we mention some at the end of the next section. We also strongly recommend that you download your dataset to preserve your data so that you can reuse them in your future research activities.
Text analysis
Text analysis is one of the basic analysis operations you can apply to a corpus of posts. Below we present how you can use the text analysis features offered by Communalytic.
Once you have your dataset, as shown in the previous step,go to “Dataset Overview Module”, where you can browse high-level data such as posts per day and accounts that post most frequently on your topic (“Top Posters”). This overview includes a word cloud, which shows the words that occur most frequently in your corpus. But you can do more than this. For example, you can also click on a keyword or hashtag to inspect it in context (i.e. where the term appears in the posts). You can also do the same with the Emoji cloud.
Next, let’s see how you can explore topics within the dataset. The “Topic Analysis” function creates groups, or “clusters”, of posts that are similar in meaning to each other. These “cluster embeddings” may then allow you to identify abstract concepts, topics or themes within the dataset. Using the default clustering algorithm, click “Visualize Embeddings” [embedding = numerical representation of information] – this will be queued in the server and you may need to wait a few moments. Then click on “Open Visualization” to view and explore the word clusters, which will appear as data points in a “similarity map”. You can then adjust the clustering parameters and analyse the data again. For example, if you lower the “minimum cluster size” you will see a higher number of distinct clusters of posts. Use the exploration tool in the sidebar to zoom in on different clusters and label them. You may also download these data as a CSV file, if you wish – and again, we strongly recommend that you download and preserve any data you use for your analysis.
By now you have already learned a lot, so let’s take some time to reflect. Communalytic has allowed you to generate and explore a word cloud based on your corpus, but how exactly did this help you to understand and analyse your data? How useful has this been for your research, if at all? To help you think through these questions, you can read this article that discusses the limits of word clouds. You can even try to use other tools and compare the visualisations that you get: Voyant Tools is one option, but you can browse the Text Analysis Portal for Research (TAPOR) to pick your preferred tool. Note that using different tools may require you to do some data cleaning - for instance, you might observe that Bluesky handles are appearing in the word cloud and this is not of great interest - or special formatting. A detailed article on data cleaning can be found on Wikipedia. You can also discuss your experience with your colleagues or classmates or even a community of users.
Network analysis
Network analysis is a second kind of analytical operation that can be applied to a social media data corpus. If you are not familiar with this field, Marten Düring’s lesson on data extraction and network visualisation of historical sources offers a nice introduction for beginners. Once you have your dataset, click on the “Network Analyzer” module and you will see several options for different types of “ties”. Ties represent interactions between Bluesky accounts, which can take several forms: replying (using the “reply” functionality: your post will then appear below the original post and start or continue a conversation) and quoting (quoting another account’s post with a comment); reposting (quoting another account’s post with no modification); mentioning (publishing a post with another account’s handle in it); and link sharing, in other words “account-to-website” ties. The Bluesky user accounts are the nodes of the network you wish to inspect and the ties are the relationships that connect these nodes.
Choose the type of interaction you want to examine and click on “Generate Network”. You will have various options: you can download the network data as a GraphML file or a Gephi file, “Visualize Network” or choose a different type of interaction to work with.
Here there are two important things to mention. First, the nodes – the Bluesky accounts – are grouped in clusters which means these accounts share some form of similarity. These clusters are calculated by an algorithm that detects how the Bluesky accounts are connected and figures out the best way to arrange these connections visually. Second, you can choose a layout to visualise the network you are analysing. A layout is a way to display the nodes (Bluesky accounts) and the connections between them (in graph theory, these connections are also called “edges”, which is another way of saying ties or links). Layouts are based on algorithms, which is why there are different possible layouts. A layout allows you to see patterns in the structure of your network. The best layout is the one that fits your dataset and your research purpose – there are no “good” or “bad” layouts per se.
You can use the Communalytic built-in visualiser to experiment with different layouts and see what kinds of visualisations they produce for your network. You can also take a closer look at what constitutes your network. For example, you can explore metrics that determine the centrality of the network’s nodes. Feel free to make these metrics visible by playing with the layout algorithms and exploring various filters. If you wish to focus on different parts of your network, you can explore “Community Clusters”. This will help you to isolate and focus on larger nodes, giving you a less detailed but clearer view of your network. Larger nodes represent Bluesky accounts with more interactions with other accounts, the highest being ranked first.
Communalytic also allows you to layer multiple types of analysis within the network, for example by running a “Sentiment” analysis on the text within the posts, which is to say identifying and describing “positive”, “neutral” or “negative” emotions or opinions about a topic within a corpus of text. This uses natural language processessing (NLP) to score posts for positivity, neutrality or negativity and can then be represented in the density of edges in the network visualisation. This may assist in thinking about the mentalités of user groups around an historical topic, or simply help you to contextualise themes found through text analysis. For a more detailed look at the ways in which sentiment analysis can be used to analyse social media data, see this book chapter. Likewise, the “Civility” analysis option (formerly the “Toxicity Analyzer) can help to identify posts containing either harmful or helpful (“prosocial”) language. However, bear in mind that the interpretation of language in a social media dataset will also depend on your research questions and must be considered in context. All of the techniques outlined above are different ways of representing the data – but remember, visualisations are interpretations, they are not raw data. If you are happy with the results, you can also save and export your visualisation to integrate it into a future report or presentation.
How can network visualisations be useful for historians? There is a vast bibliography of publications that explore this question, but it is not the object of the current tutorial. What is useful to remember, however, is that you need to fix and focus on a research objective that is related to a historical question. You may benefit from Martin Grandjean’s general introduction to social networks analysis in history,which will also give you insights into network metrics and structures such as degree centrality and communities. These are metrics that help analyse social media, specifically posts and networks, to identify dominant voices (nodes/Bluesky accounts) in the network (official, news media, themed accounts, cultural institutions, individual influencers, etc.).
As for text analysis, you can also download your network’s data and perform further analyses with Gephi software or your preferred social network analysis tool. See Martin Grandjean’s tutorial to learn how to use Gephi.
Reading suggestions
For more case studies and tutorials using Communalytic see the dedicated page on the Communalytic website.
General
Bruns, Axel, Adam Edwards, Roser Beneito-Montagut, Richard Fitzgerald, and William Housley. 2023. “Social Media Analytics: Boom and Bust?” In The SAGE Handbook of Digital Society, edited by William Housley, Adam Edwards, Roser Beneito-Montagut, and Richard Fitzgerald, 249–64. 55 City Road London: SAGE Publications Ltd. DOI: https://doi:10.4135/9781529783193.n15.
Boyd, Danah, and Kate Crawford. 2012. “Critical Questions for Big Data: Provocations for a Cultural, Technological, and Scholarly Phenomenon.” Information Communication and Society 15, no. 5: 662–79. DOI: https://doi.org/10.1080/1369118X.2012.678878.
Janetzko, Dietmar. 2016. “The Role of APIs in Data Sampling from Social Media.” In The SAGE Handbook of Social Media Research Methods, edited by Luke Sloan and Anabel Quan-Haase, 146–60. London: SAGE Publications Ltd. DOI: https://doi.org/10.4135/9781473983847.
Moreno-Ortiz, Antonio. “Sentiment.” Making Sense of Large Social Media Corpora: Keywords, Topics, Sentiment, and Hashtags in the Coronavirus Twitter Corpus, edited by Antonio Moreno-Ortiz, Springer Nature Switzerland, 2024, pp. 141–68. DOI: https://doi.org/10.1007/978-3-031-52719-7_6.
Rockwell, Geoffrey, and Stéfan Sinclair. 2016. Hermeneutica: Computer-Assisted Interpretation in the Humanities. Cambridge, Massachusetts: The MIT Press.
Rogers, Richard. 2019. Doing Digital Methods. London: SAGE Publications.
Twitter data as primary sources
Since for many years social media research focused primarily on Twitter (before it became X), there is a huge amount of literature on Twitter. These references are still valid if you wish to collect data on X, and they also offer many methodological insights.
LSE Blog – Using Twitter as a Data Source
Ahmed, Wasim, Peter A. Bath, and Gianluca Demartini. 2017. “Using Twitter as a Data Source: An Overview of Ethical, Legal, and Methodological Challenges.” In The Ethics of Online Research (Advances in Research Ethics and Integrity, vol. 2), edited by Peter A. Bath and Kandy Woodfield, 79–107. Bingley: Emerald Publishing Limited. DOI: https://doi.org/10.1108/S2398-601820180000002004.
Clavert, Frederic. 2018. “Commémorations, Scandale et Circulation de l’information : Le Centenaire de La Bataille de Verdun Sur Twitter.” French Journal for Media Research 10, (special issue: Le Web 2.0 : lieux de perception des transformations des sociétés). Link to publication.
Gruzd, Anatoliy, and Philip Mai. 2020. “Going viral: How a single tweet spawned a COVID-19 conspiracy theory on Twitter.” Big Data & Society 7 (2). DOI: https://doi.org/10.1177/2053951720938405.
Rantasila, Anna, Anu Sirola, Arto Kekkonen, Katja Valaskivi, and Risto Kunelius. 2018. “#fukushima Five Years On: A Multimethod Analysis of Twitter on the Anniversary of the Nuclear Disaster.” International Journal Of Communication 12: 928–49.
Smyth, Hannah and Diego Ramírez Echavarría. 2021. “Twitter and feminist commemoration of the 1916 Easter Rising.” Journal of Digital History, 1 (1). Link to publication
Bluesky and Mastodon data as primary sources
Cava, Lucio La, et al.. 2023. “Drivers of Social Influence in the Twitter Migration to Mastodon.” Scientific Reports 13 (1): 1–12. DOI: https://doi.org/10.1038/s41598-023-48200-7.
Failla, Andrea, and Giulio Rossetti. 2024. ““I’m in the Bluesky Tonight”: Insights from a Year Worth of Social Data.” PLoS One 19(11): e0310330. DOI: https://doi.org/10.1371/journal.pone.0310330
Gehl, Robert W. Move Slowly and Build Bridges: Mastodon, the Fediverse, and the Struggle for Democratic Social Media. Oxford University Press, 2025. Silverchair, DOI: https://doi.org/10.1093/9780197776711.001.0001.
Quelle, D., Bovet, A.: Bluesky: Network Topology, Polarisation, and Algorithmic Curation. arXiv preprint arXiv:2405.17571 (2024)
Sahneh, Erfan Samieyan, et al. (2025). The Dawn of Decentralized Social Media: An Exploration of Bluesky’s Public Opening. In: Aiello, Luca Maria, et al. (eds.). Social Networks Analysis and Mining. ASONAM 2024. Lecture Notes in Computer Science, vol. 15211. Springer, Cham. Link to preprint.
Stokel-Walker, Chris. “Should I Join Mastodon? A Scientists’ Guide to Twitter’s Rival.” Nature, Nov. 2022. DOI: https://doi.org/10.1038/d41586-022-03668-7.