Why Nostr? What is Njump?
2024-03-11 05:47:44

CXPLAY on Nostr: 最近 Amethyst 引入了一个给 Nostr 笔记再 "编辑" 的功能(就像 Twitter ...

最近 Amethyst 引入了一个给 Nostr 笔记再 "编辑" 的功能(就像 Twitter 那样的). 但是社区很多人认为为短文本消息(kind:1)的再编辑是徒增复杂性, 本身 "删除" 功能就是一种 "看起来有用" 的实现, 再编辑只是这种做法的延续.
目前 Nostr 允许内容互相替换的只有 kind:30023 (参数化可替换事件), 如果再引入编辑功能可能会继续影响事件的传递和检索效率(服务端一侧).
FWIW, I think deletions on Nostr are a "meh" idea and edits are a bad idea. Consider the following:

- It's an additional layer of complexity. Nostr should arguably be simpler and it's already more complex in some ways centralized platforms are not.
- Different relays will disagree on whether to accept the edit or the delete event, so the original note may stay available. It may also become apparently unavailable and then available again in the future. Someone could send the old version to relays you don't use.
- Unlike some specific features like articles, zaps and whatever one can think of, it only makes sense if consistently implemented, but that's something we can only assume to be true of NIP-01.
- It makes retrieving a note less efficient. You now need to wait a response from all relays, just in case one of them has a deletion or a modification the first one to reply doesn't have.
- There is value in having modifications, but there is also value in having platforms that don't allow modifications, IMO, where an ID truly identifies a specific piece of text and nothing else. Now that Twitter allows modifications, Nostr can use the fact that it doesn't to diversify itself so as to convince users to use both (otherwise the network effect plays against Nostr).

On centralized platforms which allow modifications, users sometimes write a post with the plan of modifying it later. On Nostr that would be a bad pattern, however and I think the modification features can lead to bad usage of Nostr and, therefore, a bad user experience.

Ultimately it will prevail if clients and relays implement it and fail otherwise, but I'm not in favor of it.
Author Public Key
npub1gd8e0xfkylc7v8c5a6hkpj4gelwwcy99jt90lqjseqjj2t253s2s6ch58h