Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • World
  • Users
  • Groups
Skins
  • Light
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
We Distribute
  1. Home
  2. Technical Discussion
  3. I have deeply mixed feelings about #ActivityPub's adoption of JSON-LD, as someone who's spent way too long dealing with it while building #Fedify.

I have deeply mixed feelings about #ActivityPub's adoption of JSON-LD, as someone who's spent way too long dealing with it while building #Fedify.

Scheduled Pinned Locked Moved Technical Discussion
fedifyjsonldfedidevactivitypub
168 Posts 35 Posters 286 Views
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • mat@friendica.exon.nameM mat@friendica.exon.name

    @hongminhee @julian I'm a true believer in RDF from back in the day, so I'm hardly neutral. But...

    There are essentially no interesting ActivityPub extensions right now. Even Evan's chess example, no-one's actually using AP to play chess. It's just ActivityStreams + a few cute tricks now and then. Even if there were extensions, existing AP servers chop off and throw away data they don't understand. so none of these extensions could work.

    I feel like most of the "WTF am I learning JSON-LD for" criticisms are coming from this status quo. That includes "if someone wants to add a gallery thing or whatever, can't they make a FEP?" The way things work now, your extension either a) works only in your software or b) has to be painfully negotiated with the whole community. We're all gonna have a big fight about it on this forum anyway. Let's not pretend JSON-LD helps us.

    But if we add two things to the mix, the situation looks different. Those are 1. server software that "keeps all the bits", and 2. a whitelabel extensible app. That would make it very easy to spin up crazy new experiences for a sizeable existing userbase. Developers should not be forced to endure a FEP process, and they should not have to attract a userbase from nothing. They should be able to just build, without even worrying if they're stepping on toes. And of course, Fedify and libraries in other languages are a load-bearing part of that world, including enforcement of the JSON-LD rules.

    That world does not exist at all today, but JSON-LD does, so it's pretty valid to describe this design as premature optimisation. I dunno though, we don't seem that far away.

    julian@activitypub.spaceJ This user is from outside of this forum
    julian@activitypub.spaceJ This user is from outside of this forum
    julian@activitypub.space
    wrote last edited by
    #15

    @mat@friendica.exon.name that's a really interesting point of view, and has some parallels to how app development on the ATProto side is easier in many ways.

    I do think that this is something C2S (aka the ActivityPub API) can enable.

    I am critical of JSON-LD but I do certainly recognize I could be very wrong 😁

    1 Reply Last reply
    1
    • sl007@digitalcourage.socialS This user is from outside of this forum
      sl007@digitalcourage.socialS This user is from outside of this forum
      sl007@digitalcourage.social
      wrote last edited by
      #16

      @julian @mat

      Do you know about the backgrounds of the immers project ?
      , "no-one's actually using AP to play chess"
      the reason that we have noa AP chess service _anymore_ is #uspol …

      This all feels very unfair somehow cause I know the backgrounds but anyway …
      While we 2 days ago had a long thread about our use of Chess Games I will link the video from the thread https://digitalcourage.social/@sl007/116023149133783002

      immers with its federated locations and positional audio etc was supernice for playing chess !
      Our use is fairly similar and straightforward like we did the chess Social CG meeting in 2018 and the rc3 (usually 18.000 people physically but here it was virtually cause pandemics) https://socialhub.activitypub.rocks/t/rc3-chaos-communication-congress/1202

      Maybe it would really be fair if people are new to look into the 20 years Social CG history where some volunteers really gave much work 🙂
      🧵 1/2

      sl007@digitalcourage.socialS 1 Reply Last reply
      0
      • mat@friendica.exon.nameM This user is from outside of this forum
        mat@friendica.exon.nameM This user is from outside of this forum
        mat@friendica.exon.name
        wrote last edited by
        #17
        @julian I don't know as much as I'd like about AT Lexicons. That is, not so much how they work, but what the grand idea is? I don't even understand if Bluesky imagines them being mixed and matched JSON-LD style. I think not?
        liaizon@social.wake.stL 1 Reply Last reply
        0
        • sl007@digitalcourage.socialS sl007@digitalcourage.social

          @julian @mat

          Do you know about the backgrounds of the immers project ?
          , "no-one's actually using AP to play chess"
          the reason that we have noa AP chess service _anymore_ is #uspol …

          This all feels very unfair somehow cause I know the backgrounds but anyway …
          While we 2 days ago had a long thread about our use of Chess Games I will link the video from the thread https://digitalcourage.social/@sl007/116023149133783002

          immers with its federated locations and positional audio etc was supernice for playing chess !
          Our use is fairly similar and straightforward like we did the chess Social CG meeting in 2018 and the rc3 (usually 18.000 people physically but here it was virtually cause pandemics) https://socialhub.activitypub.rocks/t/rc3-chaos-communication-congress/1202

          Maybe it would really be fair if people are new to look into the 20 years Social CG history where some volunteers really gave much work 🙂
          🧵 1/2

          sl007@digitalcourage.socialS This user is from outside of this forum
          sl007@digitalcourage.socialS This user is from outside of this forum
          sl007@digitalcourage.social
          wrote last edited by
          #18

          @julian @mat

          We implemented this standard and you can create / describe your rooms [Place, `redaktor:fictional`] and the chessboard is just a geohash as described in the geosocial CG so the use is the same, just `redaktor:fictional` too,
          You load the Collection of Chessfigures (pawn1 ...) can name them, they `Travel` over the chessboard ant the `Arrive` describes the `result`.
          As always you can get very detailed with wikidata properties and entities but bare AS Vocabulary is enough.
          In the end you have a Collection for the Travels which is your played game which you can replay or do whatever with.

          But you can still install immers - it is worth a try https://github.com/immers-space

          The reason for its end are the same as for the gup.pe groups and I hope people konw about it …

          mat@friendica.exon.nameM 1 Reply Last reply
          0
          • mariusor@metalhead.clubM mariusor@metalhead.club

            > while linked data cultists harass developers about nonresolvable URLs

            @silverpill I don't consider myself a cultist but I still think that putting invalid URLs in any payload where they are supposed to be meaningful is disrespectful towards anyone that consumes your API. Please don't do that.

            @hongminhee

            silverpill@mitra.socialS This user is from outside of this forum
            silverpill@mitra.socialS This user is from outside of this forum
            silverpill@mitra.social
            wrote last edited by
            #19

            @mariusor @hongminhee The @context is not supposed to be required in the first place, but here we are adding it to every activity and wasting bandwidth because Mastodon developers didn't read the spec.

            mariusor@metalhead.clubM 1 Reply Last reply
            0
            • sl007@digitalcourage.socialS sl007@digitalcourage.social

              @julian @mat

              We implemented this standard and you can create / describe your rooms [Place, `redaktor:fictional`] and the chessboard is just a geohash as described in the geosocial CG so the use is the same, just `redaktor:fictional` too,
              You load the Collection of Chessfigures (pawn1 ...) can name them, they `Travel` over the chessboard ant the `Arrive` describes the `result`.
              As always you can get very detailed with wikidata properties and entities but bare AS Vocabulary is enough.
              In the end you have a Collection for the Travels which is your played game which you can replay or do whatever with.

              But you can still install immers - it is worth a try https://github.com/immers-space

              The reason for its end are the same as for the gup.pe groups and I hope people konw about it …

              mat@friendica.exon.nameM This user is from outside of this forum
              mat@friendica.exon.nameM This user is from outside of this forum
              mat@friendica.exon.name
              wrote last edited by
              #20

              @sl007 @julian I admit I didn't pay attention to immers at the time - I don't play games, not even chess. I was just using chess as an example, didn't mean to trigger anyone's trauma!

              Still, it kinda proves my point. You have to use standard AS vocabulary because Mastodon, and if you squint then sure, Travel and Arrive, why not? But given some of the conversations I've seen on this forum, I shudder to think how that would go down if you tried to get approval for that usage from "the community" first.

              sl007@digitalcourage.socialS 2 Replies Last reply
              0
              • mat@friendica.exon.nameM mat@friendica.exon.name

                @sl007 @julian I admit I didn't pay attention to immers at the time - I don't play games, not even chess. I was just using chess as an example, didn't mean to trigger anyone's trauma!

                Still, it kinda proves my point. You have to use standard AS vocabulary because Mastodon, and if you squint then sure, Travel and Arrive, why not? But given some of the conversations I've seen on this forum, I shudder to think how that would go down if you tried to get approval for that usage from "the community" first.

                sl007@digitalcourage.socialS This user is from outside of this forum
                sl007@digitalcourage.socialS This user is from outside of this forum
                sl007@digitalcourage.social
                wrote last edited by
                #21

                @mat Has a reason, just wrote it to @julian in a DM, just didn't want to post public.

                Not sure if you visited the link. This _was_ the community approval …
                Immers was famous and we had some official Social CG meetings where I linked one where thousands of community people attended (?)
                The W3C Social CG _is_ the Community (?)
                Meanwhile even Public Spaces Incubator uses it which is to my best knowledge the largest upcoming iimplementor by far.
                I mean apart from that it is pretty obvious after the meeting where we talked about "factual" vs "fictional".
                mastodon has nothing to do with this. The majority of projects count in a democracy. We had a demo playing chess between 4 softwares.

                Doing the official AP Conf and becoming elected Policy Lead, I had always asked the community. For 20 years 😞
                https://conf.tube/c/apconf_channel/videos

                Not sure if anyone did read the "Conformance Section" of ActivityPub. https://www.w3.org/TR/activitypub/#conformance
                It is section 2 - You have to support "The Entirety"...
                If mastodon does not it is not ActivityPub.

                1 Reply Last reply
                0
                • lkanies@hachyderm.ioL This user is from outside of this forum
                  lkanies@hachyderm.ioL This user is from outside of this forum
                  lkanies@hachyderm.io
                  wrote last edited by
                  #22

                  @hongminhee @jalefkowit huh. I’ve been pondering using it for some projects of mine, so this is good to know.

                  Is it a fundamental problem with JSON-LD, such that it should just be avoided, or a problem with how ActivityPub uses it?

                  And is there something else you’d recommend that fulfills the same goals?

                  hongminhee@hollo.socialH 1 Reply Last reply
                  0
                  • mat@friendica.exon.nameM mat@friendica.exon.name

                    @sl007 @julian I admit I didn't pay attention to immers at the time - I don't play games, not even chess. I was just using chess as an example, didn't mean to trigger anyone's trauma!

                    Still, it kinda proves my point. You have to use standard AS vocabulary because Mastodon, and if you squint then sure, Travel and Arrive, why not? But given some of the conversations I've seen on this forum, I shudder to think how that would go down if you tried to get approval for that usage from "the community" first.

                    sl007@digitalcourage.socialS This user is from outside of this forum
                    sl007@digitalcourage.socialS This user is from outside of this forum
                    sl007@digitalcourage.social
                    wrote last edited by
                    #23

                    @mat
                    Just btw, this is 7 years old https://www.reddit.com/r/chess/comments/94ubnd/chess_over_activitypub/ but anyway

                    However, given that I have, including immers and redaktor, at least 3 apps where I can use the first chess spec.:
                    if more than 2 implementations will also support this second chess specification, I will do so too.

                    @julian

                    1 Reply Last reply
                    0
                    • lkanies@hachyderm.ioL lkanies@hachyderm.io

                      @hongminhee @jalefkowit huh. I’ve been pondering using it for some projects of mine, so this is good to know.

                      Is it a fundamental problem with JSON-LD, such that it should just be avoided, or a problem with how ActivityPub uses it?

                      And is there something else you’d recommend that fulfills the same goals?

                      hongminhee@hollo.socialH This user is from outside of this forum
                      hongminhee@hollo.socialH This user is from outside of this forum
                      hongminhee@hollo.social
                      wrote last edited by
                      #24

                      @lkanies@hachyderm.io @jalefkowit@vmst.io To be honest, I'm not too sure myself. I just know that JSON-LD was originally planned as a foundation for the Semantic Web. I can only guess that if ontology is useful in a certain area, then JSON-LD would probably be useful there too.

                      1 Reply Last reply
                      0
                      • evan@cosocial.caE This user is from outside of this forum
                        evan@cosocial.caE This user is from outside of this forum
                        evan@cosocial.ca
                        wrote last edited by
                        #25

                        @hongminhee do you use the activitystrea.ms module from npm? It takes a lot of the pain out.

                        hongminhee@hollo.socialH 1 Reply Last reply
                        0
                        • evan@cosocial.caE This user is from outside of this forum
                          evan@cosocial.caE This user is from outside of this forum
                          evan@cosocial.ca
                          wrote last edited by
                          #26

                          @hongminhee I agree that new developers should use a JSON-LD processor. It saves a lot of heartache.

                          1 Reply Last reply
                          0
                          • evan@cosocial.caE evan@cosocial.ca

                            @hongminhee do you use the activitystrea.ms module from npm? It takes a lot of the pain out.

                            hongminhee@hollo.socialH This user is from outside of this forum
                            hongminhee@hollo.socialH This user is from outside of this forum
                            hongminhee@hollo.social
                            wrote last edited by
                            #27

                            @evan@cosocial.ca I don't remember exactly, but I think I came across it while doing research before developing Fedify. I probably didn't use it because the TypeScript type definitions were missing. In the end, I ended up making something similar in Fedify anyway.

                            1 Reply Last reply
                            0
                            • silverpill@mitra.socialS silverpill@mitra.social

                              @mariusor @hongminhee The @context is not supposed to be required in the first place, but here we are adding it to every activity and wasting bandwidth because Mastodon developers didn't read the spec.

                              mariusor@metalhead.clubM This user is from outside of this forum
                              mariusor@metalhead.clubM This user is from outside of this forum
                              mariusor@metalhead.club
                              wrote last edited by
                              #28

                              @silverpill I'm sorry, I'm not aware of that and I thought I read the specs pretty thoroughly. Could you point me in the right direction for where you got this information from?

                              @hongminhee

                              silverpill@mitra.socialS 1 Reply Last reply
                              0
                              • varpie@peculiar.floristV This user is from outside of this forum
                                varpie@peculiar.floristV This user is from outside of this forum
                                varpie@peculiar.florist
                                wrote last edited by
                                #29

                                @hongminhee I have the same feeling. The idea behind JSON-LD is nice, but it isn't widely available, so developing with it becomes a headache: do I want to create a JSON-LD processor, spending twice the time I wanted to, or do I just consider it as JSON for now and hope someone will make a JSON-LD processor soon? Often, the answer is the latter, because it's a big task that we're not looking for when creating fedi software.

                                1 Reply Last reply
                                0
                                • mariusor@metalhead.clubM mariusor@metalhead.club

                                  @silverpill I'm sorry, I'm not aware of that and I thought I read the specs pretty thoroughly. Could you point me in the right direction for where you got this information from?

                                  @hongminhee

                                  silverpill@mitra.socialS This user is from outside of this forum
                                  silverpill@mitra.socialS This user is from outside of this forum
                                  silverpill@mitra.social
                                  wrote last edited by
                                  #30

                                  @mariusor @hongminhee

                                  @context is a recommendation, not a requirement.

                                  ActivityPub:

                                  Link Preview Image
                                  ActivityPub

                                  The ActivityPub protocol is a decentralized social networking protocol based upon the [ActivityStreams] 2.0 data format. It provides a client to server API for creating, updating and deleting content, as well as a federated server to server API for delivering notifications and content.

                                  favicon

                                  (www.w3.org)

                                  Implementers SHOULD include the ActivityPub context in their object definitions.

                                  ActivityStreams:

                                  Link Preview Image
                                  Activity Streams 2.0

                                  favicon

                                  (www.w3.org)

                                  Implementations producing Activity Streams 2.0 documents SHOULD include a @context property with a value that includes a reference to the normative Activity Streams 2.0 JSON-LD @context definition using the URL " https://www.w3.org/ns/activitystreams".

                                  mariusor@metalhead.clubM 1 Reply Last reply
                                  0
                                  • silverpill@mitra.socialS silverpill@mitra.social

                                    @mariusor @hongminhee

                                    @context is a recommendation, not a requirement.

                                    ActivityPub:

                                    Link Preview Image
                                    ActivityPub

                                    The ActivityPub protocol is a decentralized social networking protocol based upon the [ActivityStreams] 2.0 data format. It provides a client to server API for creating, updating and deleting content, as well as a federated server to server API for delivering notifications and content.

                                    favicon

                                    (www.w3.org)

                                    Implementers SHOULD include the ActivityPub context in their object definitions.

                                    ActivityStreams:

                                    Link Preview Image
                                    Activity Streams 2.0

                                    favicon

                                    (www.w3.org)

                                    Implementations producing Activity Streams 2.0 documents SHOULD include a @context property with a value that includes a reference to the normative Activity Streams 2.0 JSON-LD @context definition using the URL " https://www.w3.org/ns/activitystreams".

                                    mariusor@metalhead.clubM This user is from outside of this forum
                                    mariusor@metalhead.clubM This user is from outside of this forum
                                    mariusor@metalhead.club
                                    wrote last edited by
                                    #31

                                    @silverpill aaah, I see. I think we've had this discussion before (or at least I had it with someone else).

                                    For me "SHOULD" falls in the category of the robustness principle: "be conservative in what you do, be liberal in what you accept from others".

                                    So for me if you treat "SHOULD" in a spec as non mandatory you haven't really implemented the spec.

                                    @hongminhee

                                    silverpill@mitra.socialS 1 Reply Last reply
                                    0
                                    • mariusor@metalhead.clubM mariusor@metalhead.club

                                      @silverpill aaah, I see. I think we've had this discussion before (or at least I had it with someone else).

                                      For me "SHOULD" falls in the category of the robustness principle: "be conservative in what you do, be liberal in what you accept from others".

                                      So for me if you treat "SHOULD" in a spec as non mandatory you haven't really implemented the spec.

                                      @hongminhee

                                      silverpill@mitra.socialS This user is from outside of this forum
                                      silverpill@mitra.socialS This user is from outside of this forum
                                      silverpill@mitra.social
                                      wrote last edited by
                                      #32

                                      @mariusor I don't remember having such discussion. The SHOULD keyword is defined in RFC-2119:

                                      This word, or the adjective "RECOMMENDED", mean that there may exist valid reasons in particular circumstances to ignore a particular item, but the full implications must be understood and carefully weighed before choosing a different course.

                                      There are many valid reasons to not include @context. We also have almost 10 years of implementation experience and by now full implications are very well understood: by ignoring this recommendation we make messages smaller and developer experience better. No downside at all.

                                      @hongminhee

                                      mariusor@metalhead.clubM 1 Reply Last reply
                                      0
                                      • silverpill@mitra.socialS silverpill@mitra.social

                                        @mariusor I don't remember having such discussion. The SHOULD keyword is defined in RFC-2119:

                                        This word, or the adjective "RECOMMENDED", mean that there may exist valid reasons in particular circumstances to ignore a particular item, but the full implications must be understood and carefully weighed before choosing a different course.

                                        There are many valid reasons to not include @context. We also have almost 10 years of implementation experience and by now full implications are very well understood: by ignoring this recommendation we make messages smaller and developer experience better. No downside at all.

                                        @hongminhee

                                        mariusor@metalhead.clubM This user is from outside of this forum
                                        mariusor@metalhead.clubM This user is from outside of this forum
                                        mariusor@metalhead.club
                                        wrote last edited by
                                        #33

                                        @silverpill regarding size, ActivityPub is such a verbose protocol that the hundred or so of raw bytes you save through omitting context, are most likely negligible through the prism of connection compression. So to me that's not entirely a "valid reason".

                                        And as developer myself, I think that contexts, even in a non valid JSON-LD implementation, offer enough guidance for building a data vocabulary for them to have plenty of value.

                                        Do you propose we replace contexts with Open API specifications, or how do we coordinate what's a valid vocabulary data object in a federated network? And how do you propose that others discover these specs?

                                        @hongminhee

                                        mariusor@metalhead.clubM 1 Reply Last reply
                                        0
                                        • douginamug@mastodon.xyzD This user is from outside of this forum
                                          douginamug@mastodon.xyzD This user is from outside of this forum
                                          douginamug@mastodon.xyz
                                          wrote last edited by
                                          #34

                                          @pintoch read this thread?

                                          1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          Powered by NodeBB Contributors
                                          • First post
                                            Last post
                                          0
                                          • Categories
                                          • Recent
                                          • Tags
                                          • Popular
                                          • World
                                          • Users
                                          • Groups