Fedify,一个 ActivityPub 服务器框架,已达到 v0

fedify,一个 activitypub 服务器框架,已达到 v0

activitypub 框架 fedify 终于发布了第一个稳定版本 1.0.0!

什么是 fedify?

fedify 是一个 typescript 库,可以轻松创建基于 activitypub 协议的联合服务器应用程序。 activitypub 是一种开放标准协议,允许社交网络服务相互通信,使用户能够在名为 fediverse 的去中心化社交网络中跨各种服务进行交互。

使用 fedify,开发人员可以通过高级 api 轻松构建联合服务器应用程序,而无需自行实现 activitypub 协议的复杂细节。 fedify 提供了许多开箱即用的 activitypub 实现所需的功能,包括 activitypub 对象的类型安全接口、webfinger、http 签名、链接数据签名和对象完整性证明。

此外,fedify 还包括与流行的 fediverse 软件(如 mastodon 或 meta 的 threads)的互操作性的特殊处理,允许开发人员创建可以轻松与现有 fediverse 生态系统集成的应用程序。此外,它还支持与各种web框架集成,并提供cli工具,使开发和调试过程更加方便。

主要变化

弃用术语 handle

从此版本开始,fedify 中的术语 handle 将仅用于指代 fediverse 句柄(例如,@hongminhee@fosstodon.org)。参与者的内部唯一 id(例如 b379dbdc-3b4f-4ef4-88c2-fc25632d1c22)被称为 标识符,webfinger 名称(例如 hongminhee)被称为 用户名.

api 中的术语 handle 将保留一段时间以实现向后兼容性,但将记录弃用警告,并计划在将来删除它。

更多详细信息,请参阅相关文档。

关联数据签名

链接数据签名是一个过时的标准,但它仍然被 mastodon 等主要联邦实现所依赖。

除了 http 签名和对象完整性证明之外,fedify 现在还支持此版本中的链接数据签名,从而支持 fediverse 中使用的所有类型的签名方法。这使得 fedify 成为具有最佳互操作性的 activitypub 实现。

但是,fedify 用户不需要执行任何特殊操作即可使用链接数据签名。如果传入活动具有链接数据签名,它会自动验证签名,并且所有传出活动都将具有三种格式的签名:http 签名、链接数据签名和对象完整性证明。

更多详细信息,请参阅相关文档。

活动转发

从此版本开始,您可以使用 inboxcontext.forwardactivity() 方法将收件箱中收到的活动转发给其他参与者。

乍一看,您可能认为可以使用 context.sendactivity() 方法重新发送收件箱中收到的活动。但是,如果您这样做,则在将活动传递到收件箱之前,原始签名会被删除,并且在发送活动时,会附加转发参与者的签名,从而导致转发活动的接收方不信任它。

另一方面,当使用 inboxcontext.forwardactivity() 方法时,活动将在保留原始签名的情况下转发,从而避免了此问题。 (当然,原始活动本身必须使用链接数据签名或对象完整性证明进行签名。)

更多详细信息,请参阅相关文档。

在 fedify 收件箱终止时发送删除(应用程序)

从此版本开始,fedify 收件箱将向终止时遇到的所有对等服务器发送删除(应用程序)活动。这通常是删除帐户时发送的活动,这将有助于防止与临时参与者相关的残留数据保留在其他服务器上。

postgresql 驱动程序

@fedify/postgres 包实现了 kvstore 和 messagequeue 接口的 postgresql 驱动程序,已与此版本一起发布。

postgresql 驱动程序是一个可以在生产中充分使用的后端,特别推荐给已经使用 postgresql 的项目。

此外,fedify init 命令中还添加了选择 postgresql 驱动程序的选项。

庆祝 fedify 1.0.0

随着 1.0.0 版本的发布,fedify 现在将尽可能保持 api 向后兼容性。 (当然,从长远来看,可能会出现破坏向后兼容性的 2.0.0。)这对于那些因为目前还没有稳定版本而一直犹豫是否使用 fedify 的人来说应该是个好消息!

fedify 1.0.0 现已在 jsr 和 npm 上提供:

deno add jsr:@fedify/fedifynpm  add     @fedify/fedify

所以,希望以后有更多的服务支持activitypub,我就结束这篇文章了!

以上就是Fedify,一个 ActivityPub 服务器框架,已达到 v0的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1491829.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 14:18:07
下一篇 2025年12月19日 14:18:13

