💾 Archived View for gemini.ucant.org › notes › misfin-meeting.gmi captured on 2024-09-29 at 00:32:07. Gemini links have been rewritten to link to archived content

View Raw

More Information

⬅️ Previous capture (2024-02-05)

-=-=-=-=-=-=-

Misfin meeting on IRC

Time: 18:00ish GMT on 2023-12-31

Venue: ##misfin on libera.chat

Participants:

Overview

An informal discussion re the future of Misfin protocol, given the apparent absence of the originator ("Lem"). The meeting is without prejudice to any future governance arrangements for the protocol.

This doc will be updated as the meeting proceeds.

Content length

It was proposed, but definitely not yet accepted, to break backward compatibility by providing content length thus:

"misfin://<MAILBOX>@<HOSTNAME><TAB><CONTENT-LENGTH><CR><LF><MESSAGE><CR><LF>"

counterproposal:

18:33 <@clseibold> So, if we're breaking back-compat, and we want 
                   content-length to be optional, then I think your proposal is 
                   that we add a tab to tell the server that there's a 
                   content-length coming, and if there's not, then we could 
                   just use a space. So here's my tweaking of your proposal:
18:33 <@clseibold> With Content Length: 
misfin://<MAILBOX>@<HOSTNAME><TAB><CONTENT-LENGTH><SPACE><MESSAGE><CR><LF>
18:33 <@clseibold> Without Content Length: 
                   misfin://<MAILBOX>@<HOSTNAME><SPACE><MESSAGE><CR><LF>
19:39 <@mk270> (this can make the detection of end-of-message more reliable / easier to implement for those with weak TLS libraries)

resolved nem con: to go with the counterproposal of optional length

Max content length

proposed for 16K

Misfintext

(it is proposed to reword the spec to clarify how the header interacts with gemtext, without changing the semantics of misfin)

18:01 <@clseibold> So like, all we're really doing here is dividing the message 
                   body from the header format.
18:01 <@clseibold> To demonstrate:
18:01 <@clseibold> ---- misfintext header here ------
18:01 <@clseibold> > sender
18:01 <@clseibold> < receiver
18:01 <@clseibold> ---- gemtext body below here ----
18:01 <@clseibold> [gemtext body]
18:01 <@clseibold> Same format as what we currently have, we just divide and 
                   use different parsers for the two sections

(see below in next section for actual agreed proposal)

Inextensible metadata

was proposed by jmjl - how to implement?

ban commas from email address tags

exclude metadata from content length

20:28 <@clseibold> Here's my proposal for changing the misfin linetypes:
20:28 <@clseibold> address1 sender1_name, address2 sender2_name
20:28 <@clseibold> recipient_address1, recipient_address2
20:28 <@clseibold> timestamp1, timestamp2

A conversion tool can be provided for users of the old metadata format

Backwards compat

we should mandate that all new clients require the content length?

But all servers have to handle when there's no content length

yeah - the server is allowed to accept old metadata if the client sends no contentlength

but new clients must send contentlength

Message IDs

can be based on a hash of the senders, recipients and body, ignoring timestamps.

A server can calculate this. No need to change the wire format.

This is not going to be done immediately, but is for future ongoing discussion.

Known existing software

Clients

clseibold's misfinmail, reference implementation, cipres' fork, and gemalaya browser

Servers

clseibold's misfin-server, reference implementation, cipres' fork, miselfin, Dory, and I think there's a few other servers too.

Status

The original Lem spec is under a CC licence:

https://git.sr.ht/~lem/misfin/tree/master/item/COPYING

It was agreed that our document should include this by reference rather than inclusion, and be a "proposal" rather than any kind of usurpation.

The draft ID will be: e82fa2e9-a8e9-44f5-924c-77301643f5c2

Draft proposal by jmjl