---
title: "Networks"
output: rmarkdown::html_vignette
vignette: >
%\VignetteIndexEntry{Networks}
%\VignetteEngine{knitr::rmarkdown}
%\VignetteEncoding{UTF-8}
---
# Get Followers and Follows
You can retrieve a list of followers and those followed by a user through the `get_followers` and `get_follows` functions, respectively. This gives a glimpse of their social dynamics on the platform.
## Load the package
``` r
library(atrrr)
```
## `get_followers`
Retrieve the followers of a specific account with `get_followers`:
``` r
get_followers(actor = "benguinaudeau.bsky.social", limit = 200) |>
dplyr::glimpse()
#> Rows: 200
#> Columns: 8
#> $ did "did:plc:nol67uyam6hzj5…
#> $ indexed_at 2024-02-29 13:50:12, 2…
#> $ actor_handle "dkarpa.bsky.social", "…
#> $ actor_name "David Karpa", "Rémi Pa…
#> $ actor_description "PhD-candidate UBremen.…
#> $ actor_avatar "https://cdn.bsky.app/i…
#> $ viewer_data [FALSE, FALSE], [FALSE…
#> $ labels_data [], [], [], [], [], []…
```
## `get_follows`
Retrieve the accounts that are followed by a specific account with `get_follows`:
``` r
get_follows(actor = "benguinaudeau.bsky.social", limit = 200) |>
dplyr::glimpse()
#> Rows: 174
#> Columns: 8
#> $ did "did:plc:3ryku2cbgpazor…
#> $ indexed_at 2024-02-08 05:16:04, 2…
#> $ actor_handle "beamagistro.bsky.socia…
#> $ actor_name "Beatrice Magistro", "S…
#> $ actor_description "PostDoc @Caltech, thru…
#> $ actor_avatar "https://cdn.bsky.app/i…
#> $ viewer_data [FALSE, FALSE], [FALSE…
#> $ labels_data [], [], [], [], [], []…
```
You'll notice each follower/following has a description (i.e. their bio). It's a nifty way to get to know a bit about them at a glance!
## Follower Network Visualization
This section guides you through the process of visualizing a follower network for a given user on Blue Sky. The primary focus is on the interconnected relationships among followers.
The first step is to load some additional packages. Then we get the followers for the main user we are interested in. We will then delve deeper and fetch the followers for each of these followers.
``` r
library(ggplot2)
library(dplyr)
library(purrr)
library(tidyr)
library(igraph)
library(ggraph)
library(tidygraph)
# Retrieve the followers for the main user
some_followers <- get_followers(actor = "benguinaudeau.bsky.social", limit = 10)$actor_handle
# For each follower, retrieve their own set of followers.
# This provides a nested view of relationships.
followers_of_followers <- some_followers |>
purrr::map_dfr(~{
get_followers(actor = .x, limit = 200) |>
mutate(from = .x)
}) |>
dplyr::rename(to = actor_handle) |>
dplyr::select(from, to) %>%
dplyr::add_count(to, name = "n_to") %>%
dplyr::add_count(from, name = "n_from") %>%
dplyr::filter(n_to > 1 | n_from > 1) %>%
dplyr::select(-n_to:-n_from)
```
## Building and Visualizing the Follower Network
``` r
# Construct the network graph and plot
graph <- tidygraph::as_tbl_graph(followers_of_followers, directed = TRUE)
# Use ggraph to visualize the network.
ggraph::ggraph(graph, layout = 'fr') +
ggraph::geom_edge_link() +
ggraph::geom_node_point(aes(size = tidygraph::centrality_pagerank()), color = "lightblue") +
ggraph::geom_node_text(aes(label = name, size = tidygraph::centrality_pagerank(), family = "mono", fontface = "bold"),
vjust = 1, hjust = 1, check_overlap = T, color = "white", show.legend = F) +
ggraph::geom_node_text(aes(label = name, size = tidygraph::centrality_pagerank(), family = "mono"),
vjust = 1, hjust = 1, check_overlap = T, color = "blue", show.legend = F) +
ggplot2::theme_void() +
ggplot2::theme(legend.position = "bottom")
```
## Find people to follow
You can use a similar approach to find new people you might want to follow.
First get all the people you already follow by quering your own account:
``` r
my_follows <- get_follows(actor = "jbgruber.bsky.social",
limit = 10)$actor_handle # limit only for demonstration
# For each account you follow, retrieve who they follow.
follows_of_follows <- my_follows |>
purrr::map_dfr(~{
get_followers(actor = .x, limit = 100) |>
mutate(from = .x)
})
# Now we can check which accounts are popular among the people you already follow
follows_of_follows |>
dplyr::filter(!actor_handle %in% my_follows) |> # exclude accounts you already follow
dplyr::count(actor_name, actor_handle, sort = TRUE)
#> # A tibble: 704 × 3
#> actor_name actor_handle n
#>
#> 1 Johannes B. Gruber jbgruber.bsky.s… 9
#> 2 Center for Ballot Freedom fusionvoting.bs… 4
#> 3 David Karpa dkarpa.bsky.soc… 3
#> 4 Jacob Ware jacobware.bsky.… 3
#> 5 Jens Rydgren jensrydgren.bsk… 3
#> 6 edminkardes gorkem.me 3
#> 7 Adrian Florea aflorea.bsky.so… 2
#> 8 Brian O'Meara omearabrian.bsk… 2
#> 9 Darren Dahly statsepi.bsky.s… 2
#> 10 Erik Angner erikangner.com 2
#> # ℹ 694 more rows
```
The original account shows up in this overview, as do accounts that were excluded because of the limit set to do the demonstration.
But all of these accounts look interesting!
# Likes and Reposts
You can also retrieve the accounts that liked or reposted your skeets.
## Who liked your skeets?
Want to create like networks? The `get_likes` function allows you to extract information about users who liked a specific post. By simply providing the post's URL, you can get a list of users who expressed their appreciation for the content.
``` r
get_likes("https://bsky.app/profile/ryanlcooper.com/post/3kb42gayda52t") |>
dplyr::glimpse()
#> Rows: 25
#> Columns: 5
#> $ created_at 2023-10-06 21:22:39, 2023-1…
#> $ indexed_at 2023-10-06 21:22:39, 2023-1…
#> $ actor_handle "csehested.bsky.social", "da…
#> $ actor_name NA, "TassieDevyl", "Hans LeJ…
#> $ actor_data ["did:plc:zzsj7hy3wec6fhbwu…
```
## Who reposted your skeets?
Want to create repost networks? Reposts (or reskeets), akin to retweets on platforms like Twitter, amplify the reach of content by sharing it with a wider audience.
The `get_reposts` function is designed to retrieve information about users who reposted a specific piece of content.
``` r
get_reposts(post_url = "https://bsky.app/profile/ryanlcooper.com/post/3kb42gayda52t") |>
dplyr::glimpse()
#> Rows: 25
#> Columns: 8
#> $ did "did:plc:zyvmwfzbkt3igd…
#> $ indexed_at 2024-01-26 00:03:39, 2…
#> $ actor_handle "zunguzungu.bsky.social…
#> $ actor_name "Aaron Bady", "Bertie R…
#> $ actor_description "Meat blood, bees, thin…
#> $ actor_avatar "https://cdn.bsky.app/i…
#> $ viewer_data [FALSE, FALSE], [FALSE…
#> $ labels_data [], [], [], [], [], []…
```