相关推荐

  • 网页标题怎么设置?title标签应该放在哪里?

    网页标题由html中 区域内的标签定义,必须且只能出现在该位置;2. 设置标题需在内插入标签并填入文本,如“我的个人博客”;3. 撰写标题时应包含核心关键词但避免堆砌,控制在50-60字符内,确保独特性与吸引力,并与内容高度相关;4. 未设置或设置不当会导致用户体验差、seo效果差、社交媒体分享效果…

    2025年12月22日
    000
  • meta标签的用途是什么?网页元信息如何设置?

    设置meta标签需在html的 区域添加对应代码;2. 必设标签包括:防止乱码;3. 确保移动端正常显示;4. 提升搜索点击率;5. 控制页面是否被索引;6. 添加ogp标签如og:title、og:image等优化社交分享效果;7. 避免滥用keywords标签,因其已基本被搜索引擎忽略;8. 注…

    2025年12月22日 好文分享
    000
  • JavaScript图算法实现_javascript复杂计算

    图算法在JavaScript中通过邻接表或矩阵表示,适用于社交网络、导航等场景,结合DFS、BFS、Dijkstra等算法可高效处理路径与关系问题。 图算法在JavaScript中能高效处理复杂关系和路径问题,尤其适合社交网络、地图导航、依赖分析等场景。虽然JavaScript不是专为数值计算设计的…

    2025年12月21日
    000
  • JavaScript 的算法中,深度优先搜索与广度优先搜索各有何适用场景?

    DFS适合探索所有路径、连通性及深度较大场景,BFS适合最短路径、层级遍历及目标较近情况,选择依据是问题是否要求最少步数或最短距离。 深度优先搜索(DFS)和广度优先搜索(BFS)是两种基础的图或树遍历算法,在 JavaScript 中常用于解决不同类型的路径、查找与结构问题。它们的核心区别在于搜索…

    2025年12月20日
    000
  • JS 树形结构操作指南 – 深度优先与广度优先遍历算法的应用场景

    DFS和BFS是JavaScript处理树形结构的核心遍历算法,DFS优先深入分支,适用于路径查找、序列化等场景,可用递归或迭代实现;BFS逐层扩展,适合层级渲染、最近节点查找,通常用队列实现;选择依据包括数据结构特征和具体需求,如深度、宽度、内存限制及访问顺序要求。 在JavaScript中处理树…

    2025年12月20日
    000
  • 如何实现自定义的迭代器和可迭代对象,以及这些特性如何简化复杂数据结构的操作?

    自定义迭代器和可迭代对象通过实现__iter__和__next__方法,使数据结构能被for循环遍历,封装复杂逻辑,支持惰性求值、内存优化及多种遍历方式;生成器以更简洁的方式实现相同功能,适用于简单或一次性迭代场景,而类实现更适合需复杂状态管理或多策略遍历的情况。 自定义迭代器和可迭代对象,本质上为…

    2025年12月20日
    300
  • 什么是并查集?并查集的典型应用场景

    并查集通过维护一个森林结构来高效处理集合的合并与查询问题,其核心操作为find和union。find操作用于确定元素所属集合的根节点,并通过路径压缩优化,将查找路径上的所有节点直接连接到根,从而提升后续查询效率;union操作用于合并两个不同集合,通常结合按秩或按大小合并的策略,即将较小树的根连接到…

    2025年12月20日
    000
  • 图的定义是什么?JS如何表示图结构

    图在JavaScript中常用邻接表表示,适合稀疏图和动态操作,邻接矩阵适用于顶点固定且边密集的场景,边列表则用于特定算法;实际应用如社交网络、导航和推荐系统均依赖图结构。 图,简单来说,就是由一些“点”(我们称之为顶点或节点)和连接这些点的“线”(我们称之为边)构成的抽象结构。它最核心的作用是用来…

    2025年12月20日
    000
  • 什么是层序遍历?队列实现层序遍历

    层序遍历之所以重要,是因为它提供了一种广度优先的全局视角,适用于寻找最短路径、按层处理节点等问题,如求树的最小深度或判断完全二叉树;它不仅可用于二叉树,还可推广到图的遍历、网络爬虫、社交网络分析、迷宫求解等场景;与深度优先遍历相比,层序遍历使用队列实现,按层访问,空间复杂度与树的宽度相关,适合解决最…

    2025年12月20日
    000
  • 什么是JS数据结构?数据结构在编程中的作用

    JavaScript数据结构是组织和操作数据的核心方式,直接影响程序性能。除常用的数组和对象外,Set和Map提供去重与灵活键值对存储,队列、栈、链表、树和图等可基于JS实现,适用于不同场景。如Set优化查找去重,链表提升插入删除效率,图处理复杂关系。合理选择结构能显著提升性能,避免卡顿。前端中,D…

    2025年12月20日
    100
  • JS如何实现图的邻接表?图的表示方法

    答案:图的两种主要表示方法是邻接矩阵和邻接表。邻接矩阵使用二维数组存储边,适合稠密图,检查边存在性快(O(1)),但空间占用大(O(V²)),遍历邻居慢(O(V));邻接表使用Map或链表存储每个顶点的邻居,空间效率高(O(V+E)),遍历邻居高效(O(degree(V))),适合稀疏图和图遍历算法…

    2025年12月20日
    000
  • JS如何实现广度优先搜索?BFS的应用

    JS实现广度优先搜索(BFS)的核心在于使用队列逐层遍历图或树,结合visited集合避免重复访问,其典型应用包括无权图最短路径、社交网络连接、Web爬虫和迷宫求解,与DFS相比,BFS适合寻找最短路径和层级遍历,而DFS更适合遍历所有路径或处理深度较深的图,优化BFS的方法包括双向BFS、使用优先…

    2025年12月20日
    100
  • 什么是队列?JS中如何实现队列操作

    队列是一种先进先出(fifo)的数据结构,常用于任务调度、消息队列、bfs算法等场景;在javascript中可通过数组或对象实现,数组实现简单但出队操作性能较差(o(n)),推荐使用对象模拟指针(head和tail)实现o(1)时间复杂度的入队和出队操作;与栈(lifo)和链表(灵活存储结构)相比…

    2025年12月20日
    000
  • JS中如何实现图的遍历?DFS和BFS区别

    图的遍历在JS中通过DFS和BFS实现,DFS使用递归深入搜索,适用于路径存在性问题;BFS利用队列逐层扩展,适合最短路径求解;两者可应用于组件依赖分析、路由管理等前端场景。 JS中实现图的遍历,主要依赖深度优先搜索(DFS)和广度优先搜索(BFS)这两种算法。简单来说,DFS像走迷宫一样,一条路走…

    2025年12月20日
    100
  • javascript如何实现数组图结构

    在javascript中实现数组图结构的关键是选择邻接矩阵或邻接表来表示节点和边,并根据图的特性进行遍历与优化。1. 邻接矩阵使用二维数组表示图,适合稠密图,查找边的时间复杂度为o(1),但空间复杂度为o(n²);2. 邻接表使用对象或数组存储邻接节点,适合稀疏图,空间复杂度为o(n+m),但查找边…

    2025年12月20日 好文分享
    000
  • JS如何实现并查集?并查集的优化

    并查集的时间复杂度经过路径压缩和按秩合并优化后接近o(α(n)),其中α(n)是反阿克曼函数,在实际应用中可视为常数,因此可近似认为是o(1),未优化时最坏情况为o(n);其核心优化方法包括路径压缩和按秩合并;主要应用场景有判断图的连通性、kruskal算法中的环检测、动态连通性维护、图像处理中的区…

    2025年12月20日
    000
  • javascript数组如何实现分形结构

    要实现javascript数组的分形结构,核心是利用递归函数构建嵌套数组以模拟自相似性,1. 通过递归函数createfractalbranch生成多层嵌套数组,每个层级包含分支信息及子分支引用;2. 分形结构在数据可视化中的应用包括树状图、旭日图展示层级数据,网络图布局优化,分形艺术生成设计,以及…

    2025年12月20日
    000
  • 怎样用JavaScript实现图结构?

    用javascript实现图结构可以通过对象或数组表示。1) 创建无向图类,使用对象存储节点和边。2) 实现有向图,只需修改无向图的边添加方法。3) 实际应用中,需注意大规模图的性能优化和循环引用处理。这篇文章详细介绍了如何在javascript中实现无向图和有向图,并分享了在实际项目中使用图结构的…

    2025年12月20日
    000
  • Javascript 没有 LeetCode 的日子

    在上一篇文章中,我开始在 hackerrank 上练习算法,并向男友提起了此事。他建议我试试 leetcode,因为它无需使用 node.js,让我能专注于算法挑战本身。现在我已经在 leetcode 上练习两天了。 背景说明: 本文中关于平台的描述,类似于我在《系统设计》中那样,是将 Twitte…

    2025年12月19日 好文分享
    000
  • MongoDB 设计中的算法概念

    MongoDB 数据库设计中的算法优化策略 本文探讨在 MongoDB 数据库设计中应用几种算法概念以提升性能和可扩展性。这些策略着重于最小化数据库扫描、优化索引使用以及高效处理数据聚合。 1. 滑动窗口技术 滑动窗口技术常用于处理时间序列数据,例如追踪用户参与度趋势。在 MongoDB 中,可以使…

    2025年12月19日
    000

发表回复

登录后才能评论
关注微信