{
  "about" : "Building [planetable.xyz](https://planetable.xyz)",
  "articles" : [
    {
      "articleType" : 0,
      "attachments" : [
        "article-item-view.png",
        "article-settings.png",
        "avatar-picker.png",
        "filter.png",
        "pinned-with-pinnable.png",
        "quick-sharing.png",
        "rebuild-progress.png",
        "site-nav.png",
        "todo-syntax.png",
        "writer-todo-syntax.png",
        "youtube-autolink.png"
      ],
      "cids" : {
        "article-item-view.png" : "QmNs4yvj1P26LhPf51faRoNAd2NV1y5yFyz3p4reprPyEp",
        "article-settings.png" : "QmeJeKpP7Wei2VVWffQVcGJyf4GzKaYk31zs1VKd2Sktr9",
        "avatar-picker.png" : "Qmep4jLy9TMSNEdK12jZFVqowGMvw4ZSQZ6VeGvVsPcC4U",
        "filter.png" : "QmadzUn7HTKzz1Nxhe2jEsZzLHkz7CQZW69mdzc3cZemkW",
        "pinned-with-pinnable.png" : "QmdgbpMYVRJUff8MrLrpQhUYzQiRDdzyXoe9eSHVf2DqaZ",
        "quick-sharing.png" : "QmaW8UTbqn9WWnyJLePSCZXmVnGTedeKYoSKc4skFfN3TU",
        "rebuild-progress.png" : "QmPYVMnW7iQFU1QdA7Ywesa7x4XrE2oYixZUs8iqsRozvp",
        "site-nav.png" : "QmQTxd9YcEmVrH2c5LTtYUB2F8o8NKRy7XSg8EzcGXaoWu",
        "todo-syntax.png" : "QmPmFHXZ8z3Qcxsrb4rDBspcdpRBkKyhYEvmVmAWGZkoTk",
        "writer-todo-syntax.png" : "Qmd5pzmsGvtAfsTgmB6fpsPHcMnkXk5NDWryvFhd7NMgqu",
        "youtube-autolink.png" : "QmQd3FUMLFus9sPUwgghPAtdVkwmixb5HdFbrwWtYokubg"
      },
      "content" : "下载地址：\n\n* <a href=\"https://opensource.planetable.xyz/planet/release-0.14.1/Planet.zip\" target=\"_blank\">Planet 0.14.1</a>\n\n## Article Settings 及新的文章列表视图\n\n增加了一个新的 `Article Settings` 右键菜单。可以用来将一篇博客文章设置为 Page。这对于创建像 About Us 和 Contact Us 之类的站点级别页面会特别有用。\n\n![](article-settings.png)\n\n通过这些新设置，你可以获得类似 [planetable.eth](https://planetable.eth.limo) 顶部这样的网站导航设计。这可以通过指定某些文章作为网站导航栏中的条目来实现。\n\n![](site-nav.png)\n\n通过点击这个新的列表过滤器，你可以按类型过滤文章，更容易地找到特定页面。\n\n![](filter.png)\n\n重新设计过的文章条目视图现在会显示内容类型及附件信息。\n\n<img src=\"article-item-view.png\" width=\"365\" />\n\n## Planet Avatar Picker\n\nPlanet 现在有一个全新的头像选择界面。让你可以从多组充满设计感的图集中选择一张作为你的 Planet 网站的头像。\n\n![](avatar-picker.png)\n\n这次上线的第一个图集，Nostalgia，包含了 99 个简洁而抽象的来自设计师 [yihanphotos.eth](https://yihanphotos.eth.limo) 的作品。\n\n## 快速分享\n\n现在你可以把图片拖拽到 Planet 图标上，就可以快速分享图片。\n\n![](quick-sharing.png)\n\n## Pinnable\n\n[Pinnable](https://pinnable.xyz) 是一个全新的用于 ENS/IPNS 网站的 Pinning 服务。\n\n<img src=\"pinned-with-pinnable.png\" width=\"275\" />\n\n当你使用 Planet app 创建和发布去中心化网站时，你的 Mac 会成为 P2P 网络上的一个节点，用于托管你的网站。通过使用一个 Pinning 服务，你的网站内容的额外副本会被复制到 Pinning 服务的节点上，这样可以让网站的加载速度更快，同时也增加了内容的可达性（availability）。尤其是对于笔记本用户，就不用让电脑一直开着作为服务器。每次当你发布新内容时，Pinnable 就会开始与你的本地节点进行同步，同步完成之后，你的内容就也存了一份到 Pinnable，这样你就不用一直开着自己的机器作为服务器了。\n\n虽然使用了一个远程服务，你对内容的权威版本依然具有完全的控制。远程服务无法篡改或者删除你的内容。\n\n## To-Do 列表语法\n\n![](writer-todo-syntax.png)\n\nPlanet 的 Markdown 编辑器现在也可以支持类似 GitHub 的 To-Do 语法。并且在 My Planet 的右侧视图中，可以直接点击 To-Do 列表中的项目来勾上已经完成的事项。\n\n![](todo-syntax.png)\n\n## YouTube 嵌入\n\n如果你在正文中包括了一个 YouTube 的视频链接，那么现在链接会自动转化为一个播放器。\n\n![](youtube-autolink.png)\n\n## 其他改进\n\n- 支持用拖拽的方式调整左侧列表中 My Planet 和 Following Planet 的顺序\n- 在 Rebuild Planet 时现在会显示一个进度条\n\n<figure>\n<img src=\"rebuild-progress.png\">\n<figcaption>Rebuild Planet 时的进度条</figcaption>\n</figure>\n\n- 修复了移动文章时的一个问题\n- 修复了当 App 长时间运行时可能会发生的一个崩溃问题\n- 模版现在可以有自己的设置，这为更复杂的定制模版功能打开了可能性\n- 增强了 Markdown Writer 在滚动时的性能\n- Markdown Writer 的时间选择器现在可以选择「今天」\n",
      "created" : 713242857.58499706,
      "externalLink" : "",
      "hasAudio" : false,
      "hasVideo" : false,
      "heroImage" : "https://olivida.eth.limo/6A9EE20E-55FF-4E89-8EEE-F0AA4717114D/article-settings.png",
      "id" : "6A9EE20E-55FF-4E89-8EEE-F0AA4717114D",
      "link" : "/6A9EE20E-55FF-4E89-8EEE-F0AA4717114D/",
      "slug" : "",
      "title" : "Planet Feature Update 8"
    },
    {
      "articleType" : 0,
      "attachments" : [
        "writer-date-picker.png",
        "insider-and-debug.png",
        "stars.png",
        "planet-api-server.png",
        "social.png",
        "juicebox.png"
      ],
      "cids" : {
        "insider-and-debug.png" : "Qmccmyjnv1VyWwbF5BkMvYo487SaAMjVGPotZZBNXKzvWB",
        "juicebox.png" : "QmfJaNySxSkhnZijiMNWwBAWuD5F6eo6zPHmfYZ4y9bE8W",
        "planet-api-server.png" : "QmYcQf8Kvcd77LpQPUbqrt4N8WsHFFcUH17nT72AjXHXdo",
        "social.png" : "QmSpKiJ4biy62eKgtSMnKprv65HFP2VWJcVrxcGaadrz9G",
        "stars.png" : "QmeLAGT8f2MFohmparJ9rNCfYR7W6Mgfv2ESdWcKXoA3bT",
        "writer-date-picker.png" : "QmeGG3cLaemKMKWReGnUYv5jhV4QYDZzLNyGo3Xg54dnQT"
      },
      "content" : "这次的更新包括了新的星标类型，Planet 的 API 服务器，对移动主数据目录的支持，IPNS 私钥管理器，支持更多的社交网络连接，Insider 和 Debug 版本的新图标，及 bug 修复和功能改进。\n\n## 星标类型\n\n现在当你在给一篇文章添加星标时，你可以选择几种新的类型，来为星标赋予一个更明确的含义。其中几种类型会让 Planet 具有 To-Do 管理软件的感觉。除了右键点击，现在还可以从工具栏中来管理文章的星标。\n\n<img width=\"484\" alt=\"Stars\" src=\"stars.png\">\n\n在后续的更新中，我们将会支持更具星标类型过滤文章。\n\n## 文章的日期选择器\n\n当你在编辑文章时，可以为文章选择任意日期。无论是过去还是将来。\n\n<img width=\"1002\" alt=\"Writer Date Picker\" src=\"writer-date-picker.png\">\n\n## API 服务器\n\n在 Planet 应用运行的时候，现在可以提供一个 HTTP API 服务器。下面是目前能支持的请求的列表，我们会通过文档提供更具体的使用信息。这是一个 v0 版本的 API，因此在后续的更新中有可能会更改。API 服务器为第三方客户端提供了可能性，尤其是后续对移动设备的支持。\n\n* `GET /v0/planets/my` - List all my Planets\n* `POST /v0/planets/my` - Create a new Planet\n* `GET /v0/planets/my/:uuid` - Info of a specific My Planet\n* `POST /v0/planets/my/:uuid` - Modify my Planet\n* `POST /v0/planets/my/:uuid/publish` - Publish My Planet\n* `GET /v0/planets/my/:uuid/public` - Expose the content built\n* `GET /v0/planets/my/:uuid/articles` - List articles under My Planet\n* `POST /v0/planets/my/:uuid/articles` - Create a new Article\n* `GET /v0/planets/my/:uuid/articles/:uuid` - Get an article by UUID\n* `POST /v0/planets/my/:uuid/articles/:uuid` - Modify an article\n* `DELETE /v0/planets/my/:uuid/articles/:uuid` - Delete an article\n\n<img width=\"501\" alt=\"Planet API Server\" src=\"planet-api-server.png\">\n\n你可以在应用的设置中打开 API 服务器，并设置端口号、用户名及密码。\n\n## 移动主数据目录及 IPNS 私钥管理器\n\n**这还是一个试验性的功能，在使用时请注意数据备份**\n\nPlanet 应用在默认情况下，所有的数据存放在这个位置：\n\n```\n~/Library/Containers/xyz.planetable.Planet/Data/Documents/Planet\n```\n\n现在在应用设置中，你可以移动这个位置。如果新位置位于 iCloud Drive 或者 Dropbox，那么相当于你就通过云服务备份了数据。\n\n于此同时，本地的所有 IPNS 私钥，现在可以通过一个新的 Key Manager 来管理及通过 iCloud Keychain 备份，如果你在 iCloud 设置中打开了 iCloud Keychain 功能的话。你可以在 Tools 菜单下找到新的 Key Manager。\n\n对于所有数据同步的支持还在测试中。上面提到的移动主目录功能，及新的 Key Manager 功能，为数据在几台 Mac 之间的完全同步提供了可能性。但是目前还有一些边缘情况，需要更多的测试及代码上的处理。因此我们任务这个功能目前还处在一个试验性的阶段。在使用时需要小心。如果你需要任何帮助，欢迎加入我们的 nftychat 社区的 Planet 频道询问：\n\nhttps://nftychat.xyz/community/e767e0b\n\n## 更多的社交网络连接支持\n\n现在你可以为你的 Planet 填入这些社交网络的 ID，之后会显示在生成的网站首页，及其他人追随你的 Planet 时看到的信息面板里。\n\n- Juicebox\n- Mastodon\n- Twitter\n- Telegram\n- GitHub\n\n<img width=\"570\" alt=\"Juicebox\" src=\"juicebox.png\">\n\n<img width=\"551\" alt=\"Social\" src=\"social.png\">\n\n## Insider 和 Debug 版本的新图标\n\n我们会时不时发布 Insider 版本。Insider 版本中包括了最新的功能。这些功能通常在进入稳定版本之前，需要更多的测试。因此我们通过 Insider 版本来让新功能在发布之前能够获得更充分的测试。你可以从 Planet 项目的 GitHub Releases 页面下载最新的 Insider 版本。\n\nhttps://github.com/Planetable/Planet/releases\n\n如果你下载并运行了 Insider 版本，那么你会注意到这个版本现在具有一个独特的蓝色图标，具有类似 Xcode 及其他 Apple 开发工具的风格。同时我们也为 Insider 版本添加了专有的升级通道，因此现在 Insider 版本也可以获得自动升级。\n\n如果你是从源代码构建 Planet，那么你就可以获得这款黄色的具有建设中意味的图标。\n\n<img width=\"1200\" alt=\"Icons: Insider and Debug\" src=\"insider-and-debug.png\" style=\"border-radius: 8px\">\n\n在后续的更新中，我们会提供更多的图标选项。比如最近在 [Pinnable](https://pinnable.xyz) 项目中出现的[新设计](https://juicebox.money/v2/p/471)。\n\n## 其他细节改进\n\n* 在默认模版中为表格和 To-Do 列表增加了 CSS 样式\n* 为 HTML 中的社交网络分享图片使用了更兼容的绝对 URL 地址\n* 修复了一个在添加视频时的崩溃问题\n* 修复了之前版本中音频播放器按钮不响应的问题\n* 为工具栏中的 ETH 打赏功能换上了一个由 SF Symbol 驱动的图标\n* 默认的 Plain 主题中的样式微调，带来整体更好的对比度\n* 侧栏中的 Planet 图标增加了边框和投影以实现更好的对比度效果\n* 模版中现在可以使用一个新的变量用于引用社交网络分享大图 `social_image_url`",
      "created" : 701182640.08557105,
      "externalLink" : "",
      "hasAudio" : false,
      "hasVideo" : false,
      "heroImage" : "https://olivida.eth.limo/4D909465-3321-4710-8AEA-10A42B87B484/insider-and-debug.png",
      "id" : "4D909465-3321-4710-8AEA-10A42B87B484",
      "link" : "/4D909465-3321-4710-8AEA-10A42B87B484/",
      "slug" : "",
      "title" : "Planet Feature Update 7"
    },
    {
      "articleType" : 0,
      "attachments" : [

      ],
      "cids" : {

      },
      "content" : "[枫言枫语](https://justinyan.me/post/4904)是一档由开发者 [@枫影JustinYan](https://justinyan.me/) 和设计师 [@自力hzlzh](https://twitter.com/hzlzh) 主持的播客节目，主题是听见科技与人文的声音。\n\n在 Planet 项目上线前，我有幸参加了节目的<a href=\"https://justinyan.me/post/4904\" target=\"_blank\">第 67 期</a>，聊了聊关于 Planet 项目的构想。\n\n最近 Justin 在 2023 年新年期间做了一个大动作：他写了一个转换程序，将他的整个 WordPress 驱动的博客的内容转换到了 Planet 的格式，其中也包括了枫言枫语播客的所有音频内容，并绑定到了他的 ENS 上：\n\n<a href=\"https://justinyan.eth.limo\" target=\"_blank\">justinyan.eth</a>\n\n大家可以直接打开那个地址（借助于伟大的 [ETH.LIMO 项目](https://olivida.eth.limo/4B412A73-9C15-4E62-BFC6-157E2D28D0C1/)），或者在 Planet 里订阅 justinyan.eth 这个地址。\n\n因为其中包括了 81 期的音频内容，所以你可以在任何泛用型 Podcast 客户端，如 Apple Podcasts / Overcast / Castro / Pocket Casts 里，订阅下面这个地址：\n\n<a href=\"https://justinyan.eth.limo/podcast.xml\" target=\"_blank\">https://justinyan.eth.limo/podcast.xml</a>\n\nJustin 的内容丰富的博客为 Planet 下一步的很多功能需求的开发，提供了实实在在的场景，我们会继续将发现的很多缺失补齐。\n\n灵感闪现的时刻在每次淋浴的时候都能体会到，但是把灵感转换为行动，并且以年为单位坚持下去，就是另外一回事了。枫言枫语到目前已是第 81 期，内容和制作都在持续变得越来越精良，并且在这个过程中，他们还推出了像 [中文播客榜](https://xyzrank.com/) 这样有意思的新项目。\n\n在第 81 期节目中，他们提到了一些关于钱的数字（[第 81 期节目的 42:32 开始：本台年度财政赤字大起底](https://www.xiaoyuzhoufm.com/episode/63b4f6ba92f7bae63bec1566)）：在 2021 年为节目投入了大概 7500 人民币。在 2023 年，预算是 10000。因为目前并没有任何商业化，所以两位主播确实是在一个用爱发电的状态。如果你在 Planet 里 follow 了他们，可以试试用新的 [WalletConnect 钱包打赏功能](https://olivida.eth.limo/77A35810-46AC-49F7-8904-8FCDDB41E00E/)来支持一下，所有打赏金额会 100% 直接发送到 justinyan.eth。",
      "created" : 694595973.14991999,
      "externalLink" : "",
      "hasAudio" : false,
      "hasVideo" : false,
      "id" : "460BEFAC-6A31-4561-A97D-EB5F11166B93",
      "link" : "/460BEFAC-6A31-4561-A97D-EB5F11166B93/",
      "slug" : "",
      "title" : "枫言枫语"
    },
    {
      "articleType" : 0,
      "attachments" : [
        "yihanphotos.eth.png",
        "template-browser-ui.png",
        "published-folders-dashboard.png"
      ],
      "cids" : {
        "published-folders-dashboard.png" : "QmfUenC6JueZvSz7yAbRsbmZVZQ2g12SQm3vJU5Tmgezpc",
        "template-browser-ui.png" : "QmeJjcMqhw36qwruTp82bfKxDDAQwwNB7jF53WYAx57yq1",
        "yihanphotos.eth.png" : "Qmc4zqk1a2PZtZYBDz3P9hKkuEsFjrTPMJkd1ykMiApRoQ"
      },
      "content" : "这是 2022 年的最后一天。在我们发布这个功能更新时，有些时区已经迈入 2023 年了。新年快乐！感谢大家在这一年对 [Planet](https://planetable.xyz) 的关注和支持。\n\n在 Feature Update 6 中的一个主要更新，是一个全新的页面主题——**Grid**。你可以在下面这个地址看到效果：\n\n<a href=\"https://yihanphotos.eth.limo\" target=\"_blank\">yihanphotos.eth</a>\n\n<img width=\"959\" alt=\"yihanphotos.eth\" src=\"yihanphotos.eth.png\">\n\n这是一个为大量的图片和视频所优化的设计。针对 Desktop 和 Mobile 都做了响应式的设计。为了支持这个新的主题，软件本身需要提供一系列数据层面的更新：\n\n### 视频第一帧存为图片文件\n\n视频的第一帧会被保存为一个叫做 _videoThumbnail.png 的图片文件。例如这个红冠亚马逊鹦鹉的视频：\n\n* https://yihanphotos.eth.limo/665137A4-A9D7-4D7C-92ED-56DA3B3FFF75/\n\n第一帧的图片文件地址：\n\n* https://yihanphotos.eth.limo/665137A4-A9D7-4D7C-92ED-56DA3B3FFF75/_videoThumbnail.png\n\n### Hero Image\n\n如果文章附件中包括了一张足够宽的图片，那么这张图片的名字会可以在模版中以 `heroImage` 这个变量获得。这会为模版设计带来很多新的可能性。\n\n同时，这个文件会被额外转换成两个适合在方格布局中使用的版本：_grid.jpg 和 _grid.png。如果附件中包括视频，那么视频的第一帧图片会成为 Hero Image。并且生成两个方格版本，比如：\n\n* https://yihanphotos.eth.limo/665137A4-A9D7-4D7C-92ED-56DA3B3FFF75/_grid.jpg\n* https://yihanphotos.eth.limo/665137A4-A9D7-4D7C-92ED-56DA3B3FFF75/_grid.png\n\n这类由 Planet 在渲染时额外生成的图片文件，名称都会是 _ 下划线开头。\n\n---\n\n以上是关于新模版的介绍。在后续的更新中，我们会继续带来模版设计方面的更新。传统的博客系统如 WordPress、Jekyll、Ghost 等，在十多年的积累过程中，积攒了大量经过考验的信息组织方式方面的设计，而这些都是 Planet，从一个静态网站生成器的角度出发，需要接下来全部补齐的。\n\n---\n\n## Published Folders Dashboard\n\nPublished Folder 是 Planet 在 2022 年 10 月的功能更新加入的新功能——可以把任意的本地文件夹，发布为 IPNS。\n\n可以把这个功能理解为一个完全图形化界面操作的 IPFS 发布，尤其适合把各种静态网站生成器的 build 结果发布。比如 Jekyll。\n\n之前这个功能的入口是在 Tools 菜单下。现在你可以在 Tools -> Published Folders -> Dashboard 找到这个新的图形界面管理入口。\n\n<img width=\"1035\" alt=\"Published Folders Dashboard\" src=\"published-folders-dashboard.png\">\n\n## New Template Browser\n\n模版管理工具 Template Browser 现在具有一个三栏式的布局可以用于呈现更多信息。并且可以预览模版的首页列表的设计。\n\n<img width=\"948\" alt=\"Template Browser UI\" src=\"template-browser-ui.png\">",
      "created" : 694226018.48311806,
      "externalLink" : "",
      "hasAudio" : false,
      "hasVideo" : false,
      "heroImage" : "https://olivida.eth.limo/15AEA9DA-2CD6-4FF6-969A-7899586056CA/yihanphotos.eth.png",
      "id" : "15AEA9DA-2CD6-4FF6-969A-7899586056CA",
      "link" : "/15AEA9DA-2CD6-4FF6-969A-7899586056CA/",
      "slug" : "",
      "title" : "Planet Feature Update 6"
    },
    {
      "articleType" : 0,
      "attachments" : [
        "WalletConnect.mp4"
      ],
      "cids" : {
        "WalletConnect.mp4" : "QmPpH9ABf3CpB9kCaVPZNsCdab6Wvk39vaZMy2KwEKsArq"
      },
      "content" : "Planet 在最近的 [0.11](https://olivida.eth.limo/D7AC0F34-7C35-4850-8650-3B26979F93B8/) 版本的更新中，加入了通过 WalletConnect 实现的 Ethereum 钱包打赏。你可以给喜欢的 ENS 域名上的内容直接打赏以太币，作者会 100% 收到你的打赏。\n\n这里是一个视频演示。\n\n[WalletConnect](https://walletconnect.com) 是一个被众多手机钱包支持的通讯协议。可以通过安全简单的方式让像 Planet 这样的原生应用，对手机上的钱包发起签名和交易请求，然后用户在手机上确认（通常还会经过指纹或者扫脸解锁）。\n\n目前 Planet 的打赏功能是通过 WalletConnect V1 实现的，可能是世界上第一个通过 WalletConnect 实现钱包登录的 macOS 原生应用。同时，我们在密切关注各个钱包 App 对 WalletConnect V2 的支持进展，会在后续跟进升级协议。",
      "created" : 692598444.66932297,
      "externalLink" : "",
      "hasAudio" : false,
      "hasVideo" : true,
      "heroImage" : "https://olivida.eth.limo/77A35810-46AC-49F7-8904-8FCDDB41E00E/_videoThumbnail.png",
      "id" : "77A35810-46AC-49F7-8904-8FCDDB41E00E",
      "link" : "/77A35810-46AC-49F7-8904-8FCDDB41E00E/",
      "slug" : "",
      "title" : "WalletConnect 视频演示",
      "videoFilename" : "WalletConnect.mp4"
    },
    {
      "articleType" : 0,
      "attachments" : [
        "sending.png",
        "tip-tiers.png",
        "transaction-history.png",
        "qr-code-example.png",
        "automatically-publish.png",
        "tip-button.png",
        "move-article.png",
        "show-ipns-and-cid.png",
        "connect-wallet.png"
      ],
      "cids" : {
        "automatically-publish.png" : "QmZzrsQTzpWQEXqZQUAb2F1DZhsC9ibAgi7XdUPFCNrYHc",
        "connect-wallet.png" : "QmesfygFJrF8fdFSbECNMA2jK5MbffgSTLFT1vJREJRTKa",
        "move-article.png" : "Qmc9CXjFu5ivtZnX3Nf5DJSWbCsh7Rc3eT7DMkX8ewapu3",
        "qr-code-example.png" : "QmdUWJCsvWx6BeJzDb1Lm5Tp1aJ178wfGZaxbdDfApwkb9",
        "sending.png" : "QmSEZwJnHYzb6Z7ULT5fdgYAWPo7iNr2QdgaAAz3mvgzKR",
        "show-ipns-and-cid.png" : "QmXGtUUZ5oVxaBN4X7LLy9CszBEipWG83pWY8u6aUaBpj6",
        "tip-button.png" : "QmcPLZCWdQTFbLpAEgMHAFW98QMuUiL6sxqdCgZWkBjqTT",
        "tip-tiers.png" : "Qmf3Q2skqbcmiqwpBzFtoSNzqwuquAk5NeMszNnVXkQjhj",
        "transaction-history.png" : "QmZmVjFRFKEPxPCm1UVkUQDLmhXzoHyqB1hv9kvJREuBLo"
      },
      "content" : "这次的功能更新会是首先以 Insider Build 的方式发布，需要从下面的这个 GitHub 链接去下载。因为其中的一些大的变更，在通过自动更新推送给所有用户之前，我们希望能够更充分地测试一下。\n\n* https://github.com/Planetable/Planet/releases/tag/insider-20221202-1\n\n因为这次会有一个主要的新功能——通过 ETH 直接给内容创作者打赏。具体的使用方式是这样的：\n\n## ETH Tipping\n\n在 0.11 版本的 Planet 中，可以在菜单 Planet 下找到一个新的选项——Connect Wallet。\n\n<img width=\"495\" alt=\"Connect Wallet\" src=\"connect-wallet.png\">\n\n然后用支持 WalletConnect 的钱包应用扫描弹出的二维码，然后 Planet 应用里就可以知道你的钱包地址及向应用发起交易请求。在这个阶段，不会有签名操作。\n\n<img width=\"1140\" alt=\"Planet WalletConnect QR Code Example\" src=\"qr-code-example.png\">\n\n之后当你在 Planet 里访问 .eth 域名上的网站时，在 Toolbar 里会出现这个新的打赏按钮。如果在你 Follow 的 .eth 网站的 Toolbar 里没有出现这个按钮，那么请右键在 Planet 名称上点击 Check for update 解析 ENS 后面对应的钱包地址。并且，这个打赏按钮只会在连接了钱包之后才会出现。\n\n<img width=\"648\" alt=\"Tip Button\" src=\"tip-button.png\">\n\n按下之后就可以选择打赏金额——从 0.02E 到 1E 的几个不同的级别。如果你使用的是 MetaMask 的手机版本，那么这里还可以选择使用哪个网络发送，目前支持主网、测试网 Goerli 和测试网 Sepolia。\n\n<img width=\"1140\" alt=\"Tip Tiers\" src=\"tip-tiers.png\">\n\n点击 Send 之后，这时手机上的钱包应用就会弹出一个转账确认。按下确认之后，打赏就发送到目标地址了。这是一笔简单的两个 ETH 地址之间的转账，你选择的打赏金额会 100% 进入内容创作者的钱包。\n\n<img width=\"1140\" alt=\"Sending 0.02 ETH to vitalik.eth\" src=\"sending.png\">\n\n如果你在连接钱包的时候使用的应用是 [Rainbow](https://rainbow.me)，那么需要注意的是 Rainbow 会在连接界面的右下角让你选择网络。如果你希望连接的是测试网 Goerli，那么需要在这里选择。如果你没有看到 Goerli 的选项，那么需要在 Rainbow 的设置中打开对 Testnet 的支持。之后在发送交易时，Rainbow 不支持交易时切换网络，会永远使用一开始的选择。\n\n点击主界面左上方的钱包地址按钮，就可以看到所有过去发出的打赏记录：\n\n<img width=\"1140\" alt=\"ETH Transaction History\" src=\"transaction-history.png\">\n\n[MetaMask](https://apps.apple.com/us/app/metamask-blockchain-wallet/id1438144202) 和 [Rainbow](https://apps.apple.com/us/app/rainbow-ethereum-wallet/id1457119021) 是我们在开发这个功能的过程中，主要测试过的两个应用。如果你使用的是其他支持 WalletConnect 的应用，可以在 GitHub 的 [Discussions](https://github.com/Planetable/Planet/discussions) 里告知我们，我们来试着进行更多的测试。目前，我们推荐使用的手机钱包 App 是 MetaMask 和 Rainbow。\n\n* MetaMask for iOS: https://apps.apple.com/us/app/metamask-blockchain-wallet/id1438144202\n* Rainbow for iOS: https://apps.apple.com/us/app/rainbow-ethereum-wallet/id1457119021\n \n---\n\n上面是 0.11 版本中新增的 ETH 打赏功能的介绍。\n\n下面是本次更新中带来的其他功能和修复。\n\n## Published Folder 的自动发布\n\nPublished Folder 是我们在上一个版本中加入的新功能——你可以把任意的本地文件夹发布为一个 IPNS。如果你之前已经在使用某个静态网站生成器，那么这个功能可以帮助你快速把构建结果发布为 IPNS。\n\n<img width=\"1039\" alt=\"Automatically Publish\" src=\"automatically-publish.png\">\n\n新增加的 <code>Automatically Publish</code> 开关可以自动监测文件夹内的内容变化，然后在每次变化发生时，将最新的 CID 写入 IPNS 实现内容的自动更新。\n\n## 在不同的 Planet 之间移动文章\n\n现在如果你右键点击文章，就可以找到一个新的选项让你可以在 Planet 之间移动文章。\n\n<img width=\"1097\" alt=\"Move Article\" src=\"move-article.png\">\n\n比如你可以指定一个 Planet 来作为你的草稿箱，在里面写作和调整文章的样式，然后在完全满意之后，再把这篇文章移动到需要正式发布的那个 Planet。比如你现在看到的这篇文章，就是用这样的流程完成的。\n\n## Archive/Unarchive\n\n现在你可以把自己创建的或者正在追踪的 Planet 设置为 Archive 状态。Archive 状态的 Planet 不会显示在侧栏中，也不会被自动发布或者更新，但是所有的数据会在本地保留。\n\n之后如果你想找回，可以从 Planet 的设置面板中 Unarchive。\n\n## 用于显示 Planet 的 IPNS 和 CID 信息的新面板\n\n如果你需要获得一个 Planet 的 IPNS 或者最新的 CID，那么现在可以右键单击，然后找到一个新的菜单选项 Show IPNS and CID 就可以看到。\n\n<img width=\"1140\" alt=\"Show IPNS and CID\" src=\"show-ipns-and-cid.png\">\n\n---\n\n感谢大家对这个项目的持续支持。这次的新功能——ETH 打赏希望大家能够帮忙多多测试。如果需要获得 GoerliETH 测试网上的 ETH 来体验这个功能，可以通过下面这个网站挖一些试试：\n\n* [Goerli PoW Faucet](https://goerli-faucet.pk910.de/)\n\n如果你在使用中遇到问题，可以从以下社区渠道向开发者反馈或者寻求社区协助：\n\n* Telegram 上的 [Planet 中文用户群](https://t.me/+5bl7FIsxeChlOWIz)\n\n如果你十分确定遇到了软件实现上的 bug，那么可以通过 GitHub Issues 向我们描述如何复现 bug，我们会尽快调查和解决。\n\n* GitHub 上的 [Planet 项目](https://github.com/Planetable/Planet)",
      "created" : 691552952.44018805,
      "externalLink" : "",
      "hasAudio" : false,
      "hasVideo" : false,
      "heroImage" : "https://olivida.eth.limo/D7AC0F34-7C35-4850-8650-3B26979F93B8/sending.png",
      "id" : "D7AC0F34-7C35-4850-8650-3B26979F93B8",
      "link" : "/D7AC0F34-7C35-4850-8650-3B26979F93B8/",
      "slug" : "",
      "title" : "Planet Feature Update 5"
    },
    {
      "articleType" : 0,
      "attachments" : [
        "pubsub.png"
      ],
      "cids" : {
        "pubsub.png" : "QmUro4v4SUGURWyCttewJoYfSgLtuKEmnTtyJ6vUG5eKy4"
      },
      "content" : "[PubSub](https://github.com/ipfs/kubo/blob/master/docs/experimental-features.md#ipfs-pubsub) 是 IPFS 中的一项实验性的功能，默认没有在 kubo 发布版本中打开。它的具体工作方式是这样的：\n\n- 节点 A 向一个名称为 X 的 channel 发布消息\n- 如果节点 B 和 A 互相是 peers，并且节点 B 正在监听同样名称的 channel，那么就可以实时收到这条消息\n\n在 Planet 搭载的 kubo 中，打开了这个功能，因为它可以实现更快的 IPNS 信息更新。这也是 kubo 的另外一个实验性的功能：[通过 PubSub 更新 IPNS](https://github.com/ipfs/kubo/blob/master/docs/experimental-features.md#ipns-pubsub)。\n\n于是，基于 PubSub，有可能可以实现一些很有趣的互动玩法。\n\n## 对文章的点赞和评论\n\n目前 Planet 的信息发布和传播模式，是一种类似广播的单向模式：写文章的人可以把自己的作品向外传递出去，通过 IPNS 或者 ENS，但是无法收到来自读者的反馈，比如评论和点赞之类的互动是不存在的。\n\n如果，Planet 里增加一个基于 PubSub 的互动玩法，就可以这样实现：\n\n- Planet app 监听所有本地 IPNS 同名的 channel\n- 读者可以向这些 channel 发送点赞或者评论\n- 如果监听方收到这些点赞和评论，就存入本地的 `comments.json` 和 `likes.json` 这样的文件，然后定时重新渲染网站发布。\n\n这样的话，就在一个完全去中心化的环境里，实现了点赞和评论。\n\n## 话题投稿、公共空间、话题广场\n\nPubSub channel 的另外一种用法，可以被当作一个公共容器。\n\n比如你写了一篇关于 Ethereum 这个标签的文章，那么就可以把文章的 IPNS + UUID 作为一条消息发送到一个叫做 `planet:tags:ethereum` 的 channel。\n\n另外一端，如果有程序持续在监听这个 channel，就可以把所有收到的 URL 保存及抓取，然后生成一个专门关于这个 tag 的网站。\n\n整个发送、接收、展示的步骤，都是自组织、无需许可的。\n\n## 一些可能的问题\n\nPubSub 机制要能完全按照期待的那样正常工作，需要满足两个稍微有些苛刻的条件：\n\n- 发送方和接收方需要同时在线。因为中间并没有任何暂存机制，而是一种广播机制，所以如果消息发送的时候，接收方没有在线。那么稍后接收方在线的时候，并不能看到之前的消息。一种解决方式是发送方重复发送很多次，把去重（deduplication）这个问题交给接收方去处理。\n- 发送方和接收方需要是彼此的 peers。这个问题在 WAN 复杂的网络条件下，究竟会如何影响 PubSub 功能的使用体验，及能对此做什么优化，我还需要通过代码尝试更多的实际情况才能知道。",
      "created" : 689581861.89391506,
      "externalLink" : "",
      "hasAudio" : false,
      "hasVideo" : false,
      "heroImage" : "https://olivida.eth.limo/23F37D68-92CE-4626-9F8F-BB8C642265C3/pubsub.png",
      "id" : "23F37D68-92CE-4626-9F8F-BB8C642265C3",
      "link" : "/23F37D68-92CE-4626-9F8F-BB8C642265C3/",
      "slug" : "",
      "title" : "关于用 PubSub 来实现互动内容的一些构想"
    },
    {
      "articleType" : 0,
      "attachments" : [

      ],
      "cids" : {

      },
      "content" : "[原始链接](https://twitter.com/elonmusk/status/1585619322239561728)是 Twitter 的 3 张图片，下面是用 Safari 的图片转文字功能获得的文本。\n\n---\n\nI wanted to reach out personally to share my motivation in acquiring Twitter. There has been much speculation about why I bought Twitter and what I think about advertising. Most of it has been wrong.\n\nThe reason I acquired Twitter is because it is important to the future of civilization to have a common digital town square, where a wide range of beliefs can be debated in a healthy manner, without resorting to violence. There is currently great danger that social media will splinter into far right wing and far left wing echo chambers that generate more hate and divide our society.\n\nIn the relentless pursuit of clicks, much of traditional media has fueled and catered to those polarized extremes, as they believe that is what brings in the money, but, in doing so, the opportunity for dialogue is lost.\n\nThat is why I bought Twitter. I didn't do it because it would be easy. I didn't do it to make more money. I did it to try to help humanity, whom I love. And I do so with humility, recognizing that failure in pursuing this goal, despite our best efforts, is a very real possibility.\n\nThat said, Twitter obviously cannot become a free-for-all hellscape, where anything can be said with no consequences! In addition to adhering to the laws of the land, our platform must be warm and welcoming to all, where you can choose your desired experience according to your preferences, just as you can choose, for example, to see movies or play video games ranging from all ages to mature.\n\nI also very much believe that advertising, when done right, can delight, entertain and inform you; it can show you a service or product or medical treatment that you never knew existed, but is right for you. For this to be true, it is essential to show Twitter users advertising that is as relevant as possible to their needs. Low relevancy ads are spam, but highly relevant ads are actually content!\n\nFundamentally, Twitter aspires to be the most respected advertising platform in the world that strengthens your brand and grows your enterprise. To everyone who has partnered with us, I thank you. Let us build something extraordinary together.\n\n---\n\nDeepL 的中文翻译：\n\n---\n\n我想以个人名义来分享我收购 Twitter 的动机。关于我为什么收购 Twitter 以及我对广告的看法，已经有很多猜测。其中大部分都是错误的。\n\n我收购推特的原因是，拥有一个共同的数字城市广场对人类文明的未来非常重要，在这里可以以健康的方式对各种信仰进行辩论，而不诉诸暴力。目前有一个很大的危险，就是社交媒体会分裂成极右翼和极左翼的回音室，产生更多的仇恨，分裂我们的社会。\n\n在对点击率的不懈追求中，许多传统媒体已经助长并迎合了这些极化的极端主义，因为他们认为这就是带来金钱的原因，但是，在这样做时，失去了对话的机会。\n\n这就是我购买 Twitter 的原因。我这样做并不是因为这很容易。我这样做不是为了赚更多的钱。我这样做是为了试图帮助我所爱的人类。我是带着谦卑的态度这样做的，因为我认识到，尽管我们做出了最大的努力，但在追求这一目标的过程中，失败是一种非常现实的可能性。\n\n也就是说，推特显然不能成为一个自由放纵的地狱，在那里可以说任何话而不承担任何后果！。除了遵守国家法律之外，我们的平台必须对所有人都是温暖的，你可以根据你的喜好选择你想要的体验，就像你可以选择，比如说，看电影或玩视频游戏，从所有年龄段到成熟。\n\n我也非常相信，广告，如果做得好的话，可以让你高兴、娱乐和知情；它可以向你展示一个你从来不知道存在的服务或产品或医疗，但却适合你。要做到这一点，向Twitter用户展示尽可能与他们的需求相关的广告是至关重要的。低相关性的广告是垃圾邮件，但高度相关的广告实际上是内容！。\n\n从根本上说，Twitter 渴望成为世界上最受尊重的广告平台，加强你的品牌，发展你的企业。对每一个与我们合作的人，我都感谢你们。让我们一起打造非凡的东西。\n\n---\n\n2022 年 10 月 27 日",
      "created" : 688603522.13245201,
      "externalLink" : "",
      "hasAudio" : false,
      "hasVideo" : false,
      "id" : "B740813B-7F72-4CEC-989C-DC845EE4DCF5",
      "link" : "/B740813B-7F72-4CEC-989C-DC845EE4DCF5/",
      "slug" : "",
      "title" : "Elon Musk 在完成收购 Twitter 之后写给 Advertisers 的公开信"
    },
    {
      "articleType" : 0,
      "attachments" : [
        "podcast-settings.png",
        "custom-code-sheet.png",
        "custom-code.png",
        "published-folders.png",
        "filebase-pinned.png"
      ],
      "cids" : {
        "custom-code-sheet.png" : "QmXF36Ev4JT1rcWhdGvDfsJuUgeErVkL7E5L4eotCSZ9tR",
        "custom-code.png" : "QmPpo4YyivbgrC8pZcHavd8aCGqKpWGo7nwXQzF1HSLzga",
        "filebase-pinned.png" : "QmRPsTorikdrzWat2D1MLrB269Kz6qyjnFYV9Zt8pCeX6m",
        "podcast-settings.png" : "QmQqRtg5KsZmLGQFWxzghmBvE4ekTw3zK3P4nrCPtw6ftR",
        "published-folders.png" : "QmeRsDVt7NpwBY3kJonoS3bfLgwS9JLmN4mL5fcXPrViSd"
      },
      "content" : "欢迎来到 Planet 在 2022 年 10 月 12 日发布的 Feature Update 4。在这次的功能更新中，我们为你带来了 4 个大的主要功能，及其他细节问题上的修复。\n\n下面的链接是从 0.9.2 到 0.10.0 版本之间的所有改动的更新日志：\n\n[https://github.com/Planetable/Planet/compare/release-0.9.2...release-0.10.0](https://github.com/Planetable/Planet/compare/release-0.9.2...release-0.10.0)\n\n## 发布本地目录到 IPNS\n\n现在你可以在 Planet 把本地的任意目录发布为一个 IPNS。这个功能可以在菜单 Tools -> Published Folders 找到。\n\n<img width=\"612\" alt=\"published-folders\" src=\"published-folders.png\">\n\n这样的话，意味着可以用 Planet 发布其他静态网站生成器的构建结果，比如用 Jekyll、Hugo、Zola 等构建的网站，发布为 IPNS。\n\n比如这是一个用 Jekyll 构建的网站：\n\n* 传统域名 [https://livid.v2ex.com/](https://livid.v2ex.com/)\n* 使用 Planet 0.10+ 发布的 IPNS [k51qzi5uqu5dk40pdgrqh5e6soy2bide88stdbkx8h7jjwvo5cb3xbkb2b7wmq](https://cf-ipfs.com/ipns/k51qzi5uqu5dk40pdgrqh5e6soy2bide88stdbkx8h7jjwvo5cb3xbkb2b7wmq)\n\n上面的这个 IPNS 也可以直接在 Planet 里 Follow。\n\n## Filebase Pinning\n\n<img width=\"1238\" alt=\"Filebase: Pinned\" src=\"filebase-pinned.png\">\n\n<a href=\"https://www.filebase.com/\" target=\"_blank\">Filebase</a> 目前提供免费的 5GB 存储空间及 Pinning 服务。关于这个功能的具体使用方式，可以查看我们之前的博客内容：\n\n<a href=\"https://olivida.eth.limo/9BE484CD-0EA5-4742-927E-FA56F7591CC2/\" target=\"_blank\">https://olivida.eth.limo/9BE484CD-0EA5-4742-927E-FA56F7591CC2/</a>\n\n借助 Pinning 服务，只要在每次内部发布完成之后，再稍微多等待一会让 Pinning 服务也保存一份内容之后，就可以合上你的笔记本了。同时你的访客也会获得更快的速度。\n\n我们会在将来提供对更多 Pinning 服务的支持。关于 Pinning 服务的一些设想，还可以看我之前的这篇文章：\n\n<a href=\"https://olivida.eth.limo/09582A3A-7F32-4E3D-97B0-3105DFE42566/\" target=\"_blank\">https://olivida.eth.limo/09582A3A-7F32-4E3D-97B0-3105DFE42566/</a>\n\n## Custom Code\n\n如果你需要在 Planet 构建出来的网站的 HTML 的 head 或者 body 插入代码，比如各类流量统计或者第三方的评论系统。现在可以有更简单的方式了，之前需要编辑本地模版。\n\n现在可以在 My Planet 上右键选择 Custom Code 就可以设置插入代码。\n\n<img width=\"429\" alt=\"Planet: Custom Code\" src=\"custom-code.png\">\n\n然后就可以在 3 个可能的位置插入定制代码：\n\n* &lt;head&gt;&lt;/head&gt; 中间\n* &lt;body&gt; 开始\n* &lt;/body&gt; 结束之前\n\n<img width=\"563\" alt=\"Planet: Custom Code\" src=\"custom-code-sheet.png\">\n\n## RSS 及 Podcast 支持\n\n现在 Planet 在生成网站时，也可以同时生成 RSS 文件。比如你当前正在查看的这个博客的 RSS 地址是：\n\n<a href=\"https://olivida.eth.limo/rss.xml\" target=\"_blank\">olivida.eth.limo/rss.xml</a>\n\n如果你发布过音频内容，那么 Planet 还可以为你生成符合 Apple Podcast 标准的，只包括音频内容的 XML 文件，地址是在域名根目录下的 podcast.xml：\n\n<a href=\"https://olivida.eth.limo/podcast.xml\" target=\"_blank\">olivida.eth.limo/podcast.xml</a>\n\n右键点击 My Planet 可以找到新的 Podcast 设置，里面可以单独为 Podcast 频道设置封面图及选择分类。\n\n<img width=\"571\" alt=\"Podcast Settings\" src=\"podcast-settings.png\">\n\n完整的 Podcast 发布平台还有许多细节功能需要做。我们会在未来持续更新和 Podcast 有关的实现。\n\n## 其他细节改进\n\n* 修复了在构建网站时一个没有必要的 CID 变化\n* 增加了针对 localhost 上的 IPFS API 端口在 WKWebView 里的屏蔽规则\n* RSS 订阅时，如果页面上发现了多个不同格式，那么优先选择 JSON Feed\n* 增加了 Insider Build 预览测试版的发布渠道\n* 更新内置 kubo 版本到 0.15。我们也测试了最新的 0.16，但其中似乎有一个未修复的资源消耗问题，因此在本次更新时，没有使用最新的 0.16 而是使用了 0.15。\n* 使用 SecureField 显示所有涉及 API Token 的部分，防止在截图或者屏幕共享时泄露敏感信息。\n* 🌟 [支持订阅 Matters Lab 发布的 IPNS](https://matters.news/@web3/337152-matters-lab-%E8%88%87-planetable-xyz-%E9%81%94%E6%88%90%E6%88%B0%E7%95%A5%E5%A4%A5%E4%BC%B4%E5%90%88%E4%BD%9C%E9%97%9C%E4%BF%82-bafyreifdjatteouzchvustaxj3o4a34ka6wb2xi3wxbivuvsgyzuagsolq)\n\n---\n\n以上是本次 0.10 更新里的主要新功能和改进。如果你在使用中遇到问题，可以从以下社区渠道向开发者反馈或者寻求社区协助：\n\n* Telegram 上的 [Planet 中文用户群](https://t.me/+5bl7FIsxeChlOWIz)\n\n如果你十分确定遇到了软件实现上的 bug，那么可以通过 GitHub Issues 向我们描述如何复现 bug，我们会尽快调查和解决。\n\n* GitHub 上的 [Planet 项目](https://github.com/Planetable/Planet)",
      "created" : 687455877.27024198,
      "externalLink" : "",
      "hasAudio" : false,
      "hasVideo" : false,
      "heroImage" : "https://olivida.eth.limo/BE667AFC-8C21-41AD-B37E-C76341EFD988/filebase-pinned.png",
      "id" : "BE667AFC-8C21-41AD-B37E-C76341EFD988",
      "link" : "/BE667AFC-8C21-41AD-B37E-C76341EFD988/",
      "slug" : "",
      "title" : "Planet Feature Update 4"
    },
    {
      "articleType" : 0,
      "attachments" : [
        "filebase-status.png",
        "filebase-create-bucket.png",
        "filebase-access-keys.png",
        "filebase-api-token.png",
        "filebase-pinned.png"
      ],
      "cids" : {
        "filebase-access-keys.png" : "QmXAE4uLKGaeiaS8NiZwNstpESPaM7zQtny8bxh11aE2dM",
        "filebase-api-token.png" : "QmZE3AgKXyxWZJwhfhWxcCz6D1LHFZncZFYKiZyV5ABmMq",
        "filebase-create-bucket.png" : "QmRCJuuU4KRNwLc7CL7CgKJGkAfVCJons8xgB3EC9wuyZ4",
        "filebase-pinned.png" : "QmRPsTorikdrzWat2D1MLrB269Kz6qyjnFYV9Zt8pCeX6m",
        "filebase-status.png" : "QmQU4kNjGk24nBHJ69jNdCDkQxk9AQKhCE8cPoNb8jCHHx"
      },
      "content" : "为了能够在正式发布功能之前进行更充分的测试，我们在 GitHub 上增加了一个新的 Release 类型：Insider Build\n\n目前最新的 Insider Build 可以从这里下载：\n\n[https://github.com/Planetable/Planet/releases/tag/insider-20221013-1](https://github.com/Planetable/Planet/releases/tag/insider-20221013-1)\n\n这个版本中增加的新功能是借助 <a href=\"https://www.filebase.com/\" target=\"_blank\">Filebase</a> 提供的 Pinning 服务，来让 Planet 中发布的内容可以更快地分发。\n\n## Pinning 服务是什么？\n\n在初始状态下，用 Planet 发布的内容，通过本地运行的 IPFS 节点对外提供服务。如果打个比方，这样的状态就像是在用 BitTorrent 下载时，一开始，最初的内容发布者，是整个网络里唯一的做种者（seeder）。\n\n当其他人需要访问内容时，就需要在 P2P 网络上找到做种者。所以，如果没有能够找到，或者连接不顺畅，那么也就无法访问内容。\n\n而 Pinning 服务，就是在发布内容时，使用 API 通知的方式，让 Pinning 服务也保存一份内容，这样网络上就会有更多的 seeder，内容也就会更容易被找到和下载。\n\n## Filebase\n\nFilebase 是一家提供分布式存储的初创公司。他们在最近支持了 IPFS，并且提供了一个<a href=\"https://ipfs-shipyard.github.io/pinning-service-compliance/api.filebase.io.html\" target=\"_blank\">很可靠</a>的 <a href=\"https://docs.filebase.com/api-documentation/ipfs-pinning-service-api\" target=\"_blank\">Pinning API</a>。于是基于这个 API，我们为 Planet 添加了第一个 Pinning 服务集成。\n\n## 开始使用 Filebase\n\n以下是启用 Filebase 来为 Planet 提供 Pinning 的步骤。\n\n1. 首先需要<a href=\"https://www.filebase.com\" target=\"_blank\">注册一个免费的 Filebase 账号</a>。目前，免费账号可以获得 5GB 的 IPFS 存储空间。\n\n2. 点击 Filebase 主界面左侧的 Buckets，然后按 Create Bucket 创建一个新的存储桶。需要输入一个名字，比如 planet，然后下面 Storage Network 就保持默认的 IPFS (Always public)\n\n<img width=\"1233\" alt=\"filebase-create-bucket\" src=\"filebase-create-bucket.png\">\n\n3. 创建 bucket 完成之后，点击左侧的 Access Keys，然后在 IPFS Pinning Service API Endpoint 那里选中刚才创建的 bucket，然后按下面的 Copy 就可以获得 Pinning API 的 API Token，是一串很长的字符串，请当作一种密码保管。\n\n<img width=\"2466\" alt=\"filebase-access-keys\" src=\"filebase-access-keys.png\">\n\n4. 回到想要启用 Pinning 的 My Planet，右键点击 Edit Planet，然后切换到 Pinning Tab，填入一个 Pin Name，比如 ENS 或者其他 URL 友好的名字。及刚才获得的 API Token。然后按下 OK 保存。\n\n<img width=\"1238\" alt=\"filebase-api-token\" src=\"filebase-api-token.png\">\n\n5. 之后每次你的网站发布新内容时，就会通知 Filebase 也保存副本。目前 Filebase 会在 3 个不同的节点上保存内容。如果你 Edit Planet 然后切换到 Pinning Tab，还可以看到内容在 Filebase 上的状态：\n\n  - Pinning - 内容正在被复制到 Filebase\n  - Pinned - 内容已经完成复制\n  - Queued - 正在排队等候\n  - Unknown - 出错了，状态未知\n\n如果出现 Unknown 状态，那么需要检查输入的 API Token 是否正确。可以从 Filebase 网站上重新复制之后重新在 Planet 里填入。\n\n<img width=\"1238\" alt=\"filebase-pinned\" src=\"filebase-pinned.png\">\n\n那个 Pinned 状态的按钮是可以按的，会打开 Pinned 内容在 Filebase 的 Gateway 上类似这样的地址：\n\n[https://ipfs.filebase.io/ipfs/bafybeihkepvteld5u7rmca6ud2cmi5pnpluwpvz6wtmnepmsmyner7xkq4/](https://ipfs.filebase.io/ipfs/bafybeihkepvteld5u7rmca6ud2cmi5pnpluwpvz6wtmnepmsmyner7xkq4/)\n\n内容成功 Pinned 之后，也可以在 Filebase 网站上看到状态：\n\n<img width=\"2466\" alt=\"filebase-status\" src=\"filebase-status.png\">\n\n---\n\nPinning 服务的集成，是一个很新也很复杂的功能，如果你在使用过程中遇到任何问题，欢迎加入 Planet 的 Telegram 群讨论或寻求开发者帮助：\n\n[https://t.me/+5bl7FIsxeChlOWIz](https://t.me/+5bl7FIsxeChlOWIz)",
      "created" : 686209463.36344397,
      "externalLink" : "",
      "hasAudio" : false,
      "hasVideo" : false,
      "heroImage" : "https://olivida.eth.limo/9BE484CD-0EA5-4742-927E-FA56F7591CC2/filebase-status.png",
      "id" : "9BE484CD-0EA5-4742-927E-FA56F7591CC2",
      "link" : "/9BE484CD-0EA5-4742-927E-FA56F7591CC2/",
      "slug" : "",
      "title" : "Insider Build 及 Pinning 测试"
    },
    {
      "articleType" : 0,
      "attachments" : [
        "general-setting-public-gateway.png",
        "planet-info-markdown.png",
        "dwebservices-api-key.png"
      ],
      "cids" : {
        "dwebservices-api-key.png" : "Qmb9CrzyRB3xWodibp6kbJDZrgd9LaRFsKcUtHxDz7EZrb",
        "general-setting-public-gateway.png" : "QmUNU8q8eKfTocaghQufiqKf5vyTJdpZfDezJdewkg3wf9",
        "planet-info-markdown.png" : "QmRy2vSoT2EomYkNNuCsvo8zWqmHnJdjZT6y7au4wggZ1y"
      },
      "content" : "欢迎来到 Planet 在 2022 年 9 月 18 日发布的 Feature Update 3。在这次的功能更新中，我们为你带来了 2 个大的主要功能，及诸多细节问题上的修复。\n\n下面的链接是从 0.8.1 到 0.9.2 版本之间的所有改动的更新日志：\n\n[https://github.com/Planetable/Planet/compare/release-0.8.1...release-0.9.2](https://github.com/Planetable/Planet/compare/release-0.8.1...release-0.9.2)\n\n## Follow .bit\n\n现在在 Follow Planet 时，可以支持 [.bit](https://app.did.id/explorer?inviter=olivida.bit) 域名。\n\n.bit 域名是另外一个基于区块链的域名系统，底层数据存储和计算用的链是 [Nervos Network](https://www.nervos.org/)。\n\n和 ENS 类似，.bit 也提供对 dWeb 的支持，你可以在给你的 .bit 域名绑定用 Planet 生成 IPNS 地址，这样你的 .bit 域名上就可以有用 Planet 构建的网站。.bit 的公共网关是 .bit.cc，比如 olivida.bit 上的 IPNS 可以用这个地址访问到：\n\n[https://olivida.bit.cc](https://olivida.bit.cc)\n\n和 ENS 不同的是，.bit 在更新 dWeb 纪录的时候，不需要付出额外的 gas 费，因为 .bit 在注册时，注册费中就已经包括了一定数量的数据更新所需要的费用。\n\n## dWebServices.xyz\n\n[dWebServices.xyz](https://dwebservices.xyz) 提供托管的 IPNS 纪录。你可以在 Planet 的设置窗口中填入 dWebServices.xyz 的 API Key 和域名，之后每次你的 Planet 更新时，最后的 CID 就会被设置到 dWebServices.xyz 上的 IPNS 记录。这样，除了 Planet 自带的 IPNS 记录，你会获得一个额外的位于 dWebServices.xyz 上的 IPNS 记录。这对于笔记本电脑用户可能会更方便，因为这样你不需要一直开机来保证你的 IPNS 记录存活。但在 Pinning 服务被引入之前，依然需要确保网络上至少有一个节点保存了你的内容，这样其他人才能访问和 Follow 你的网站。\n\n<img width=\"1214\" alt=\"dwebservices-api-key\" src=\"dwebservices-api-key.png\">\n\n我们会在未来的功能更新中提供 Pinning 服务的集成，这样使用笔记本电脑运行 Planet 的用户，在每次内容更新后，只需要再稍微等一下，等远程的 Pinning 服务获得内容之后，就可以彻底把本子合上了。\n\n或是通过一个 [Pinning DAO](../09582A3A-7F32-4E3D-97B0-3105DFE42566/) 来实现这样的效果。\n\n## 功能细节改进\n\n- 现在 Planet 应用的主窗口可以记住位置和尺寸，不会在每次关闭又重开的时候回到一个默认尺寸。\n- 全局设置中增加了选择公共网关的选项。\n\n<img width=\"532\" alt=\"general-setting-public-gateway\" src=\"general-setting-public-gateway.png\">\n\n- 更新了和 Cloudflare 的 peering 设置，现在内容可以更顺畅地被 Cloudflare 的公共网关找到。\n- 本地 IPFS 设置中增加了对 [webui.ipfs.io](https://webui.ipfs.io) 的 CORS 允许，这样你可以通过 webui.ipfs.io 查看本地 IPFS 节点的一些状态。\n- 增加了对 Planet 内部链接的支持，如果现在你相对链接同一个 Planet 中的其他文章，那么应用将可以正确跳转和设置焦点。\n- 初步支持了链接到另外一个 Planet，比如 [planet://zh.gamedb.eth](planet://zh.gamedb.eth) 。如果你已经 Follow，那么会跳转到这个 Planet。如果你还没有 Follow，那么会尝试 Follow 这个地址。\n- 修复了文章列表中未读数更新不实时的问题。\n- 顶部工具栏增加了单篇文章的分享按钮。\n- 降低了 IPFS 进程保持的连接数，可以一定程度降低 IPFS 对资源的消耗。我们会在后续的更新中提供更细致的调整选项。\n- 修复了 Mark All as Read 没有正常工作的问题。\n- 修复了内容检查更新时可能导致风火轮的一个性能问题。\n- 在 Planet 的信息面板中，增加对了 ENS 类型 Planet 的标识。\n- 在 Planet 的信息面板中，可以正确显示其中的 Markdown 语法。也就是说，你可以在 Planet 的 about 信息中使用 Markdown。比如这样的链接：\n\n<img width=\"368\" alt=\"planet-info-markdown\" src=\"planet-info-markdown.png\">\n\n- 在 Unfollow Planet 操作上增加了一个确认框防止误操作。\n- Planet 的信息设置窗口现在使用 TabView 来更好地组织更多信息。\n- Planet 信息中可以填入 GitHub / Twitter 用户名，在模版渲染时会用上这些信息。\n- 修复了打开 Plausible.io Dashboard URL 时的一个编码问题。（感谢来自 [@Fatpandac](https://github.com/Planetable/Planet/commit/915671892324b1ccd6369ac1ed9b7d4f8731912b) 的 PR）\n- 修复了一个编辑器预览区域没有同步滚动的 regression 问题。\n- 编辑器窗口会按照所属的 Planet 记住尺寸和位置。\n- 支持自建版本的 Plausible.io 流量统计服务。\n- 首页模版渲染时新增变量 hasAvatar，模版设计者可以根据这个变量定制是否显示 Planet 的图标。\n- 如果为 Planet 设置了图标，那么图标也会被保存为 32x32 的位于根目录的 favicon.ico。\n- 支持通过 The Iconfactory 的 [WorldWideWeb](https://blog.iconfactory.com/2022/06/worldwideweb-part-2/) 应用来预览本地构建的网站。\n\n---\n\n以上是本次 0.9 更新里的主要新功能和改进。如果你在使用中遇到问题，可以从以下社区渠道向开发者反馈或者寻求社区协助：\n\n* V2EX 上的 [Planet 节点](https://www.v2ex.com/go/planet)\n* Telegram 上的 [Planet 中文用户群](https://t.me/+5bl7FIsxeChlOWIz)\n\n如果你十分确定遇到了软件实现上的 bug，那么可以通过 GitHub Issues 向我们描述如何复现 bug，我们会尽快调查和解决。\n\n* GitHub 上的 [Planet 项目](https://github.com/Planetable/Planet)",
      "created" : 685447505.34159505,
      "externalLink" : "",
      "hasAudio" : false,
      "hasVideo" : false,
      "heroImage" : "https://olivida.eth.limo/37FAB0F7-A2CA-4AA8-AC8D-BB40CC713F49/dwebservices-api-key.png",
      "id" : "37FAB0F7-A2CA-4AA8-AC8D-BB40CC713F49",
      "link" : "/37FAB0F7-A2CA-4AA8-AC8D-BB40CC713F49/",
      "slug" : "",
      "title" : "Planet Feature Update 3"
    },
    {
      "articleType" : 0,
      "attachments" : [

      ],
      "cids" : {

      },
      "content" : "通过 Planet 发布内容，是一种完全去中心化的 local-first 模式。所有的内容不仅存储是在本地，提供对外服务的 IPFS 节点，也是运行在本地机器上。这样的好处是，整个内容的发布和订阅流程，不会受制于外部的大公司的基础架构。\n\n但这样的完全去中心化的做法，也会带来一些挑战：\n\n因为提供对外服务的 IPFS 节点也在本地，因此需要程序一直运行。这对于 Mac mini 或者 Mac Studio 这样的桌面设备可能不是太大的问题，但是对于笔记本电脑的用户就会是一个问题。\n\n对于笔记本电脑的用户，因为不可能让设备保持 24x7 开机及联网，那么最简单的解决方案还是引入服务器来帮助分发。如果你有自己的 Linux 服务器，那么下面是在自己的服务器上启用 IPFS 来帮助 Planet 内容分发的操作步骤和原理。\n\n## 安装 IPFS for Linux Server\n\n* 从这里 [https://github.com/ipfs/kubo/releases](https://github.com/ipfs/kubo/releases) 下载 Linux 版本的 IPFS 服务器端。就是一个可执行文件，我通常的做法就是把这个文件 `ipfs` 复制到 `/usr/local/bin/ipfs`，这样就可以随时运行 `ipfs` 指令。\n* 启动 IPFS 进程 `ipfs daemon`，可以使用 screen、tmux 或者 supervisord。\n\nIPFS 进程启动之后，就可以通过下面这样的指令来 pin 内容了。\n\n```\nipfs pin add /ipns/olivida.eth\n```\n\n所谓 pin 内容这个操作，其实很类似 BitTorrent 下载中的「做种」这个概念。就是，如果一份内容被 pin 了，意味着本地保存了一份经过完整性校验的拷贝，如果网络上的其他节点也要请求这份内容，那么就是所有有拷贝的机器来一起提供，就像 BitTorrent 下载时，是所有 seeder 来一起服务下载请求。\n\n你可以在 `pin add` 使用 IPNS 地址，无论是 k 开头的原生 IPNS 地址，或者是 ENS 地址，都可以支持：\n\n```\nipfs pin add /ipns/planetable.eth\n```\n\n```\nipfs pin add /ipns/k51qzi5uqu5dgv8kzl1anc0m74n6t9ffdjnypdh846ct5wgpljc7rulynxa74a\n```\n\n如果你把这样的指令放到 crontab 中，那么就可以实现追踪 IPNS 背后的 CID 的变化，然后一直 pin 最新内容。\n\n## Pinning DAO\n\n上面的这个操作过程，对于没有 Linux 服务器的用户来说，还是太麻烦了。我们需要更简单的方式，而这件事情非常适合做成一个 DAO。\n\nDAO 存在的意义，就是服务成员的共同需求。\n\nPinning DAO 里，这个共同需求就是：成员需要全世界各地的服务器，来保证发布在 IPFS 上的内容，是永远可用的。为了持续实现这一点，于是需要一个或者多个这样的去中心化自治组织。\n\n我希望接下来能够看到这样的组织的出现。\n\n为了完整实现这个愿景，将会需要构建很多新的开源软件。\n\n比如一个用 [RainbowKit](https://www.rainbowkit.com/) 或者 [ConnectKit](https://docs.family.co/connectkit) 实现登录的网站，ENS holder 登录并且通过 Juicebox 付款成为 DAO Member 之后，就可以通过这个 DAO 部署在全球各地的基础架构来 pin 自己发布在 ENS 上的网站。\n\n而除了提供 pin 服务之外，DAO 也可以为成员提供自建的 Plausible 流量统计之类的服务。\n\n虽然内容通过 DAO 进行了分发，但是权威版本依然是完全控制在用户本地。而不是像之前，因为使用了 Web 2.0 大公司的平台来存储和分发内容，内容的实际存活就完全被大公司所控制了。如果一个 DAO 提供的服务成员不满意，那完全可以发起另外一个，充分的竞争会带来最好的产品和服务。",
      "created" : 685001384.01210403,
      "externalLink" : "",
      "hasAudio" : false,
      "hasVideo" : false,
      "id" : "09582A3A-7F32-4E3D-97B0-3105DFE42566",
      "link" : "/09582A3A-7F32-4E3D-97B0-3105DFE42566/",
      "slug" : "",
      "title" : "💡为什么我们会需要一个甚至多个 Pinning DAO"
    },
    {
      "articleType" : 0,
      "attachments" : [
        "follow-dotbit.png",
        "dotbit-manage.png",
        "dotbit-logo.png",
        "hello-dotbit.png"
      ],
      "cids" : {
        "dotbit-logo.png" : "QmNoYu4cPkuoeKMDYYj7Dv6wE42s5yCbbGaT6miGBLZCSG",
        "dotbit-manage.png" : "QmUYM8QBRmFisAUDfVnMBhb3PFoZ6GXsZa38uviDv6UsE7",
        "follow-dotbit.png" : "QmY8143fBVgm7raLBYTVhf12U3ut5RKGVM85xnC8fdFcHL",
        "hello-dotbit.png" : "QmcuyuciQ8gxBy7GFSge3DfCjLFVVYsnAnTT7gs2JVx7Ui"
      },
      "content" : "<a href=\"https://app.did.id/explorer?inviter=olivida.bit\" target=\"_blank\"><img width=\"1800\" alt=\"hello-dotbit\" src=\"hello-dotbit.png\" border=\"0\"></a>\n\n在 9 月的这个功能更新中，Planet 加入了对另外一个区块链域名的支持：\n\n[.bit](https://app.did.id/explorer?inviter=olivida.bit)\n\n点击上面的域名，就可以注册属于你自己的 .bit 域名。（利益申明：这是一个带有 referral 信息的链接，如果你通过上面这个链接注册，那么我会收到返佣。）\n\n.bit 也支持将 Planet 生成的 IPNS 设置为域名上分布式网站内容源。\n\n<img width=\"1334\" alt=\".bit Manage\" src=\"dotbit-manage.png\">\n\n与 ENS 不同的是，.bit 在设置网站内容源的时候，不需用户再次支付 gas。.bit 对此的解释是两个原因：\n\n1. .bit 的注册费用中已经包括了一定数量的后续操作所需要的 gas 费。\n2. .bit 所依赖的区块链 [Nervos Network](https://www.nervos.org/) 的设计让计算类型的任务的 cost 较低。\n\n所以，大家目前正在访问的这个博客，现在也有了一个 .bit 域名 olivida.bit，并且可以通过 .bit 的 dWeb Public Gateway 访问了：\n\n<div style=\"display: flex; align-items: center;\">\n<img width=\"64\" alt=\"dotbit-logo\" src=\"dotbit-logo.png\">\n<div style=\"flex: 1; font-size: 40px;\">\n<a href=\"https://olivida.bit.cc\" target=\"_blank\">olivida.bit.cc</a>\n</div>\n</div>\n\nPlanet 的 Follow 功能，现在也可以支持 .bit 地址了：\n\n<img width=\"1092\" alt=\"Follow .bit\" src=\"follow-dotbit.png\">\n",
      "created" : 684712580.017205,
      "externalLink" : "",
      "hasAudio" : false,
      "hasVideo" : false,
      "heroImage" : "https://olivida.eth.limo/8F4176F4-BDFB-4049-B901-FAACEBA6FFEF/follow-dotbit.png",
      "id" : "8F4176F4-BDFB-4049-B901-FAACEBA6FFEF",
      "link" : "/8F4176F4-BDFB-4049-B901-FAACEBA6FFEF/",
      "slug" : "",
      "title" : ".bit"
    },
    {
      "articleType" : 0,
      "attachments" : [

      ],
      "cids" : {

      },
      "content" : "<a href=\"https://eth.limo\" target=\"_blank\">eth.limo</a> 是一个很特别的项目。最早是从 vitalik.eth 在 Gitcoin 的捐赠记录中了解到这个项目的存在。当时 eth.link 过期事件还没有发生，因此可以对比两个项目的性能。eth.limo 在大部分时间都更快，更稳定。\n\n两个项目做的是同一件事情：通过在互联网上设置一个特殊的代理服务器，让任何浏览器都可以通过 HTTP 方式访问到 IPFS 上的内容。如果没有这样的代理服务器项目，那么需要客户端浏览器内置 IPFS 节点，比如像 Brave 和 Planet 的做法。而 eth.limo 的实现方式就是，如果你在任意设置了 contenthash 的 ENS 上加上 .limo，那么就可以在普通浏览器里打开，比如：\n\n* [vitalik.eth.limo](https://vitalik.eth.limo)\n* [planetable.eth.limo](https://planetable.eth.limo)\n* [zh.gamedb.eth.limo](https://zh.gamedb.eth.limo) （是的，eth.limo 对 ENS 的二级域名也可以支持）\n\n现在 eth.limo 项目入选了最新 Gitcoin 的 [Grants Round 15](https://gitcoin.co/grants/4760/ethlimo-your-privacy-focused-ens-ipfs-gateway)。所以现在如果你在 Gitcoin 上支持这个项目，那么项目还可以收到来自 Gitcoin 的机构的匹配支持。\n\n在他们的路线图描绘几件接下来会做的事情。其中我个人觉得最有趣是：\n\n🔵 Privacy first traffic analysis and reporting - view how many requests your ENS dwebsite has received.<br /><br />可以看到脱敏之后的流量分析。如果到时候使用流程是用自己钱包登录，然后就可以看到钱包里的所有 ENS 在 eth.limo 上的流量，那对 dWebsite 的搭建者也会是一个很好的激励。\n\n🌎 Decentralizing the LIMO infrastructure through a community run CDN.<br /><br />结合 Roadmap 中的其他条目，大概率会有一个可以在自己本地电脑上部署的 eth.limo，并且可以和全世界的其他节点结合成为一个全球加速的 CDN。\n\n完整的 Roadmap 可以在项目主页上看到：\n\nhttps://gitcoin.co/grants/4760/ethlimo-your-privacy-focused-ens-ipfs-gateway",
      "created" : 684266258.42110097,
      "externalLink" : "",
      "hasAudio" : false,
      "hasVideo" : false,
      "id" : "4B412A73-9C15-4E62-BFC6-157E2D28D0C1",
      "link" : "/4B412A73-9C15-4E62-BFC6-157E2D28D0C1/",
      "slug" : "",
      "title" : "ETH.LIMO"
    },
    {
      "articleType" : 0,
      "attachments" : [
        "HighWater.png"
      ],
      "cids" : {
        "HighWater.png" : "QmRcvaX5eHiRyVFru46ZLPvtGWrggZ5XTDfnPHUsrmXwfi"
      },
      "content" : "我们会在之后的版本更新中，为这篇文档中提到的配置方式提供图形界面。\n\n目前如果你希望稍微降低 Planet 内置的 IPFS 的资源占用，那么可以打开这个位置的配置文件：\n\n`~/Library/Containers/xyz.planetable.Planet/Data/Library/Application Support/ipfs/config`\n\n上面路径中的 `~` 的意思是用户的 Home Directory。\n\n在这个文件中搜索 `HighWater`，然后你会看到这样的一组默认配置：\n\n<img width=\"234\" alt=\"HighWater\" src=\"HighWater.png\">\n\n- HighWater: 900\n- LowWater: 600\n\n你可以试着把这对值改低一些，比如改到：\n\n- HighWater: 200\n- LowWater: 100\n\n这样会降低 IPFS 在运行时的连接数，也就降低了资源消耗。但是这样的代价是，某些情况下，在 P2P 网络上寻找全新内容的速度可能会降低。\n\n为什么说是某些情况下呢，因为如果你要寻找的内容，你已经掌握它具体所在的节点位置，那么是可以通过 peering 和 pinning 的方式让内容快速同步的，同时并不需要维持很高的 peers 数量。关于 peering 和 pinning 能带来的诸多有趣可能性，我会在之后的另外一篇文章中介绍。",
      "created" : 683283664.93403196,
      "externalLink" : "",
      "hasAudio" : false,
      "hasVideo" : false,
      "heroImage" : "https://olivida.eth.limo/EB692F2E-2783-4A61-BD8B-7C1AA685C671/HighWater.png",
      "id" : "EB692F2E-2783-4A61-BD8B-7C1AA685C671",
      "link" : "/EB692F2E-2783-4A61-BD8B-7C1AA685C671/",
      "slug" : "",
      "title" : "关于优化 IPFS 的资源占用"
    },
    {
      "articleType" : 0,
      "attachments" : [
        "template-browser.png",
        "open-in-www.png",
        "edit-name.png",
        "demo-olivida.eth.png",
        "demo-zh.gamedb.eth.png"
      ],
      "cids" : {
        "demo-olivida.eth.png" : "QmVqgZbdMfYVDj1E2ZySrdxf1bt4zJmmrnoE9TcM5nRrQj",
        "demo-zh.gamedb.eth.png" : "QmUvFkkBGwvk5qqjjaJRVpxdfdV646uVqGjFDYvXisHDYE",
        "edit-name.png" : "QmU9PtmFPvnwQYCFPfCRovCu719nkrc1AvEHkkg7VzhiZF",
        "open-in-www.png" : "Qme4Vy9aNADJid2SVZ7m34mpcqCSJgF8qvX62Hpgd8Toos",
        "template-browser.png" : "QmPrKBBJn88inFSNQLpTHgmqrs2xwJ8MmQtuSU9BrHGzUp"
      },
      "content" : "Planet 的核心功能之一，是一个静态网站生成器。所以，用 Planet 做网站，是可以支持全站模版替换的。在这篇文章里，我们会向你介绍目前系统的内置模版，及如何制作自己的新模版。\n\n## 内置模版\n\n在目前的版本中，Planet 有两个内置模版：\n\n### Plain\n\n<img width=\"930\" alt=\"demo-olivida.eth\" src=\"demo-olivida.eth.png\">\n\n外观简洁，尽量贴近操作系统原生 look-n-feel 的模版，支持自动切换 Light/Dark 模式。Planet 如果有新的媒体格式支持，那么 Plain 模版会最先更新，提供对新的媒体格式的支持。比如之前的更新中，对视频和音频，及附件下载的支持。\n\n* GitHub https://github.com/Planetable/SiteTemplatePlain\n* Demo Site https://olivida.eth.limo/\n\n### 8-bit GameDB\n\n<img width=\"930\" alt=\"demo-zh.gamedb.eth\" src=\"demo-zh.gamedb.eth.png\">\n\n一个 8-bit 风格的模版。一些新的前端技术会在这个实验性的模版中使用。比如目前这个模版中的很多组件，就是用 Vanilla JS Web Component 实现的。GameDB 模版在获得新的媒体格式支持方面会比 Plain 模版稍微慢一周。\n\n* GitHub https://github.com/Planetable/SiteTemplate8bit\n* Demo Site https://zh.gamedb.eth.limo/\n\n## 制作自己的模版\n\n如果你希望制作自己的新模版，那么目前我们推荐的步骤是：\n\n* 打开 Planet 的数据目录：`~/Library/Containers/xyz.planetable.Planet/Data/Documents/Planet/Templates`\n* 复制其中的 Plain 模版的目录到一个新的目录\n* 打开新目录中的 `template.json` 文件，编辑其中的 name 字段，给你的新模版一个新名字 <br /><img width=\"1136\" src=\"edit-name.png\">\n* 然后在下次启动 Planet 之后，就可以看到和选择这个新模版了。\n\n## 编辑和预览模版\n\n如果你改动了自己的新模版的 HTML / JS / CSS，想要快速预览的话，我们推荐的做法是：\n\n安装来自 The Iconfactory 的 [WorldWideWeb](https://blog.iconfactory.com/2022/06/worldwideweb-part-2/)，这是一款非常简单好用的静态网站 HTTP 服务器。它可以快速将任意目录的内容以 HTTP 方式提供服务。\n\n在安装完 WorldWideWeb 之后，你会在右键点击 My Planet 时在 Develop 菜单下看到新选项：Open in WorldWideWeb \n\n<img width=\"612\" src=\"open-in-www.png\" alt=\"Open in WorldWideWeb\">\n\n然后 WorldWideWeb 就可以在 localhost 上预览你的 Planet 的新模版构建的网站。每次你做了修改时，只需要在 Develop 菜单下 Rebuild，然后就可以通过 WorldWideWeb 提供的 localhost 上的服务预览更改。\n\n此外，你可以通过 Planet 的 Tools 菜单下的 Template Browser 看到目前你本地的 Planet 所安装的所有模版：\n\n<img width=\"1012\" src=\"template-browser.png\" alt=\"Template Browser\">\n\n---\n\n这个关于 Planet 的 Template Engine 模版引擎的文档会在未来持续更新。",
      "created" : 683162375.597157,
      "externalLink" : "",
      "hasAudio" : false,
      "hasVideo" : false,
      "heroImage" : "https://olivida.eth.limo/08CC35A0-F2CC-425B-B520-E5838B17827A/template-browser.png",
      "id" : "08CC35A0-F2CC-425B-B520-E5838B17827A",
      "link" : "/08CC35A0-F2CC-425B-B520-E5838B17827A/",
      "slug" : "",
      "title" : "Planet 的模版系统"
    },
    {
      "articleType" : 0,
      "attachments" : [
        "worldwideweb-icon.png",
        "open-in-worldwideweb.png",
        "first-web-server.jpg",
        "the-workflow.png",
        "worldwideweb.png"
      ],
      "cids" : {
        "first-web-server.jpg" : "QmTnfb1ttYFPXcYvJjojQiNqLtJ1Rmk6PmT5WV4xaoYv1E",
        "open-in-worldwideweb.png" : "QmWqPk2LhJUCWVjDVjbSEimLSR9wZebxNonkat1VGRnxVW",
        "the-workflow.png" : "QmUGU4S6Gfi29JFdfPrdckc1c22gfvdjTTfMkCR7mQqz1P",
        "worldwideweb-icon.png" : "QmToC5738ktC6CTThrvYHt3WPfpc8DrWUM7ZDJALimqX5S",
        "worldwideweb.png" : "QmUkfDyWyHTxiL28mB4hPUpiuRBSZQpYE3KKhnB9TFGNmh"
      },
      "content" : "[WorldWideWeb](https://blog.iconfactory.com/2022/06/worldwideweb-part-2/) 是来自图形设计公司 [The Iconfactory](https://iconfactory.com) 的一款简单好用的 HTTP 服务器。\n\n<img width=\"592\" alt=\"worldwideweb\" src=\"worldwideweb.png\">\n\n这个名字 WorldWideWeb 致敬了世界上第一个 HTTP 服务器，也就是当年跑在 [Tim Berners-Lee](https://en.wikipedia.org/wiki/Tim_Berners-Lee) 的 NeXT 电脑上的那个。因此你也可以在 WorldWideWeb 的 Help 页面看到当年的那台机器的样子。\n\n<img width=\"1884\" alt=\"first-web-server\" src=\"first-web-server.jpg\">\n\nWorldWideWeb 的工作方式非常简单：选择一个文件夹，然后 WorldWideWeb 就会在 8080 端口上启动，然后访问本地机器的 8080 端口就可以看到那个目录里的网站。\n\n在刚刚发布的 Planet 0.8.2 版本更新里，我们加入了对 WorldWideWeb 的支持。如果你的 Mac 上有安装 WorldWideWeb，那么现在当你右键单击自己的 Planet 时，会在 Develop 菜单下看到一个 Open in WorldWideWeb 的新选项，然后就可以用 WorldWideWeb 打开你自己的 Planet 构建的静态网站。\n\n<img width=\"608\" alt=\"open-in-worldwideweb\" src=\"open-in-worldwideweb.png\">\n\n这样的用途是？如果你在开发自己的 Planet 模版，那么配合新的 Develop 菜单的 Rebuild 功能，每次你在自己的模版中改动了什么的时候，就可以方便地马上看到改动之后的效果了。\n\n<img width=\"1920\" alt=\"the-workflow\" src=\"the-workflow.png\">\n\n<div style=\"background-color: rgba(0, 0, 0, 0.1); padding: 10px; display: flex; gap: 10px; border-radius: 30px; align-items: center; margin-top: 20px; box-shadow: 0px 3px 12px rgba(0, 0, 0, 0.1)\">\n<div>\n<img width=\"128\" alt=\"worldwideweb-icon\" src=\"worldwideweb-icon.png\" style=\"vertical-align: bottom\">\n</div>\n<div style=\"flex: 1;\"><p>你可以从 App Store 免费下载 WorldWideWeb：</p>\n\n<a href=\"https://apps.apple.com/us/app/worldwideweb-desktop/id1621370168?mt=12\" target=\"_blank\">WorldWideWeb for macOS</a></div>\n</div>",
      "created" : 682548021.632658,
      "externalLink" : "",
      "hasAudio" : false,
      "hasVideo" : false,
      "heroImage" : "https://olivida.eth.limo/C90EEACD-807B-4CCA-8D44-5AD0D9C5D79C/first-web-server.jpg",
      "id" : "C90EEACD-807B-4CCA-8D44-5AD0D9C5D79C",
      "link" : "/C90EEACD-807B-4CCA-8D44-5AD0D9C5D79C/",
      "slug" : "",
      "title" : "Planet and WorldWideWeb"
    },
    {
      "articleType" : 0,
      "attachments" : [
        "fyfy-067.mp3",
        "deep-look.png",
        "toolbar-plausible.png",
        "plausible-olivida.eth.png",
        "template-browser-8bit.png",
        "writer-podcast.png",
        "planet-audio-player.png"
      ],
      "audioByteLength" : 136023316,
      "audioDuration" : 5666,
      "audioFilename" : "fyfy-067.mp3",
      "cids" : {
        "deep-look.png" : "QmSawvtDUX3hkhZp5KLazNdCLMR9poLjRDTtmPR1XAkwGw",
        "fyfy-067.mp3" : "QmWHXePeCHPFKzQnD3BxfVUot4DKj6dDL68Q9RoLD8VbCc",
        "planet-audio-player.png" : "QmfR3xWtWwF7r18asJJEy2cuSBYjRkjdnfCra8kP5oKjw4",
        "plausible-olivida.eth.png" : "QmXbU6PRwmFH2oGhXWm28ouqytwKRdaCSfW9BasWWGgbeK",
        "template-browser-8bit.png" : "QmWDPGBrqRM86CgjBN4isEjrpQpyeEpWz3NLmLKdCzDJqz",
        "toolbar-plausible.png" : "QmNhfBotXzbvcHrz5dDVcUxBDdgws9ivgmVCuxJVEFYCU8",
        "writer-podcast.png" : "QmU4P5mdVWQvtoUsYCtoETpYGgb4Eyt4WL6xS6vve2i6aG"
      },
      "content" : "这是 Planet 的第二个功能更新，版本号 0.8.0，发布于 2022 年 8 月 13 日。这次的更新的代码来自于以下贡献者：\n\n* [@stdc105](https://github.com/stdc105)\n* [@kailuo](https://github.com/kailuo)\n* [@livid](https://github.com/livid)\n\n下面的链接是从 0.7.0 到 0.8.0 版本之间的所有改动的更新日志：\n\n[https://github.com/Planetable/Planet/compare/release-0.7.0...release-0.8.0](https://github.com/Planetable/Planet/compare/release-0.7.0...release-0.8.0)\n\n下面是这个版本里带来的新功能和改进。\n\n## Plausible.io 数据统计\n\n[Plausible.io](https://plausible.io) 是一个开源的数据统计平台，创始团来自欧洲。现在 Planet 支持在 Info 面板中填入 Plausible 的 domain 和 API token，这样就可以通过 Plausible.io 看到有多少人访问过你的 Planet。\n\n![](toolbar-plausible.png)\n\n比如下面的链接是 [olivida.eth](https://olivida.eth.limo/) 的访问数据例子：\n\nhttps://plausible.io/olivida.eth.limo\n\n![](plausible-olivida.eth.png)\n\n另外一个例子，Plausible.io 官方网站的流量：\n\nhttps://plausible.io/plausible.io\n\nPlausible.io 的实现方式是[尊重隐私](https://plausible.io/privacy-focused-web-analytics)的。这个平台不会收集个人信息，甚至都没有使用 cookie。因此不需要在使用 Plausible.io 的页面上弹出 cookie banner。\n\n我们会在未来的版本更新中加入对 self-hosted 版本的 Plausible 的支持。\n\n## 博客 Podcast 和附件支持\n\n现在你可以在撰写内容时，选择附加一个音频文件，或者是直接将音频文件拖拽到写作窗口中。之后在发布时，页面上就会出现一个音频播放器。\n\n![](writer-podcast.png)\n\n在本篇博客的内容中，就附加了一段音频内容。这是我在 5 月份 Planet 上线之前，和 [枫言枫语播客](https://justinyan.me/post/4904) 录制的。里面分享了关于 Planet 在制作过程中的一些思考。\n\n如果是在 0.8.0 之后版本的 Planet 客户端中访问这样的带有音频的内容，那么在工具栏中会看到一个耳机按钮，点击之后就会启动一个全局的音频播放器去播放内容中所携带的音频内容。得益于这个全局播放器的存在，播放时切换查看的文章内容，播放不会被打断。\n\n<img width=\"818\" alt=\"planet-audio-player\" src=\"planet-audio-player.png\">\n\n我们会在未来的版本中继续优化这个全局音频播放器的使用体验。\n\n如果你将其他格式的文件，比如 PDF 或者 DMG 之类拖拽进入写作窗口，那么这样的内容在发布之后，会在 0.8.0 的客户端中显示为附件。访客可以点击工具栏中的附件图标就可以下载。\n\n## 内置模版的细节改进\n\nPlanet 目前内置了两个网站模版用于切换样式。\n\n![](template-browser-8bit.png)\n\n在这次的更新中，我们为这两个模版加入了众多的细节改进：\n\n* 对音频内容的支持\n* 针对视频和图片内容的 CSS 样式优化\n* 在顶部区域，从内容页面返回到首页的链接\n* 在 iOS 移动设备上访问时的 safe-area 问题\n* Plain 主题首页对 Dark Mode 的支持\n\n模版的功能完备是 Planet 的重要部分。所有的内置模版和 Planet App 一样，也都是开源软件，所以如果你发现任何模版相关的问题，也可以通过 GitHub Issues 甚至 PR 的方式反馈给我们：\n\n* https://github.com/Planetable/SiteTemplatePlain\n* https://github.com/Planetable/SiteTemplate8bit\n\n接下来，我们会在 2022 年 8 月发布关于如何自己构建新模版的详细文档。\n\n下面这个项目是来自开发者 [Fledge Shiu](https://github.com/FledgeXu) 的一个有意思的模版，实现了中文竖排的效果：\n\nhttps://github.com/FledgeXu/Vertical\n\n然后这里是一个用 8-bit 模版的关于经典老游戏的博客：\n\n[https://zh.gamedb.eth.limo/](https://zh.gamedb.eth.limo/)\n\n## 内置 go-ipfs 版本升级\n\nPlanet 内置的 go-ipfs 版本从 0.12 升级到了 0.14。从 0.13 版本开始，上游 Protocol Labs 将 go-ipfs 项目更名为了 [kubo](https://github.com/ipfs/kubo)，所以之后我们如果需要在文档中提到 go-ipfs，我们会使用它的新名字 kubo。\n\n由于 kubo 的版本升级，会在 Planet 启动时有一个迁移仓库的操作。如果你的本地 IPFS repo 的文件数量较大，那么这个迁移可能会需要一些时间，让它跑一会就好。\n\n我们会在未来的版本中提供更多针对本地 IPFS repo 的图形界面管理功能。\n\n## RSS 订阅器相关的细节改进\n\n其实从 Planet 的第一个发布版本开始，这个软件就是带有 RSS 订阅功能的。但是因为一些细节还不够好用，所以我们之前没有公开宣布过这个功能的存在。\n\n在这次的 0.8.0 更新中，我们针对 RSS 订阅的很多细节功能做了改进和测试，所以现在我们可以有一些信心来邀请你试用一下。\n\n这里有一些有趣的 RSS 订阅源：\n\n* [Low Tech Magazine](https://solar.lowtechmagazine.com/): 一个完全靠太阳能驱动的网站，所以阴天的时候可能会断线。\n* YouTube 上的 [Deep Look](https://www.youtube.com/c/KQEDDeepLook) 频道：各种有趣动物的 4K 科普视频\n\n![YouTube Channel: Deep Look](deep-look.png)\n\n很多会持续更新内容的网站，很可能都带有 RSS 订阅地址，一个例子就是 YouTube 上的各类 Channel 的首页。你可以尝试直接把网址填入到 Follow Planet 那里，如果内容源上确实存在 RSS 地址，那么就可以用 Planet 订阅。\n\n如果你在使用 RSS 订阅功能的过程中遇到问题，欢迎反馈到下面这些社区渠道：\n\n* Telegram 上的 [Planet 中文用户群](https://t.me/+5bl7FIsxeChlOWIz)\n\n## 提醒相关的细节改进\n\n我们在这次更新中进一步改进了 Local Notification 的工作方式。现在如果你收到了订阅的 Planet 的内容更新提醒，那么点击 Notification 就可以直接跳转到这篇文章。\n\n## 其他细节改进\n\n* 更换了 Markdown 渲染引擎，现在 Planet 可以输出和 [GitHub Flavored Markdown](https://github.github.com/gfm/) 完全一致的结果，同时也解决了之前由于使用 [Ink](https://github.com/JohnSundell/Ink) 渲染所带来的一些 crash 问题。\n* 现在在查看文章时，如果执行了任何的下载相关的操作，那么这些操作可以正常工作了，并且可以从一个新的 Download Manager 窗口中看到下载进度。之前的版本中由于缺乏对 WKDownloadDelegate 的实现而导致了下载相关的操作没有反应。\n* 改进了对 DNSLink 加载内容的支持。值得注意的是，如果你希望以 DNSLink 方式订阅一个 IPFS 上的网站，那么需要在 Follow Planet 窗口使用 planet 协议，比如这样去输入域名 `planet://zu1k.com`。\n* 从 Planet 发布的 IPNS 记录的 TTL 时间从 1 周调整到了 1 年。但 IPNS 记录在节点上的存在时间，依然取决于很多其他因素。所以，如果你希望保持你的 IPNS 记录有效，那么至少每周打开 Planet 运行一段时间，就肯定没有问题的。关于 IPNS 及 Pinning 这几个复杂而又重要的技术细节，我们会在接下来的一篇博客里详细介绍。\n\n---\n\n以上是本次 0.8.0 更新里的主要新功能和改进。如果你在使用中遇到问题，可以从以下社区渠道向开发者反馈或者寻求社区协助：\n\n* V2EX 上的 [Planet 节点](https://www.v2ex.com/go/planet)\n* Telegram 上的 [Planet 中文用户群](https://t.me/+5bl7FIsxeChlOWIz)\n\n如果你十分确定遇到了软件实现上的 bug，那么可以通过 GitHub Issues 向我们描述如何复现 bug，我们会尽快调查和解决。\n\n* GitHub 上的 [Planet 项目](https://github.com/Planetable/Planet)",
      "created" : 682123014.095752,
      "externalLink" : "",
      "hasAudio" : true,
      "hasVideo" : false,
      "heroImage" : "https://olivida.eth.limo/7CD979D8-B4E8-43ED-96DA-A012FDDC81BE/deep-look.png",
      "id" : "7CD979D8-B4E8-43ED-96DA-A012FDDC81BE",
      "link" : "/7CD979D8-B4E8-43ED-96DA-A012FDDC81BE/",
      "slug" : "",
      "title" : "Planet Feature Update 2"
    },
    {
      "articleType" : 0,
      "attachments" : [
        "By the sea.mp4"
      ],
      "cids" : {
        "By the sea.mp4" : "QmU4KDh9HaaWcVuawGx9Cx39pagk2Hs9FNPxP2ESgXLpNx"
      },
      "content" : "这是 Planet 的第一个功能更新，版本号 0.7.0。\n\n## 视频发布\n\n现在在发布文章时，可以为文章附加一条视频。效果就像现在你看到的这篇一样。如果你现在在用的屏幕支持 HDR（比如新款 14 和 16 MacBook Pro 的屏幕），你会注意到这个视频是 HDR 的。\n\n## 数据存储优化\n\n我们对 App 底层的数据架构做了一次比较大的重构，来解决在上个月初次发布的版本中遇到的一些问题。在有了这个新的数据层之后，整个 App 的性能会有一个明显的提升。比如之前在打开 Unread 时可能会感受到的延迟现在消失了。如果你在升级之后遇到任何和数据相关的问题，可以到这个 Telegram 群寻求开发者支持 [https://t.me/+5bl7FIsxeChlOWIz](https://t.me/+5bl7FIsxeChlOWIz)\n\n另外就是，现在 App 在检查到新的内容更新时，会发送本地通知。我们会继续增强和 Notification 有关的功能的使用体验。\n\n## 增强的 ENS 支持\n\n最近我们发现了一个性能很好的 ENS Gateway——[ETH.LIMO](https://eth.limo)，然后我们把 App 里如果用传统浏览器打开 ENS 链接的地方都换成了这个。这样如果你需要把自己发布在 ENS 上的内容发给没有安装 Planet 也没有在使用 Brave 的朋友，那么你可以使用类似下面这样的连接：\n\n[https://olivida.eth.limo/](https://olivida.eth.limo/)",
      "created" : 679466808.07791495,
      "externalLink" : "",
      "hasAudio" : false,
      "hasVideo" : true,
      "heroImage" : "https://olivida.eth.limo/5C9A4ABD-0F63-447A-A0DE-589AFBEAAA4C/_videoThumbnail.png",
      "id" : "5C9A4ABD-0F63-447A-A0DE-589AFBEAAA4C",
      "link" : "/5C9A4ABD-0F63-447A-A0DE-589AFBEAAA4C/",
      "slug" : "",
      "title" : "Planet Feature Update 1",
      "videoFilename" : "By the sea.mp4"
    },
    {
      "articleType" : 0,
      "attachments" : [
        "wunderlist.jpg"
      ],
      "cids" : {
        "wunderlist.jpg" : "QmVBxjjVCY1iQhetTS1nE43RaM5yycpNf9aYnFuktFk9zw"
      },
      "content" : "![wunderlist.jpg](wunderlist.jpg)\n\n在过去几年的时间里，有这么几件事情让我印象深刻。\n\nMicrosoft 收购了 Wunderlist。基于 Wunderlist 推出了 Microsoft To Do，但是却并没有 Wunderlist 的所有功能。比如一直都没有评论功能。后来 Microsoft 宣布会在 2020 年 5 月彻底关闭 Wunderlist。Wunderlist 的创始人 Christian Reber 试图买回公司，但是却没有得到回应。\n\n[Atlassian 宣布之后将只会提供云版本的 Jira](https://www.atlassian.com/migration/assess/journey-to-cloud)，不会再出售新的 Jira on-premise 的授权。也就是说，以后就不会再有可以跑在自己服务器上的 Jira 了。\n\nGoogle 宣布会终止一直免费的自建域名版本 Gmail。如果要继续使用，那么请绑定信用卡。收费模式是每用户每月 6 美元起。\n\n大公司的这些决定让我作为他们曾经的用户，而不得不去花额外的时间和资源，寻找替代方案、改变使用习惯。而有些产品，虽然有不错的替代方案——比如 [Linear](https://linear.app) 是很好的 Jira 替代品，但我不知道如果什么时候 Linear 被一家大公司收购，然后大公司关闭 Linear？那我之前在 Wunderlist 和 Jira server 关闭时所经历的一切无奈就会被迫又经历一次。\n\n于是所有的这些事情，都促成了我后来在很长一段时间内的思考——自己接下来新产生的那些创作及创作过程，到底应该放在一个什么样的地方？",
      "created" : 677876398.31888199,
      "externalLink" : "",
      "hasAudio" : false,
      "hasVideo" : false,
      "heroImage" : "https://olivida.eth.limo/E099F6AF-968E-45AA-B909-0DE04BFAA8E4/wunderlist.jpg",
      "id" : "E099F6AF-968E-45AA-B909-0DE04BFAA8E4",
      "link" : "/E099F6AF-968E-45AA-B909-0DE04BFAA8E4/",
      "slug" : "",
      "title" : "自己的数据"
    },
    {
      "articleType" : 0,
      "attachments" : [
        "template-browser.png"
      ],
      "cids" : {
        "template-browser.png" : "QmXADLe5XFZS8VGrKhFg68HwQPt4BvaLtP6hgbGcd6QEKe"
      },
      "content" : "上周（2022 年 6 月初）的 [Planet](https://planetable.xyz) 是第一个提供了公开下载链接的版本。里面出现了一些我们在之前更小范围测试时，没有发现的问题。其中最尴尬的一些 crash 问题，已经在 2022 年 6 月 12 日的 0.6.16 里修复。这件事情刚刚开始，重要的是之后用稳定的节奏，把计划中的事情一件一件全部交付。\n\n那么，后续的计划是什么？这里大概说一下。\n\n1. 视频和音频。在传统的 Web 2.0 场合，视频和音频是一种「上传」体验。而将来在 Planet 里，应该只是一件拖拽进来，加上描述，然后发布之后放在那里就好的体验。\n2. 评论和 Web Ping。\n3. 移动版本。具体细节还在设计中。但考虑到不太可能会让手机来运行 IPFS 的服务器（网络流量消耗和电池都是问题），所以一种可能的实现方式是 Planet 的 Desktop 版本提供一个 API，然后手机来连接这个 API。现在有 [Tailscale](https://www.tailscale.com/) 和 [ZeroTier](https://www.zerotier.com/) 这样的技术可以让手机在任意网络上都和家里的电脑保持内网直连状态，因此如果能够实现这样的一种卫星式的体验，应该会很有意思。\n4. 更多更强更美的页面主题。Planet 内部在渲染每一个网站时，使用了一套基于 [Jinja](https://jinja.palletsprojects.com/) 语法的模版系统。借助这套模版系统，每一个 Planet 都有可能可以使用完全个性化的设计。\n\n我们会在后续发布详细的模版设计相关的文档。但是如果你是经验丰富的前端工程师，想提前试试的话，那么可以在菜单里 Tools -> Template Browser 找到模版浏览器，然后在 Template Item 上右键 Reveal in Finder。每一个 Template 都在一个自己的文件夹，你可以把文件夹复制一份，改个名，然后里面的 `template.json` 的元信息也改一改，就可以做自己的模版了。剩余的文件结构并不复杂，一看就明白。如果你机器上安装了 Visual Studio Code，那么可以直接右键 `Open in VSCode`：\n\n![template-browser.png](template-browser.png)\n\n要支持一个完整的模版设计系统，会需要很多的支持变量（variables），不过这不会是一件很复杂的事情。我们会尽快把这件事情补齐。",
      "created" : 676800593.68975794,
      "externalLink" : "",
      "hasAudio" : false,
      "hasVideo" : false,
      "heroImage" : "https://olivida.eth.limo/44A8A7F5-6484-4141-B65C-E57B09E83BCF/template-browser.png",
      "id" : "44A8A7F5-6484-4141-B65C-E57B09E83BCF",
      "link" : "/44A8A7F5-6484-4141-B65C-E57B09E83BCF/",
      "slug" : "",
      "title" : "20220612"
    },
    {
      "articleType" : 0,
      "cids" : {

      },
      "content" : "IPNS 是 IPFS 生态中的一个重要组件，全称是 InterPlanetary Name System，一个去中心化的类似域名的系统。\n\n这里是 IPNS 的官方介绍：\n\n* [InterPlanetary Name System](https://docs.ipfs.io/concepts/ipns/)\n\n内容寻址是 IPFS 找到内容的最基础的方式。但是会有一个问题是，内容 ID 其实是内容的 hash。因此如果内容本身如果发生了任何变化，那么 hash 也会变。所以如果是用内容 ID（CID）来绑定给 ENS 的话，每更新一次博客就去烧 gas 重新设置 ENS 的 Content Hash，在现有的 gas fee 情况下，就太贵了。\n\n而 IPNS 可以解决这个问题。每一个 IPNS 类似加密货币的钱包，会有一对 public key 和 private key。public key 就是 IPNS 的对外的地址，而 private key 可以用来修改这个对外地址所对应的 CID。\n\n因此，当你用 IPNS 来绑定给 ENS 作为 Content Hash 的时候，完整的链条是这样的：\n\nENS -> IPNS -> CID\n\n其中 ENS 到 IPNS 这层绑定，会需要一次性的 gas 费。\n\nIPNS 到 CID 这一层，是免费的。\n\n这样我们就可以实现用 IPFS 更新内容之后，ENS 上的网站也就能够动态更新，同时只需要消耗一次性的 gas 费。\n\n---\n\n比如本站的 IPNS 地址是：\n\n```\nk51qzi5uqu5dgbfw2poynnynor8h9kqqoxmzdrxy4h4wnzx1x5p4n40ijtosxk\n```\n\n然后绑定到了 olivida.eth 这个 ENS 域名上。\n\n在所有支持 IPFS + ENS 生态系统的应用中，你可以使用上面的 IPNS 地址或者 ENS 找到同样的内容。\n\n- [https://ipfs.io/ipns/k51qzi5uqu5dgbfw2poynnynor8h9kqqoxmzdrxy4h4wnzx1x5p4n40ijtosxk/](https://ipfs.io/ipns/k51qzi5uqu5dgbfw2poynnynor8h9kqqoxmzdrxy4h4wnzx1x5p4n40ijtosxk/)\n- [https://ipfs.io/ipns/olivida.eth/](https://ipfs.io/ipns/olivida.eth/)\n\n![olivida-eth.png](olivida-eth.png)",
      "created" : 676394558.58041596,
      "externalLink" : "",
      "hasAudio" : false,
      "hasVideo" : false,
      "id" : "11BD26DD-A0C9-4B82-AB26-6E20E1CD2D51",
      "link" : "/11BD26DD-A0C9-4B82-AB26-6E20E1CD2D51/",
      "slug" : "",
      "title" : "IPNS"
    },
    {
      "articleType" : 0,
      "attachments" : [
        "export-planet.png"
      ],
      "cids" : {
        "export-planet.png" : "QmWdEibmGEpT5E3rtEEvst45ZCHNgESgrHv8z2ZmyiKgfb"
      },
      "content" : "目前 Planet 还处在一些非常大的变化中，因此时不时备份你的 IPNS key 是非常有必要的。在 0.6.* 版本中备份的操作方式是侧栏中选中自己的 Planet，然后从 Tools 菜单中按 Export Planet。\n\n![export-planet.png](export-planet.png)",
      "created" : 676258821.53371894,
      "externalLink" : "",
      "hasAudio" : false,
      "hasVideo" : false,
      "heroImage" : "https://olivida.eth.limo/A72693B7-095D-4EC2-8A7A-A730C68B467C/export-planet.png",
      "id" : "A72693B7-095D-4EC2-8A7A-A730C68B467C",
      "link" : "/A72693B7-095D-4EC2-8A7A-A730C68B467C/",
      "slug" : "",
      "title" : "关于备份 IPNS Key"
    },
    {
      "articleType" : 0,
      "attachments" : [

      ],
      "cids" : {

      },
      "content" : "如果你之前曾经尝试过去用 IPFS 发布一些东西给别人访问，那么你很可能已经体会过这个技术的慢。比如 ipfs.io 上的各种超时。\n\n因为这个技术的底层是 DHT，也就是类似 BitTorrent 和电驴下载的那种 P2P 技术。如果你曾经用过 BitTorrent 的 DHT 下载，你肯定也经历过刚开始下载的时候，漫长的找节点的过程。及就算是找到了节点之后，各种连不上或者没速度。作为使用同样基础技术的 IPFS，这些问题也同样存在于 IPFS。\n\n所以，如果使用场景场景是发布一些东西，然后让用户去浏览器中通过 ipfs.io 这样的 Public Gateway 去加载，那么很有可能就卡在那里直接卡超时了。Web 2.0 时代的 HTTP 已经被优化到了极致，但是 Public Gateway 的架构决定了那些优化到了 P2P 网络上并不完全适用。\n\n但是，当你在用本地电脑作为 IPFS 节点时，依然是可以有一些技术手段对发布性能进行优化的。\n\n## 端口转发\n\n你可以把你的公网 IP 的 4001 端口转发到你运行 Planet 的本地电脑上。\n\n## IPv6 的入流量\n\n如果你的运营商提供 IPv6 并且你知道怎么设置 IPv6 防火墙，那么你可以在防火墙上打开外部对 4001 端口的访问。\n\n## UPnP\n\n如果你的路由器支持 UPnP，那么打开 UPnP 支持可以允许 IPFS 节点更好地进行 P2P 通讯。\n\n---\n\n4001 端口是 IPFS 的 peer 流量端口，上面的所有操作是只读的。在公网上打开这个端口不会造成安全问题。但是部分入侵检测系统可能会抱怨，比如 UniFi Network 的 IDS 系统就会报告这个端口上有异常。",
      "created" : 676141683.32768297,
      "externalLink" : "",
      "hasAudio" : false,
      "hasVideo" : false,
      "id" : "930EAD16-718F-4553-87C8-F54FCCD1C4B1",
      "link" : "/930EAD16-718F-4553-87C8-F54FCCD1C4B1/",
      "slug" : "",
      "title" : "IPFS 的性能及优化"
    },
    {
      "articleType" : 0,
      "attachments" : [
        "set-content-hash.png",
        "brave-eth.png"
      ],
      "cids" : {
        "brave-eth.png" : "QmVKfomjh6DEXsQNA76N9s2nZX8iJQT4VLqH94MHTFUgWf",
        "set-content-hash.png" : "Qmb7eQKRCjeW6s8hLzUCpBdvHeZSsZNCnJVZ9z3wkDr6KL"
      },
      "content" : "[Planet](https://github.com/Planetable/Planet) 是一个开源的 macOS 原生 App，让你可以直接从自己的电脑上发布一个网站或者博客到 IPFS，并且这个网站或者博客可以绑定到一个 ENS 域名（比如 .eth 结尾）上。因为 IPFS 和 ENS 都是去中心化的，所以你发布的这个网站也是去中心化的。其他人可以通过这个 App 来 follow 你最新的更新，你的更新可以直接到达你的观众，不依赖一个中心化的云。\n\n目前这个 App 还处在一个非常早期的阶段，还有很多实现上的问题。我们会在后续继续更新。如果你之前玩过 IPFS 或者 ENS，那么你可能会想要试试这个完全的 GUI 体验的发布方案。\n\n## 开始使用\n\n在 App 第一次启动时，会自动 follow 下面的这两个 ENS：\n\n- vitalik.eth - Ethereum 的创始人之一\n- planetable.eth - Planet 项目的博客\n\n点击主界面下方的加号，就可以创建自己的 Planet。在创建并写了第一个篇文章之后，你的 Planet 就会被发布为一个 IPNS。右键点击侧栏里你的网站，选择 Copy IPNS。然后你就会在剪贴板中获得像这样的一串东西：\n\n`k51qzi5uqu5dgbfw2poynnynor8h9kqqoxmzdrxy4h4wnzx1x5p4n40ijtosxk`\n\n然后你把这串 IPNS 发给其他 Planet 用户，他们就可以收到来自你的更新了。\n\n你用 Planet 发布的网站，也可能可以通过各种 Public Gateway 访问，比如这是你当前正在阅读的这篇文章在各个 Gateway 上的地址（URL 拼接规则是 Public Gateway 域名 + /ipns/ + Planet.ipns + / + Article.UUID）：\n\n- [ipfs.io](https://ipfs.io/ipns/k51qzi5uqu5dgbfw2poynnynor8h9kqqoxmzdrxy4h4wnzx1x5p4n40ijtosxk/D2FC97F4-4F27-4FE2-A6BE-12C8DF44BBC1/)\n- [dweb.link](https://dweb.link/ipns/k51qzi5uqu5dgbfw2poynnynor8h9kqqoxmzdrxy4h4wnzx1x5p4n40ijtosxk/D2FC97F4-4F27-4FE2-A6BE-12C8DF44BBC1/)\n- [cf-ipfs.com](https://www.cf-ipfs.com/ipns/k51qzi5uqu5dgbfw2poynnynor8h9kqqoxmzdrxy4h4wnzx1x5p4n40ijtosxk/D2FC97F4-4F27-4FE2-A6BE-12C8DF44BBC1/)\n\n## 绑定 ENS\n\n你可以把 Planet 发布出来的 IPNS 设置为你的 ENS 域名的 Content Hash。这类似于在传统 DNS 中设置一条 A 记录。\n\n打开 app.ens.domains 然后在 Content 处填入你刚才获得的 IPNS，记得在前面加上协议 `ipns://`，就像下面截图中这样：\n\n![set-content-hash.png](set-content-hash.png)\n\n注意因为设定 Content Hash 会是一个 ENS 合约上的操作，所以这一步会有 gas 费。但是之后你在 Planet 里发布新的内容，你的 IPNS 不会发生改变，也不会再有 gas 费的问题。\n\n在完成了 ENS 绑定之后，也可以直接用类似下面这样的地址通过 Public Gateway 打开你的 ENS：\n\n- [https://ipfs.io/ipns/olivida.eth](https://ipfs.io/ipns/olivida.eth)\n- [https://olivida.eth.limo](https://olivida.eth.limo)\n\n在原生支持 IPFS 的 [Brave](https://www.brave.com) 浏览器里，你甚至可以用 ipns://olivida.eth 这样的地址直接打开你用 Planet 发布的网站。\n\n![brave-eth.png](brave-eth.png)\n\n记得在 Brave 设置中将 Method to resolve IPFS resources 设置为 Brave local IPFS node，这样你才可以通过真正的去中心化方式访问。\n\n**因为目前 Planet 还处在一些非常大的变化中，因此时不时备份你的 IPNS key 是非常有必要的。在 0.8+ 版本中备份的操作方式是侧栏中选中自己的 Planet，然后从右键菜单中选择 Export Planet。**\n\n## 一些已知问题\n\n由于 IPFS 的 DHT 本质，虽然你用 Planet 发布出来的 IPNS 可以通过 IPFS 的 Public Gateway 访问，但是第一次的速度可能会非常缓慢，甚至打不开。\n\n当你把 IPNS 发给其他人，让其他人 follow 你时，你的 App 必须处于打开状态，否则别人无法获得内容。当然，如果你熟悉 IPFS 的特性，那么你可以用 Pin 的方式加速和解决这个问题。关于 Pin 的优化，我们会在之后的文档中详细解释。每一个 follower 的获取更新时，也会做一个 pin 操作。因此如果一个内容的访问者越多，那么在 IPFS 网络中的性能也就会越好。\n\n你的网站内容每次更新时，所有 follow 你的人在获得更新时大概会是一个分钟级别的延迟。\n\n目前 Planet 里有一些地方允许你用 Public Gateway 去测试打开你发布的内容。我们目前使用的 Public Gateway 是 dweb.link，之后这个地方会变成一个可以更改的选项。\n\n另外值得说明的是，由于 IPFS 的 DHT 本质，所以是可以看到一条内容可以通过哪些 IP 提供服务。就像你通过 BitTorrent 下载时，你的 IP 也会被其他节点看到。\n\n## 开源及下载\n\nPlanet 的最新版本会在 planetable.xyz 的首页或者我们的 GitHub 项目首页提供。\n\n- [https://planetable.xyz](https://planetable.xyz)\n- [https://github.com/Planetable/Planet](https://github.com/Planetable/Planet)\n\n如果你遇到了什么问题，或者是想要新功能，可以在 GitHub 上以创建 issue 的方式提给我们。\n\n或者加入我们在 Telegram 上的中文用户群：\n\n[https://t.me/+5bl7FIsxeChlOWIz](https://t.me/+5bl7FIsxeChlOWIz)",
      "created" : 676112169.20437503,
      "externalLink" : "",
      "hasAudio" : false,
      "hasVideo" : false,
      "heroImage" : "https://olivida.eth.limo/D2FC97F4-4F27-4FE2-A6BE-12C8DF44BBC1/set-content-hash.png",
      "id" : "D2FC97F4-4F27-4FE2-A6BE-12C8DF44BBC1",
      "link" : "/D2FC97F4-4F27-4FE2-A6BE-12C8DF44BBC1/",
      "slug" : "",
      "title" : "Introducing Planet"
    },
    {
      "articleType" : 0,
      "attachments" : [

      ],
      "cids" : {

      },
      "content" : "按照两个月之前的计划，在 2022 年 6 月 1 日这天上线了 [planetable.xyz](https://planetable.xyz)\n\n这一年一直在想的就是，如果我能够有机会，把一个 idea 给完整地执行出来会怎样。现在这个机会就这样正在实现中，我很感激走过来的每一步。\n\n如果每一个细节背后，都能够有足够的思考和设计，那结果就不会是一个赶着上线的垃圾，而是在很多年之后，你甚至都会想去高清重制它。\n\n我们生活在这样的一个千兆网络、高速 SSD、多核 CPU 逐渐变成日常用品的时代。未来已经到来，只是没有均匀分布。Planet 就是这个时代的一种全新的互联网内容创作和分发的试验。",
      "created" : 675894157.03691494,
      "externalLink" : "",
      "hasAudio" : false,
      "hasVideo" : false,
      "id" : "29381FD0-9C8F-485B-A51D-A33310168319",
      "link" : "/29381FD0-9C8F-485B-A51D-A33310168319/",
      "slug" : "",
      "title" : "Hello World"
    }
  ],
  "created" : 675894069.49131298,
  "githubUsername" : "livid",
  "id" : "4C515DC7-CE8C-4FCD-9B95-4FAE9D63F214",
  "ipns" : "k51qzi5uqu5dgbfw2poynnynor8h9kqqoxmzdrxy4h4wnzx1x5p4n40ijtosxk",
  "juiceboxEnabled" : true,
  "juiceboxProjectID" : 471,
  "mastodonUsername" : "@livid@mastodon.world",
  "name" : "olivida.eth",
  "plausibleAPIServer" : "plausible.io",
  "plausibleDomain" : "olivida.eth.limo",
  "plausibleEnabled" : true,
  "podcastCategories" : {
    "Technology" : [

    ]
  },
  "podcastExplicit" : false,
  "podcastLanguage" : "zh-CN",
  "telegramUsername" : "olivida",
  "twitterUsername" : "livid",
  "updated" : 713331607.56220102
}