{
  "$type": "site.standard.document",
  "bskyPostRef": {
    "cid": "bafyreifqj6pztx3j35sg7hx4aycbbfxdpv7ua44zhshe4zax6un5pctd3q",
    "commit": {
      "cid": "bafyreic5vzupwr4m523bjcqcjfojowlenc72mztmegqelphcwhpbe3t4la",
      "rev": "3mnfgoewjic2n"
    },
    "uri": "at://did:plc:2hgmrwevidwsxundvejdeam5/app.bsky.feed.post/3mnfgoesy7c2t",
    "validationStatus": "valid"
  },
  "content": {
    "$type": "pub.leaflet.content",
    "pages": [
      {
        "$type": "pub.leaflet.pages.linearDocument",
        "blocks": [
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.text",
              "plaintext": "Today I'm launching a completely new backend for Sill, one that removes Sill's dependency on the Bluesky AppView and broadens Sill's link aggregation to the rest of the Atmosphere. For the technical details, scroll down to the bottom of this post. First, I'll explain the user-facing improvements that this new backend enables."
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.header",
              "level": 2,
              "plaintext": "Same Sill, just better"
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.text",
              "plaintext": "For the most part, Sill will look the same to longtime users. It just works better now. The new backend is better at finding links in your network's activity, better at matching slightly different URLs into the same canonical URL, faster to load new activity from your network, and less susceptible to connection errors with your account."
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.text",
              "plaintext": "On finding links, Sill is better at finding multiple links in the same post, looking through nested quote posts to find the original link shared, and providing context around where a link came from, whether it was from a custom feed or a reply someone you follow made to someone else."
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.text",
              "plaintext": "One of Sill's longstanding pain points is that it wasn't perfect at matching shares that were to the same page, but had differing share URLs (for example, tracking query parameters, gift link codes, URL shorteners). The old backend did its best, but the new one is better at it. As a result, you should see fewer duplicates, and you should see more link cards with rich metadata like publish times and authors."
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.header",
              "level": 2,
              "plaintext": "Activity from across the Atmosphere"
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.text",
              "plaintext": "Did you know that your Bluesky account can log into a bunch of other services? We call this collection of services the Atmosphere, and the way these products all interoperate is part of a broad vision this developer community has to remake the social internet on human terms."
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.text",
              "plaintext": "While Bluesky is still the largest actor on the Atmosphere, there is much more you can do with your account. Sill wants to help you discover what your network is already doing across the Atmosphere through the power of link aggregation."
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.text",
              "facets": [
                {
                  "features": [
                    {
                      "$type": "pub.leaflet.richtext.facet#link",
                      "uri": "https://semble.so/"
                    }
                  ],
                  "index": {
                    "byteEnd": 37,
                    "byteStart": 31
                  }
                }
              ],
              "plaintext": "For example, do you know about Semble? It's a \"social knowledge network for learners,\" letting you bookmark and organize everything you encounter across the web. You can curate collections with others in the network and learn from everyone participating on Semble. It's a great product, and now Sill can show you what your network is bookmarking."
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.image",
              "aspectRatio": {
                "height": 1350,
                "width": 1106
              },
              "image": {
                "$type": "blob",
                "ref": {
                  "$link": "bafkreicmrn7luav4physeyqdhb747u4rvvb6s6itynmhevbxzq4evuyijq"
                },
                "mimeType": "image/webp",
                "size": 109790
              }
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.text",
              "facets": [
                {
                  "features": [
                    {
                      "$type": "pub.leaflet.richtext.facet#italic"
                    }
                  ],
                  "index": {
                    "byteEnd": 125,
                    "byteStart": 118
                  }
                },
                {
                  "features": [
                    {
                      "$type": "pub.leaflet.richtext.facet#link",
                      "uri": "https://kipclip.com/"
                    }
                  ],
                  "index": {
                    "byteEnd": 318,
                    "byteStart": 311
                  }
                }
              ],
              "plaintext": "Speaking of bookmarking, Sill also supports the community lexicon for bookmarks. This is what Sill has been using for writing user bookmarks (click the bookmark icon under a link card!), but now it can read them back, and you can see what the rest of your network is bookmarking. These bookmarks also work with Kipclip!"
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.text",
              "facets": [
                {
                  "features": [
                    {
                      "$type": "pub.leaflet.richtext.facet#link",
                      "uri": "https://standard.site/"
                    }
                  ],
                  "index": {
                    "byteEnd": 60,
                    "byteStart": 47
                  }
                },
                {
                  "features": [
                    {
                      "$type": "pub.leaflet.richtext.facet#footnote",
                      "contentPlaintext": "Today, Sill supports links in documents that use the leaflet.pub, pckt.blog, and offprint.app content lexicons. I'll add support for more as they come along.",
                      "footnoteId": "019e8e21-bc29-733d-ae63-f9655bfb2210"
                    }
                  ],
                  "index": {
                    "byteEnd": 71,
                    "byteStart": 70
                  }
                }
              ],
              "plaintext": "Beyond bookmarking, Sill also finds links from standard.site documents* (like this very blog post). Sill will quote the paragraph the link came from and link you out to the blog post as well."
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.image",
              "aspectRatio": {
                "height": 1384,
                "width": 1094
              },
              "image": {
                "$type": "blob",
                "ref": {
                  "$link": "bafkreidf4fudbkqtipcu6n4kfbra2lvpfcdu555loorp6lspyz35hkrkg4"
                },
                "mimeType": "image/webp",
                "size": 104718
              }
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.header",
              "level": 2,
              "plaintext": "New ways to browse your links"
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.text",
              "facets": [
                {
                  "features": [
                    {
                      "$type": "pub.leaflet.richtext.facet#link",
                      "uri": "https://404media.co/"
                    }
                  ],
                  "index": {
                    "byteEnd": 295,
                    "byteStart": 286
                  }
                }
              ],
              "plaintext": "With better support for rich metadata around links, I can now launch a feature I've had planned for a while. You can now browse your network by domain and by author. To do so, just click on the site name or the author name in a link card. For example, I can see all of the stories from 404 Media that my network has shared over the last two weeks."
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.image",
              "aspectRatio": {
                "height": 1774,
                "width": 2624
              },
              "image": {
                "$type": "blob",
                "ref": {
                  "$link": "bafkreih3vuxfvfw2bc3rgtyjfm3gsvfrxmfjq6jhdzsl5i4z3oslu47kyi"
                },
                "mimeType": "image/webp",
                "size": 198944
              }
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.text",
              "plaintext": "If I really like Sam Cole's writing in particular, I can drill down to an author page as well."
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.image",
              "aspectRatio": {
                "height": 1768,
                "width": 2646
              },
              "image": {
                "$type": "blob",
                "ref": {
                  "$link": "bafkreihqa5g2noxmtrhplidcwr2ece4zafhtugoqrw4iez5k42lqcglx5y"
                },
                "mimeType": "image/webp",
                "size": 234156
              }
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.text",
              "plaintext": "Where possible, Sill joins publications and authors to their atproto identity. Right now, Sill is pretty conservative about matching, relying on direct handle matching and Bluesky's Trusted Verification system. Thus, not every publication/author will have fully hydrated profile screens. The worst thing this could do is return false positives, so please let me know if you see any."
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.header",
              "level": 2,
              "plaintext": "What about Mastodon?"
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.text",
              "plaintext": "From day one, Sill has worked with Mastodon. That's still true today. However, if you only connect a Mastodon account to Sill, you won't see any additional activity beyond Mastodon posts."
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.header",
              "level": 2,
              "plaintext": "The technical details"
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.text",
              "plaintext": "If you're an atproto dev and you've read this far, you've probably deduced that Sill now runs off of its own AppView. It's a full network-ish AppView optimized for aggregative queries about URLs against a user's social graph. For example: what URLs are most common in a user's network over 24 hours? This query is Sill's default view."
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.text",
              "facets": [
                {
                  "features": [
                    {
                      "$type": "pub.leaflet.richtext.facet#link",
                      "uri": "https://constellation.microcosm.blue/"
                    }
                  ],
                  "index": {
                    "byteEnd": 101,
                    "byteStart": 88
                  }
                },
                {
                  "features": [
                    {
                      "$type": "pub.leaflet.richtext.facet#italic"
                    }
                  ],
                  "index": {
                    "byteEnd": 128,
                    "byteStart": 121
                  }
                }
              ],
              "plaintext": "When I talk to atproto devs about Sill, the most common question I get is, \"Why not use Constellation?\" Constellation is awesome, but it doesn't quite do what Sill needs. Constellation works best when you already know the URL and want every possible reference. Sill's job is to discover what the URLs are in your network. You could probably cobble it together via a bunch of Constellation calls, but it probably wouldn't scale well."
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.text",
              "facets": [
                {
                  "features": [
                    {
                      "$type": "pub.leaflet.richtext.facet#footnote",
                      "contentPlaintext": "Apologies to all the PDS providers out there! Sill should be spamming you less now.",
                      "footnoteId": "019e8e22-3544-733d-ae64-f4a8e40ab540"
                    }
                  ],
                  "index": {
                    "byteEnd": 324,
                    "byteStart": 323
                  }
                },
                {
                  "features": [
                    {
                      "$type": "pub.leaflet.richtext.facet#italic"
                    }
                  ],
                  "index": {
                    "byteEnd": 497,
                    "byteStart": 493
                  }
                }
              ],
              "plaintext": "Sill's solution to the problem, back when I originally built it in 2024, was to crib everything off the Bluesky AppView. I looped through every account connected to Sill, called app.bsky.feed.getTimeline, looked for new posts with links in them, and wrote them to Sill's database. It worked for a while, but it didn't scale*. Sill got slower every time a new user signed up. And maintaining all of those OAuth tokens for the worker was a nightmare. But this is why atproto is so cool: I don't have to use the Bluesky AppView to get the data I want. I can also build my own using the firehose (or in my case, jetstream)."
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.text",
              "plaintext": "The Sill AppView takes a pretty similar approach to Constellation at the start: listen for all records and walk them for anything that resembles a URL. Write down where in the record that URL occurs."
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.text",
              "plaintext": "From there, I take a different approach. The Sill AppView special cases some lexicons, namely follow and block lexicons from across the network. With this, it builds social graphs, enabling easy indexing for following timelines. For now, the AppView only builds graphs for Sill users, but I may scale this to the entire network in the future. (Any new user who signs up gets their graph built on-demand, which thankfully only takes a couple seconds.)"
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.text",
              "plaintext": "I also run a scraper against every URL the walk finds to extract as much metadata as possible. This is what powers the publication/author routes I showed above. Most of the complicated work in this AppView is actually on this side: resolving link shorteners and tracking params to canonical URLs, matching publications and authors to DIDs, adding layers of verification to ensure Sill doesn't pick up impersonations."
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.text",
              "plaintext": "In total, the Sill AppView does the following:"
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.unorderedList",
              "children": [
                {
                  "$type": "pub.leaflet.blocks.unorderedList#listItem",
                  "content": {
                    "$type": "pub.leaflet.blocks.text",
                    "plaintext": "Finds and indexes URLs referenced in records on AT Protocol"
                  }
                },
                {
                  "$type": "pub.leaflet.blocks.unorderedList#listItem",
                  "content": {
                    "$type": "pub.leaflet.blocks.text",
                    "plaintext": "Scrapes URL metadata for each unique URL and resolves to canonical URLs"
                  }
                },
                {
                  "$type": "pub.leaflet.blocks.unorderedList#listItem",
                  "content": {
                    "$type": "pub.leaflet.blocks.text",
                    "plaintext": "Indexes social graphs for Sill users"
                  }
                },
                {
                  "$type": "pub.leaflet.blocks.unorderedList#listItem",
                  "content": {
                    "$type": "pub.leaflet.blocks.text",
                    "plaintext": "Attempts to match publications and authors found via URLs to DIDs on AT Protocol"
                  }
                },
                {
                  "$type": "pub.leaflet.blocks.unorderedList#listItem",
                  "content": {
                    "$type": "pub.leaflet.blocks.text",
                    "plaintext": "Surfaces an API for Sill to easily query for trending URLs in arbitrary user networks"
                  }
                }
              ]
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.text",
              "plaintext": "It runs on a $60/month OVH box, and honestly, I probably over-provisioned."
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.header",
              "level": 2,
              "plaintext": "Limitations"
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.text",
              "plaintext": "There are some limitations to this AppView:"
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.unorderedList",
              "children": [
                {
                  "$type": "pub.leaflet.blocks.unorderedList#listItem",
                  "content": {
                    "$type": "pub.leaflet.blocks.text",
                    "plaintext": "Custom feeds still have to go through the same looping worker process, since the only way to get a response from a feed that is customized to a user (like For You) is a proxied PDS request."
                  }
                },
                {
                  "$type": "pub.leaflet.blocks.unorderedList#listItem",
                  "content": {
                    "$type": "pub.leaflet.blocks.text",
                    "plaintext": "I have not backfilled the whole network for all of history. I'm keeping a rolling 90-day window. Sill is all about recency, so there is very little benefit to keeping full history around."
                  }
                },
                {
                  "$type": "pub.leaflet.blocks.unorderedList#listItem",
                  "content": {
                    "$type": "pub.leaflet.blocks.text",
                    "plaintext": "Moderation relies on the Bluesky moderation labeler. The AppView operates on !takedown and !suspend. I'd like to expand this, and make it customizable per user, in the future."
                  }
                },
                {
                  "$type": "pub.leaflet.blocks.unorderedList#listItem",
                  "content": {
                    "$type": "pub.leaflet.blocks.text",
                    "plaintext": "For now, the AppView is closed source, and the API is private. Mostly, I want to make sure this actually works for Sill at scale before I open it up to others. But I will open source the AppView and make my API instance publicly accessible in time."
                  }
                }
              ]
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.header",
              "level": 2,
              "plaintext": "What's next"
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.text",
              "plaintext": "I'll be monitoring the AppView to make sure it holds up to production scale. But once we're stable, this AppView empowers a whole bunch of new features I've wanted to build for Sill for a long time. Also, I'm testing an iOS app. Stay tuned."
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.text",
              "plaintext": ""
            }
          },
          {
            "$type": "pub.leaflet.pages.linearDocument#block",
            "block": {
              "$type": "pub.leaflet.blocks.text",
              "plaintext": ""
            }
          }
        ],
        "id": "019e895e-2f29-7446-bd32-bac94d318b56"
      }
    ]
  },
  "coverImage": {
    "$type": "blob",
    "ref": {
      "$link": "bafkreih3vuxfvfw2bc3rgtyjfm3gsvfrxmfjq6jhdzsl5i4z3oslu47kyi"
    },
    "mimeType": "image/webp",
    "size": 198944
  },
  "description": "Some major improvements come to Sill today",
  "path": "/3mnfgoajlps2v",
  "publishedAt": "2026-06-03T15:33:54.432Z",
  "site": "at://did:plc:2hgmrwevidwsxundvejdeam5/site.standard.publication/3lprgsvtvtk23",
  "tags": [
    "atproto",
    "sill"
  ],
  "title": "Sill's new view"
}