-
Notifications
You must be signed in to change notification settings - Fork 597
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
NIP-106 Decentralized Web Hosting on Nostr #811
base: master
Are you sure you want to change the base?
Conversation
} | ||
``` | ||
|
||
Moreover, internal links within the `content` should be assigned NIP-33 identifiers instead of event IDs. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Will internal links change to NIP-21 naddr
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes. All internal links will be replaced with naddr format.
- HTML: `kind: 5392` | ||
- CSS: `kind: 5393` | ||
- JS: `kind: 5394` |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm not going to make a noise, but I feel like don't need regular events.
Co-authored-by: Asai Toshiya <to.asai.60@gmail.com>
Copy edits
NIP-106 Decentralized Web Hosting on Nostr
By recording HTML, CSS, and JS on the Nostr relay, it becomes possible to create a decentralized web hosting solution that eliminates the need for centralized servers. Web servers or Nostr clients retrieve these recorded data, transform them into appropriate forms, and deliver them.
Reasons for Hosting on Nostr
Proposed Approach
Each HTML, CSS, and JS file is assigned a
kind
for identification.kind: 5392
kind: 5393
kind: 5394
The "content" field contains the content of the file. However, internal links (
href
,src
, etc.) referenced within should be replaced with event IDs.Example:
<link rel="stylesheet" href="066b7ca0b167f0adad5c6d619ab1177050423e3979e83b8dfa069992533bdcf5">
Implementation on Web Server or Client
Access events using
/e/{nevent}
. Since eventnevent
are specified for each internal link, opening an HTML file enables automatic retrieval of data from this endpoint.By using
nevent
, you can expedite the retrieval of relay information by including it internally, which offers the advantage of speed. However, it is also acceptable to implement the retrieval in the usual hex format as an option.Implementation Example (Golang)
Replaceable Decentralized Web Hosting
Additionally, this proposal can be extended to incorporate the NIP-33 based decentralized web hosting specification. This allows tracking of website data with a single identifier, keeping URL paths immutable.
Following the NIP-33 specification, the
kind
would be as follows.kind: 35392
kind: 35393
kind: 35394
Identifiers must be included within the
d
tag.Example
Moreover, internal links within the
content
should be assigned NIP-33 identifiers instead of event IDs.Identifier Format
[html_identifier][filepath]
Example:
hostr-lp
hostr-lp/assets/index-ab834f60.css
Implementation on Web Server or Client
Events can be accessed through
/p/{author_hex}/d/{d_tag}
.Implementation Example (Golang)
Web Server Implementation Vulnerabilities
The current web server implementation allows access to websites within a single domain. While this reduces the implementation complexity on the server side and provides resilience against blocking, it is not suitable for use with domain-based authorization systems (such as NIP-07). For instance, if signing is permitted for Nostr clients on the web hosting relay, it would grant permission for all web pages hosted on that relay, making it vulnerable to spam postings.
Implementation
Repository: https://github.com/studiokaiji/nostr-webhost
Example Implementation: https://h.hostr.cc/p/a5a44e2a531efcc86491c4b9a3fa67daee8f60c9d2757a12eed95d98c5d6fc42/d/hostr-lp