-
Notifications
You must be signed in to change notification settings - Fork 602
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-54: Inline Image Metadata #478
Conversation
I think this is a terrible hack that duplicates hashes and metadata across all kind-1s that cite the same URL. How many tag properties can be added? We need space for 5 at the least, but the default will have more once we add license attributes. {
"content": "More image metadata tests don’t mind me https://nostr.build/i/863321bb1ae68830ebcf9a343ca0a5e0ce2323d0a55b7fbe86f7a886cf61db8d.jpg ",
"kind": 1,
"tags": [
[
"imeta",
"url https://nostr.build/i/863321bb1ae68830ebcf9a343ca0a5e0ce2323d0a55b7fbe86f7a886cf61db8d.jpg",
"blurhash eVF$^OI:${M{o#*0-nNFxakD-?xVM}WEWB%iNKxvR-oetmo#R-aen$",
"dim 3024x4032",
"description <accessibility descriptor with spaces>"
"decryptionKeys <secret> <nonce>"
"license <CC, CC-atribution, etc>"
]
]
} Needless to say, the encoding of A quoted NIP-94 event inside a regular kind-1 is a superior engineering solution, IMHO. |
disagree. clients might not care to re-use urls across posts .
nip01 doesn't specify a limit but, I think some relays do something like 256 ? lots of room.
This is for clients that are not planning on implementing nip-94 like damus |
You know, I think I'm with Vitor on this one. Composition is amazingly powerful. If clients can make rendering generic you get all kinds of neat emergent behavior (e.g. quoted kind-1's in DMs). The main objection to NIP-94 was latency, right? Maybe we could do something similar to 9735's where the kind-1063 can be optionally provided in a tag, e.g. This could also be a useful mechanism for reducing flakiness of quotes — if you're quoting an event, the client could provide the entire quoted event using |
damus is not implementing nip-94, this is for clients who want a simpler self-contained option. this is unrelated to nip94, and as that is starting to be used to enable storing data on relays (nip95) I want nothing to do with it. not to mention it is backwards incompatible with urls and doing something like an embedded nip94 is very bloaty and carries extra signatures for no reason. |
My suggestion is as self-contained as the new NIP, if a little more verbose, and it re-uses an existing part of the protocol, decreasing implementation surface area, and enabling new emergent behavior. More options = less simplicity. |
I'm a huge fan of this idea. In my perfect world attachments wouldn't be present in the content at all, and we'd include tags like this instead: {
"content": "More image metadata tests don’t mind me",
"kind": 1,
"tags": [
[
"media",
"image/jpeg",
"https://nostr.build/i/863321bb1ae68830ebcf9a343ca0a5e0ce2323d0a55b7fbe86f7a886cf61db8d.jpg",
"blurhash eVF$^OI:${M{o#*0-nNFxakD-?xVM}WEWB%iNKxvR-oetmo#R-aen$",
"dim 3024x4032"
]
]
} (mime type and url are positional and required, other arguments are named and optional) However if we're set on including the URL in the content, I think this is a decent solution. I would just try to generalize it to other kinds of attachments such as videos, and ideally be able to handle whatever else you could throw at it like PDFs etc. {
"content": "More image metadata tests don’t mind me https://nostr.build/i/863321bb1ae68830ebcf9a343ca0a5e0ce2323d0a55b7fbe86f7a886cf61db8d.jpg ",
"kind": 1,
"tags": [
[
"mmeta",
"mime image/jpeg",
"url https://nostr.build/i/863321bb1ae68830ebcf9a343ca0a5e0ce2323d0a55b7fbe86f7a886cf61db8d.jpg",
"blurhash eVF$^OI:${M{o#*0-nNFxakD-?xVM}WEWB%iNKxvR-oetmo#R-aen$",
"dim 3024x4032"
]
]
}
|
good call on mime, will add |
mmeta too, this makes sense |
hmm well mime+mmeta start to feel a lot like nip94 at that point.. maybe it's worth keeping imeta small and concise for images... |
How about skipping tags if you want it contained? {
"content": "More image metadata tests don’t mind me https://nostr.build/i/863321bb1ae68830ebcf9a343ca0a5e0ce2323d0a55b7fbe86f7a886cf61db8d.jpg#blurhash=eVF$^OI:${M{o#*0-nNFxakD-?xVM}WEWB%iNKxvR-oetmo#R-aen$&dim=3024x4032 ",
"kind": 1,
"tags": []
} The URL got the meta data after a Edit: In this event I added the
|
I already have enough trouble parsing URLs, I don't want to do more of that. |
Interesting idea! They would make the url look pretty bad for clients that don't support this. The tag approach seemed friendlier. plus it could get really ugly once we started adding more and more metadata fields 🤔 |
@jb55 @staab Clients that don't support this do not really care. Current day Snort handling https://snort.social/e/note10a7rpdvms04pdzp3k3dsvp0nqs7edzzuujs5v2phgawzpfchk6gs3f92nl without problem. Note that I did url-encode stuff, apparently correctly. |
Image handling in text clients wasn't really a consideration of mine but wouldn't they ellipse shorten urls anyway? And the more technical would show the tags, so ... I'm not sure what is gained by moving this to tags. |
definitely an interesting approach, I would have to change my code and see if its simpler. it likely is 🤔, then you wouldn't have to duplicate the url in tags. |
ok I'm leaning toward switching to this approach. I really like it. great idea @Giszmo |
@jb55 glad I could help. A mention as co-author would be appreciated. |
@Giszmo's idea is at least easier for users to copy and paste with all the attached metadata so the user doesn't need to retype accessibility descriptors every time and the app doesn't need to compute hashes again. The current one requires custom copy paste code to move all tags of one URLs into a new kind 1. I still think NIP-94 is superior. Just copy |
ah crap there is one issue for me here. The tags approach allows me to start building blurhash images immediately when I receive the note over the wire (a slow operation so I need to queue it immediately). I don't do any content parsing when I receive notes since that could be potentially slow if I do it for every note I receive over the wire, since most won't be seen. ugh! |
I like @Giszmo 's approach: I was thinking of an 'nimage1' bech encoded tlv thing (to avoid duplicating the URL in the tags) until I read @Giszmo 's note and realized that his suggestion tops that because it is backwards compatible to all the clients. And URL fragments are client-side with no participation from the web server, so this works very well. URL encoding/decoding libraries are widely available and it is a well known art. We are already stuck with early content parsing: As for @jb55 's performance issue: Until recently I wasn't doing content parsing immediately on incoming events either, but once embedded 'nevent' links became a thing, I started doing that content parsing on all incoming events (just once, cached) so that I could start fetching these referenced events immediately. So now that I am doing content parsing anyways, I don't mind this data being in the content. |
@mikedilger yeah if I were to change this I would have to move content parsing to all events... I would have to test how this affects battery and performance on mobile devices which are more resource constrained than something like gossip :( |
I don't think this is necessarily true. Damus lazily parses and fetches this information when we are about to scroll into view. |
I could try this with blurhash but I notice is was pretty slow and didn't want it popping in, but I can experiment with that. |
Don't forget to percent-encode. |
in damus I will just include my old variant and remove it once I've managed to make it work with the new one, but send both 🤔 |
I hear you. @bu5hm4nn argued against nevent embedded for that very reason. We didn't even want to parse every note on the desktop and weren't even thinking about limited phone resources. |
I like the tag approach more than the giant URL approach. |
Is it a dumb idea to use an offset index to refer to where in the content the media reference is? #319 (comment) |
I think this is a bit unnecessary, NIP94 can already do this |
do we have an alt-text spec ? maybe image optimization is too specific. this would be a great place for alt text |
it also requires extra REQs... by that time you could have already loaded the image most likely |
Not a big deal. We load quoted events all the time. This has already been optimized. |
ok all updated, added alt-text |
You mean something like File Metadata? |
To be clear, I don't think hash, alt-text, and any other metadata should be in this spec. This is not a replacement for file metadata, otherwise there would be way too many fields in these tags. |
I am not implementing nip94 so this makes the most sense to me. clients can choose to ignore those fields if they are using nip94, but I still think nip94 is a separate use case than inline image metadata. |
do you have anything better to do? |
Inline image metadata is additional information associated with urls in notes that clients can use to provide a better experience when loading images.
Clarified the difference between this and NIP94: 3c5c49b |
renamed to "Inline Image Metadata" to clarify this even further |
What if we create a NIP that requires future NIPs to backwards compatible? 🤔 Or that a backwards incompatible NIP needs to meet certain criteria (like a vote or something)? It seems that there a lot of implicit assumptions about backwards compatibility that aren't common and aren't explicit. |
It's usually never a problem, urls are a weird edge case where almost all standardized on using image URLs because it made the most sense. It is not really a spec per say, it's just a thing that all clients do. Markdown in kind1 was another one of those things that has subjective rendering which is why damus eventually removed it. |
So, it's not about Image Loading Optimization thing anymore? Looks like we are back to being a copy cat of NIP-94. |
this is for inline image metadata where some fields can be used for loading optimization yes |
it has all the same data as before, you can ignore the alt-text if you find it offensive. |
Then it should not be positional anymore. There are too many inline image metadata options for people to agree on an ordering scheme. It will be a mess. Keep it simple, solve your optimization needs, and address the rest of the tags outside an optimization context. |
this is exhausting. ya'll are wasting my time. I'm closing this and my interest in submitting new NIPs has gone to 0. if anyone else wants to pick this up then so be it. please do not implement this as it is no longer what damus implements. |
I will be uploading the old version of the spec at https://github.com/damus-io/dips if any other clients are interested in using this information in their clients. |
Well, you folks know we are using NIP94 directly for all kinds of metadata. I am still open to implementing something that makes sense for regular URLs as long as it doesn't end up creating a duplicated structure. |
Are there any other edge cases that should be clarified, so that future NIPs don't mess with them (or everyone agrees that messing with the edge case is fine)? |
Inline Image metadata is additional information associated with urls in notes that
clients can use to provide a better experience when loading images.