Second, the boundaries between IndieWeb building blocks are defined by standards; Once I set out to build a Microsub server, I was not engaged in decisions related to Microsub clients (except through bug reporting, feature requests, and other troubleshooting). This belief had some merit, but with hindsight and further observation I have realized that some of the errors I encountered with other clients also occurred with Monocle, yet resulted in a more graceful failure. In brief, the same underlying error was encountered in both cases, but it was smoothed over in Monocle such that things could still operate invisibly as an infrastructure in the background. In some cases, one party demonstrated that the other had misinterpreted the spec, in which case person who had made an error would typically update their code to rectify their mistake. Nonetheless, problems can arise when either client or server interprets the standard differently, or otherwise includes an error. People publishing using IndieWeb building blocks can exercise considerable freedom in choosing how to structure and present Web content they publish, and this increases the complexity of writing a tool like Yarns that must make sense of messy data.
This has been a major concern among corporate social networks, with companies like Facebook and Twitter devoting increasing attention toward content moderation (Gillespie 2018). The response typically employed by corporate platforms, to hire moderators to review and remove offensive content, is not feasible in a system like IndieWeb that lacks centralized gatekeepers by design. First, like many projects, Bridgy is not contained wholly within a single repository, instead relying on pieces from other repositories to perform some of its functions. First, h-feed elements are contained within an h-card. First, discussions were a way to present one’s views to other developers, encouraging the spread of particular design approaches. The purpose of this dissertation has been to investigate the activities involved in building and maintaining IndieWeb, with particular attention to designers’ values. Discussions of all sorts were crucial for articulating values. Both processes and outcomes of these discussions varied by circumstance. This illustrates the extent to which technical, human, and Xtenze Plus Ingredients postsocial ties co-constitute one another, since the existence of the Microsub standard articulated a norm about anticipated users, which contributed to its communal uptake.
This clarification offers a new view on the bug described earlier between Yarns and the Indigenous Microsub client. The component of Yarns that has taken the longest time to implement and maintain is parsing websites. As it turned out, I did a haphazard job of parsing events, since rather than following the spec, I wrote code for parsing events based on the structure I had observed on people’s websites, which largely used the e-content property. At IndieWeb Summit 2018, Xtenze Plus Ingredients I had a conversation with an attendee who contributes to a large number of IndieWeb WordPress plugins, one of which includes code for parsing websites. Based on this appreciation, I attempted to make Yarns’s code more modular in the same way. Specifically, RSS and Atom feeds are presented in .RSS or .XML files, which are not intended to be read by humans directly, and MF2 feeds are constructed directly in the same HTML that is viewed by human readers of a website.
On a meso level, IndieWeb’s building block approach is an articulation of the same separations of concerns concept. On a micro level, separations of concern structured sections of code within a project. From an instrumental perspective, my code increased in quality as I adopted this approach, yet this was a challenge for ongoing reflection. This type of thinking does tend to close off “critical” reflection since it requires an intense focus on just getting the thing to work. As described earlier in this chapter, that is what allows IndieWeb sites to parse incoming Webmentions (e.g. to display Bob liked this post or Bob replied to this post), and is also useful for software such as feed readers to identify and filter posts by type (e.g. to display a feed of only photos, or only replies). Feed items are communicated from server to client using a format called JF2, which was edited by IndieWeb contributors and published by the W3C’s Social Web Working Group (Roberts and Marks 2018). The purpose of JF2 is to represent an MF2 feed using JavaScript Object Notation (JSON).22 JF2 is a clearly defined format, but allows some flexibility in data structures, which was a major source of errors between Yarns and various Microsub clients.