<?xml version="1.0" encoding="UTF-8"?><rss xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:atom="http://www.w3.org/2005/Atom" version="2.0"><channel><title><![CDATA[FEP-be68: Audio Objects]]></title><description><![CDATA[<p>I writing a big fep covering various mechanisms around audio federation. This describe how Funkwhale federation works. I never writed a protocol enhancement proposal. Maybe I should split it into various fep ? the draft is here <a href="https://codeberg.org/petitminion/fep/src/branch/fep-be68/fep/be68/fep-be68.md">https://codeberg.org/petitminion/fep/src/branch/fep-be68/fep/be68/fep-be68.md</a></p><p>also created a post here : <a href="https://the.socialmusic.network/t/fep-be68-audio-objects/767">https://the.socialmusic.network/t/fep-be68-audio-objects/767</a></p>]]></description><link>https://fedi.wiki/topic/2dd04d9e-530a-4d33-a936-7b3cb2a5c839/fep-be68-audio-objects</link><generator>RSS for Node</generator><lastBuildDate>Mon, 25 May 2026 01:51:44 GMT</lastBuildDate><atom:link href="https://fedi.wiki/topic/2dd04d9e-530a-4d33-a936-7b3cb2a5c839.rss" rel="self" type="application/rss+xml"/><pubDate>Mon, 23 Mar 2026 10:47:08 GMT</pubDate><ttl>60</ttl><item><title><![CDATA[Reply to FEP-be68: Audio Objects on Sun, 17 May 2026 17:32:38 GMT]]></title><description><![CDATA[<blockquote><p>absolute or relative identifiers</p></blockquote><p>I think all identifiers should be absolute URIs. If we are talking about actor and collection IDs, ActivityPub requires them to be "publicly dereferencable URIs": <a href="https://www.w3.org/TR/activitypub/#obj-id" rel="noopener">https://www.w3.org/TR/activitypub/#obj-id</a></p><p>Relative identifiers are theoretical artifacts of JSON-LD processing that won't be understood by most ActivityPub implementations. The only exception is <code>as:Public</code>, short for <code>https://www.w3.org/ns/activitystreams#Public</code>, but even those are not universally supported.</p><p>-----</p><p>In the section "Privacy level", the FEP still refers to levels by name (<code>followers</code> and <code>everyone</code><img src="https://fedi.wiki/assets/plugins/nodebb-plugin-emoji/emoji/android/1f61e.png?v=cfc437c8754" class="not-responsive emoji emoji-android emoji--disappointed" style="height:23px;width:auto;vertical-align:middle" title="):" alt="😞" /> <a href="https://codeberg.org/petitminion/fep/src/commit/95fd73232dd1d8f95e6731ccb4ebbc79c5a2e330/fep/be68/fep-be68.md#privacy-level" rel="noopener">https://codeberg.org/petitminion/fep/src/commit/95fd73232dd1d8f95e6731ccb4ebbc79c5a2e330/fep/be68/fep-be68.md#privacy-level</a></p>]]></description><link>https://fedi.wiki/post/https://mitra.social/objects/019e36ff-4126-77a1-a9c9-8aea58a16e77</link><guid isPermaLink="true">https://fedi.wiki/post/https://mitra.social/objects/019e36ff-4126-77a1-a9c9-8aea58a16e77</guid><dc:creator><![CDATA[silverpill@mitra.social]]></dc:creator><pubDate>Sun, 17 May 2026 17:32:38 GMT</pubDate></item><item><title><![CDATA[Reply to FEP-be68: Audio Objects on Fri, 08 May 2026 13:38:12 GMT]]></title><description><![CDATA[<blockquote><p>If you knew the collection ID of another instance’s users, you could in theory send them activities that would be forwarded (or not) by that other instance. (Say you knew of an “instance actor” that linked to its “users” collection.)</p></blockquote><p>I guess the nodeinfo could be use to share the instance’s users collection id ? Would you recommend to use absolute or relative identifiers ? From my pov absolute is easier to handle ^^</p><blockquote><p>This is all known as “identity by description”, as opposed to “identity by name” which is a thing you can do to enable easier reuse.</p></blockquote><p>Since the FEP do not forbid it this kind of use case if allowed, but it think we should encourage the use of ids.</p> trwnh:<blockquote><p>The “responsibility” is implicitly tied to the id. If you have a “metadata provider” then you can notify them of any new Audio objects referencing it (which is I think what you are proposing with the “source of the track” stuff described above?).</p></blockquote><p>yes this was my proposition. But the problem comes when the tracks has a mbid. Various AP track with different ids can share the same mbid. So we should send the audio create activity to each one of them.</p> trwnh:<blockquote><p>If you’re using Musicbrainz to provide Track metadata then why not use their database directly? Otherwise, you could link a metadata provider’s data by declaring it as being equivalent to the Musicbrainz entities.</p></blockquote><p>because not all audio files or tracks have mbids. When they have we use their db. The proposition was to use \<code>musicbrainzId\</code> on any audio object. I updated the FEP explaining the relation between AP audio objects and MusicBrainz audio objects. A funkwhale track is a musicbrainz recording.</p>]]></description><link>https://fedi.wiki/post/https://socialhub.activitypub.rocks/ap/object/1b92ab0ce03ffc1792dacf2f1ee36c80</link><guid isPermaLink="true">https://fedi.wiki/post/https://socialhub.activitypub.rocks/ap/object/1b92ab0ce03ffc1792dacf2f1ee36c80</guid><dc:creator><![CDATA[petitminion@socialhub.activitypub.rocks]]></dc:creator><pubDate>Fri, 08 May 2026 13:38:12 GMT</pubDate></item><item><title><![CDATA[Reply to FEP-be68: Audio Objects on Wed, 06 May 2026 00:05:50 GMT]]></title><description><![CDATA[silverpill:<blockquote><p>single-word strings, not URIs</p></blockquote><p>slight pushback on the "not URIs" bit -- even JSON strings that aren't in normal form are still identifiers because "audience" is defined in a way that types its values as identifiers. it could be disambiguated by expanding those (in effect relative) identifiers against a base URI, but you can't make this part of the definition of "audience" without confusing others who don't share this definition. and "audience" is also already defined by AS2 which requires that you <em>MUST NOT</em> override or change its definitions. I think the earlier recommendation to map these to existing identifiers still holds: <a href="https://socialhub.activitypub.rocks/t/fep-be68-audio-objects/8614/10">https://socialhub.activitypub.rocks/t/fep-be68-audio-objects/8614/10</a></p><p>---</p> petitminion:<blockquote><p>Why not use this approach then. For the <code>instance</code> why no use the instance url ? This would also allow to share activities with one specific instance and not with others ?</p></blockquote><p>This is fine as long as everyone agrees on what the "instance URL" is. The service itself isn't necessarily always represented by the HTTP resource <code>/</code>. I think for the Funkwhale concept of <code>instance</code> you could mint an identifier like <code>https://funkwhale.example/users/</code> and have it represent all users on the host <code>funkwhale.example</code>. You could then describe that as a Collection, as well:</p><pre><code>{ "@context": "https://www.w3.org/ns/activitystreams", "id": "https://funkwhale.example/users/", "type": "Collection", "name": "funkwhale.example's users" "summary": "Represents every user on funkwhale.example"}</code></pre><p>and then <code>another-funkwhale.example</code> would have its own users:</p><pre><code>{ "@context": "https://www.w3.org/ns/activitystreams", "id": "https://another-funkwhale.example/users/", "type": "Collection", "name": "another-funkwhale.example's users" "summary": "Represents every user on another-funkwhale.example"}</code></pre><p>Your local instance should know its own local users collection ID. If you knew the collection ID of another instance's users, you could in theory send them activities that would be forwarded (or not) by that other instance. (Say you knew of an "instance actor" that linked to its "users" collection.)</p><p>If you used relative identifiers and implicitly expand them against the current network location, it could look like this:</p><pre><code>{ "@context": [ "@base": "https://funkwhale.example/", // insert your own instance name here "https://www.w3.org/ns/activitystreams" ], "audience": "/users/" // only you need to know what this means, so there aren't any compatibility/interop concerns}</code></pre><p>If you used absolute identifiers it would look like this:</p><pre><code>{ "@context": "https://www.w3.org/ns/activitystreams", "audience": "https://funkwhale.example/users/"}</code></pre><p>---</p> petitminion:<blockquote><p>If a project do not implement <code>Artist</code> or some other objects they can still parse the audio metadata and use it has they wish. They just can’t share the metadata that is missing an id.</p></blockquote><p>Would it be correct to interpret this as Funkwhale allowing anonymous objects? (Fudging the vocab here a bit):</p><pre><code>{ "@context": "https://www.w3.org/ns/activitystreams", "actor": { "name": "a" }, "type": "Listen", "object": { "name": "House of Leaves", "attributedTo": { "name": "Circa Survive" } }}</code></pre><p>You could specify any "id" here to enable reuse, but on its own, this document contains enough information to describe a useful activity: <code>a listened to "House of Leaves" by Circa Survive.</code> You could progressively enhance this with other statements, like when the Listen occurred, or so on. You just don't know which specific  we're talking about here, although you can probably be reasonably sure you know what is meant by  and  by context clues -- specifically, that since this is a Listen activity, the Listen.object is probably some listenable thing like a Track, and then a Track.attributedTo is probably the attribution of a Track to an Artist, and then you fill in the gaps that way to understand that we are both talking about the band Circa Survive and their work "House of Leaves".</p><p>This is all known as "identity by description", as opposed to "identity by name" which is a thing you can do to enable easier reuse. (The third way to identify something is "identity by possession". If this sounds familiar at all, it's because they map to the concept of "authentication factors" -- "what you know", "what you are", and "what you have".)</p><p>---</p> petitminion:<blockquote><p>We should describe a mechanism to get the <code>Audio</code> object if we only have a <code>Track</code></p></blockquote><p>Couldn't you just link Audio objects to the Track? Or the other way around could work, too.</p><p>For Funkwhale this is like saying:</p><ul><li>I have a Library containing an Audio, and the Audio references a Track; or</li><li>I have a Track referencing an Audio contained in a Library.</li></ul><p>I assume Funkwhale doesn't store an index of which Tracks correspond to which Audio objects (since what I have seen so far without looking deeply is that Funkwhale prefers to index Audio objects that individually refer to a Track), but it's doable. It would also allow searching for a Track and finding any Library that contains an Audio object referencing that Track ("which libraries contain audio for this track" rather than "which track does this audio represent").</p><p>I think this is what you mean by this bit?</p> petitminion:<blockquote><p>add an <code>Audio</code> attribute to the <code>Track</code> object</p></blockquote><p>---</p> petitminion:<blockquote><p>An issue arise when the source instance goes down : we should probably have a mechanism that allow another instance to “claim the responsibility” of the track metadata ? This seem impossible since ids can’t changes…</p></blockquote><p>The "responsibility" is implicitly tied to the id. If you have a "metadata provider" then you can notify them of any new Audio objects referencing it (which is I think what you are proposing with the "source of the track" stuff described above?).</p><pre><code>{ "type": "Activity", "summary": "Letting you know that your Track was uploaded as Audio", "audience": "https://track-owner.example/", "object": "https://audio.example"}</code></pre> petitminion:<blockquote><p>Another option is to use musicbrainz : give them the audio id has streaming link (its a centralized approach but why not)</p></blockquote><p>If you're using Musicbrainz to provide Track metadata then why not use their database directly?</p><p>Otherwise, you could link a metadata provider's data by declaring it as being equivalent to the Musicbrainz entities.</p><pre><code>{ "@id": "https://musicbrainz.org/work/38df7f57-de90-437f-8a61-3dd8f4e2f9af"}</code></pre><p>Although this does raise the issue of what to do when the metadata of the Audio doesn't actually match the metadata provider's information. For example, according to Musicbrainz, the Recording is <a href="https://musicbrainz.org/recording/7a3fad60-938e-4c17-bc83-342acd713c04">https://musicbrainz.org/recording/7a3fad60-938e-4c17-bc83-342acd713c04</a> "Meet Me In Montauk", which contains the titular work followed by ~7 minutes of silence, and then the hidden "bonus track" follows afterward. In my personal library, the audio I'm playing has actually been extracted from the official release, so that my copy of "Meet Me In Montauk" is only about 2 minutes long instead of 14:39, and my copy of "House of Leaves" represents something that was never officially released as a singular Track.</p><p>If we take the activity from before, then the question is this: what did I actually listen to?</p><ul><li>I didn't listen to "Meet Me In Montauk".</li><li>I didn't listen to the 7 minutes of silence.</li><li>I listened to "House of Leaves".</li><li>What I listened to is not described in Musicbrainz as a Recording.<ul><li>It is described by Musicbrainz as a Work (specifically a Song).</li></ul></li></ul><p>What ends up in the Funkwhale concept of a "Track"? Which <code>musicbrainzId</code> do you use? Does it get an <code>id</code>?</p>]]></description><link>https://fedi.wiki/post/https://socialhub.activitypub.rocks/ap/object/b135dec202935d8a9225195edc8d8135</link><guid isPermaLink="true">https://fedi.wiki/post/https://socialhub.activitypub.rocks/ap/object/b135dec202935d8a9225195edc8d8135</guid><dc:creator><![CDATA[trwnh@socialhub.activitypub.rocks]]></dc:creator><pubDate>Wed, 06 May 2026 00:05:50 GMT</pubDate></item><item><title><![CDATA[Reply to FEP-be68: Audio Objects on Tue, 05 May 2026 19:04:36 GMT]]></title><description><![CDATA[<p>The definitions of <code>audience</code> are ambiguous. For example, the "Library" table</p><p><a href="https://codeberg.org/petitminion/fep/src/branch/fep-be68/fep/be68/fep-be68.md#library" rel="noopener">https://codeberg.org/petitminion/fep/src/branch/fep-be68/fep/be68/fep-be68.md#library</a></p><p>states that <code>audience</code> is a <code>String (URI)</code>.</p><p>But in the "Privacy level" section, privacy levels are defined as single-word strings, not URIs.</p><p>Also, is it correct that <code>Audio</code> objects don't have an <code>audience</code> property?</p>]]></description><link>https://fedi.wiki/post/https://mitra.social/objects/019df987-22a8-7981-90a2-43fec645aaca</link><guid isPermaLink="true">https://fedi.wiki/post/https://mitra.social/objects/019df987-22a8-7981-90a2-43fec645aaca</guid><dc:creator><![CDATA[silverpill@mitra.social]]></dc:creator><pubDate>Tue, 05 May 2026 19:04:36 GMT</pubDate></item><item><title><![CDATA[Reply to FEP-be68: Audio Objects on Mon, 04 May 2026 18:57:21 GMT]]></title><description><![CDATA[<p>the fep has been updated with all the music/audio objects</p>]]></description><link>https://fedi.wiki/post/https://socialhub.activitypub.rocks/ap/object/2d2d94e3f6b1fac2e16cdd768b9aa37e</link><guid isPermaLink="true">https://fedi.wiki/post/https://socialhub.activitypub.rocks/ap/object/2d2d94e3f6b1fac2e16cdd768b9aa37e</guid><dc:creator><![CDATA[petitminion@socialhub.activitypub.rocks]]></dc:creator><pubDate>Mon, 04 May 2026 18:57:21 GMT</pubDate></item><item><title><![CDATA[Reply to FEP-be68: Audio Objects on Fri, 10 Apr 2026 10:25:20 GMT]]></title><description><![CDATA[<blockquote><p>it is unclear whether this FEP permits standalone <code>Audio</code> objects that are not part of any library.</p></blockquote><p>Funkwhale approach is that every <code>Audio</code> object has a library at the db level (this allow to know if the url is playable or not, wihtout having to do a request and to update the playable status of batch of audio objects). When we receive an activity, if no library if on the payload we consider the audio acctivity comes from a channels instead of a normal user and we create a public library locally. But I guess it doesn’t have to be mandatory.</p><blockquote><p>For example, if a software doesn’t implement <code>Artist</code> and <code>Album</code> as separate entities, is it allowed to omit the <code>id</code> property in those objects, like so?</p></blockquote><p>I don’t think this should be allowed since it generate a lot of issues like duplication, missing metadata and unknown metadata origin. Also the id in AP is used to fetch the whole object and avoid sending big nested objects. But If a project do not implement \<code>Artist\</code> or some other objects they can still parse the audio metadata and use it has they wish. They just can’t share the metadata that is missing an id. For example they still can send \<code>Listening\</code> objects because they only need the track id for this. The remote server can use the track id to get all the associated metadata from the original server.</p><blockquote><p>Also, it is unclear how to fetch <code>Audio</code> objects from a <code>Track</code> object.</p></blockquote><p>Indeed.. Funkwhale parse audio collections (libraries and channels) so we have the <code>Audio</code> object before having the track. We should describe a mechanism to get the <code>Audio</code> object if we only have a <code>Track</code> :</p><p>To get playable tracks, a server should parse <code>Audio</code> collections (<code>Library</code> and <code>Channel</code>) since \<code>Audio\</code> object has a track attribute. If the a server has a Track without any playable audio associated to it, they can request \<code>Audio\</code> objects to remotes servers. Note that if instance A is the source of the track, it doesn’t mean it has an playable \<code>Audio\</code> object. While instance B might have one.</p><p>We could use the source of the track (instance A) to centralize all the <code>Audio</code> objects by sending the <code>create</code><code>Audio</code> activity to them. And add an <code>Audio</code> attribute to the <code>Track</code> object. This way other server can request instance A instead of having to parse the whole network for <code>Audio</code> objects. An issue arise when the source instance goes down : we should probably have a mechanism that allow another instance to “claim the responsibility” of the track metadata ? This seem impossible since ids can’t changes… So we need to send the Create Audio to all instance that use the track (we can’t guess all of them but it still better than nothing) or we send it to all the instance ? (might be too much).Another option is to use musicbrainz : give them the audio id has streaming link (its a centralized approach but why not)</p>]]></description><link>https://fedi.wiki/post/https://socialhub.activitypub.rocks/ap/object/41e97906cebf2f49743d7c3210bf0b83</link><guid isPermaLink="true">https://fedi.wiki/post/https://socialhub.activitypub.rocks/ap/object/41e97906cebf2f49743d7c3210bf0b83</guid><dc:creator><![CDATA[petitminion@socialhub.activitypub.rocks]]></dc:creator><pubDate>Fri, 10 Apr 2026 10:25:20 GMT</pubDate></item><item><title><![CDATA[Reply to FEP-be68: Audio Objects on Sun, 05 Apr 2026 14:39:25 GMT]]></title><description><![CDATA[<p>Thanks for your insights </p><p>Why not use this approach then. For the \<code>instance\</code> why no use the instance url ? This would also allow to share activities with one specific instance and not with others ?</p>]]></description><link>https://fedi.wiki/post/https://socialhub.activitypub.rocks/ap/object/c69415d8852a55adbaef1097b1bed7d4</link><guid isPermaLink="true">https://fedi.wiki/post/https://socialhub.activitypub.rocks/ap/object/c69415d8852a55adbaef1097b1bed7d4</guid><dc:creator><![CDATA[petitminion@socialhub.activitypub.rocks]]></dc:creator><pubDate>Sun, 05 Apr 2026 14:39:25 GMT</pubDate></item><item><title><![CDATA[Reply to FEP-be68: Audio Objects on Wed, 01 Apr 2026 00:36:24 GMT]]></title><description><![CDATA[<p>Your <code>audience_string</code> is still a form of <code>@id</code> since it is a vocabulary term you define.</p><pre><code>{ "audience": {"id": "https://w3id.org/fep/xxxx/everyone"}}</code></pre><p>The thing is, 3/4 of your <code>audience_string</code>s already have other identifiers which mean the same thing.</p><ul><li><code>me</code> == <code>$.actor.id</code></li><li><code>followers</code> == <code>$.actor.followers</code></li><li><code>everyone</code> == <code>https://www.w3.org/ns/activitystreams#Public</code></li></ul><p>The only one that doesn't currently have a mapping to an existing term is <code>instance</code>, but this could be done with a Collection containing all local users, like a hypothetical <code>https://social.example/users/</code>.</p>]]></description><link>https://fedi.wiki/post/https://socialhub.activitypub.rocks/ap/object/0e32391d87a1de3794bba08a7d3ae1cb</link><guid isPermaLink="true">https://fedi.wiki/post/https://socialhub.activitypub.rocks/ap/object/0e32391d87a1de3794bba08a7d3ae1cb</guid><dc:creator><![CDATA[trwnh@socialhub.activitypub.rocks]]></dc:creator><pubDate>Wed, 01 Apr 2026 00:36:24 GMT</pubDate></item><item><title><![CDATA[Reply to FEP-be68: Audio Objects on Tue, 31 Mar 2026 18:29:06 GMT]]></title><description><![CDATA[<p>That would probably make it compliant with ActivityStreams, but still, it is not good for interop, because other fedi software specifies audience using URIs.</p><p>I would be happy to federate with Funkwhale, but with the mechanism described in the FEP it will require special treatment.</p>]]></description><link>https://fedi.wiki/post/https://mitra.social/objects/019d4528-0dbf-4cd4-a9e4-fbadb8dc2cb3</link><guid isPermaLink="true">https://fedi.wiki/post/https://mitra.social/objects/019d4528-0dbf-4cd4-a9e4-fbadb8dc2cb3</guid><dc:creator><![CDATA[silverpill@mitra.social]]></dc:creator><pubDate>Tue, 31 Mar 2026 18:29:06 GMT</pubDate></item><item><title><![CDATA[Reply to FEP-be68: Audio Objects on Tue, 31 Mar 2026 12:41:44 GMT]]></title><description><![CDATA[<p>\<code>audience\</code> can be object or link : <a href="https://www.w3.org/TR/activitystreams-vocabulary/#dfn-audience">https://www.w3.org/TR/activitystreams-vocabulary/#dfn-audience</a> . Your proposition is too complicate from my pov. We could, send an object like :<code>{</code><code> "type": "Group",</code><code> "name": audience_string</code><code> },</code></p>]]></description><link>https://fedi.wiki/post/https://socialhub.activitypub.rocks/ap/object/03a4a04e7e0d17456f70dff90791b189</link><guid isPermaLink="true">https://fedi.wiki/post/https://socialhub.activitypub.rocks/ap/object/03a4a04e7e0d17456f70dff90791b189</guid><dc:creator><![CDATA[petitminion@socialhub.activitypub.rocks]]></dc:creator><pubDate>Tue, 31 Mar 2026 12:41:44 GMT</pubDate></item><item><title><![CDATA[Reply to FEP-be68: Audio Objects on Tue, 31 Mar 2026 12:30:07 GMT]]></title><description><![CDATA[<p>yes I guess having the definition on the FEP is the proper way to do it.</p>]]></description><link>https://fedi.wiki/post/https://socialhub.activitypub.rocks/ap/object/c235dcf40f1918a7beb63ab217035767</link><guid isPermaLink="true">https://fedi.wiki/post/https://socialhub.activitypub.rocks/ap/object/c235dcf40f1918a7beb63ab217035767</guid><dc:creator><![CDATA[petitminion@socialhub.activitypub.rocks]]></dc:creator><pubDate>Tue, 31 Mar 2026 12:30:07 GMT</pubDate></item><item><title><![CDATA[Reply to FEP-be68: Audio Objects on Mon, 23 Mar 2026 19:43:42 GMT]]></title><description><![CDATA[<p>This may limit interoperability because <code>audience</code> is supposed to contain IDs (either actor IDs or collection IDs). I think many servers don't even check <code>audience</code>, and rely only on <code>to</code> and <code>cc</code>.</p><p>Here's how these special strings could be translated into IDs for <code>to</code> / <code>cc</code>:</p><p>- <code>me</code>: current actor ID.<br />- <code>instance</code>: special collection ID, similar to <code>https://www.w3.org/ns/activitystreams#Public</code>. Prior art: <a href="https://docs.akkoma.dev/develop/development/ap_extensions/#local-post-scope" rel="noopener">Akkoma</a> uses <code>https://server.example/#Public</code> for local-only posts.<br />- <code>followers</code>: actor's <code>followers</code> collection ID.<br />- <code>everyone</code>: <code>https://www.w3.org/ns/activitystreams#Public</code></p>]]></description><link>https://fedi.wiki/post/https://mitra.social/objects/019d1c39-7ac0-b33b-b0d6-6c1486af048c</link><guid isPermaLink="true">https://fedi.wiki/post/https://mitra.social/objects/019d1c39-7ac0-b33b-b0d6-6c1486af048c</guid><dc:creator><![CDATA[silverpill@mitra.social]]></dc:creator><pubDate>Mon, 23 Mar 2026 19:43:42 GMT</pubDate></item><item><title><![CDATA[Reply to FEP-be68: Audio Objects on Mon, 23 Mar 2026 13:04:14 GMT]]></title><description><![CDATA[<p>One question for now, are you planning to copy the object definitions from the Funkwhale site into the FEP? </p><p><span><a href="https://socialhub.activitypub.rocks/u/petitminion">@<span>petitminion</span></a></span></p>]]></description><link>https://fedi.wiki/post/https://mastodon.social/users/benpate/statuses/116278627859728935</link><guid isPermaLink="true">https://fedi.wiki/post/https://mastodon.social/users/benpate/statuses/116278627859728935</guid><dc:creator><![CDATA[benpate@mastodon.social]]></dc:creator><pubDate>Mon, 23 Mar 2026 13:04:14 GMT</pubDate></item><item><title><![CDATA[Reply to FEP-be68: Audio Objects on Mon, 23 Mar 2026 12:51:47 GMT]]></title><description><![CDATA[<p>Thank you for writing this. I’ll need to read more thoroughly, but this looks good to me. I’ll note any extra requests I have on codeberg <img src="https://fedi.wiki/assets/plugins/nodebb-plugin-emoji/emoji/android/1f642.png?v=cfc437c8754" class="not-responsive emoji emoji-android emoji--slightly_smiling_face" style="height:23px;width:auto;vertical-align:middle" title=":)" alt="🙂" /></p><p>Your FEP is definitely NOT too long, so I wouldn’t worry about splitting it into multiple documents.</p><p>And, I’m really glad to see Albums in there. It will be a big help for Bandwagon. I’m really excited that we’ll be able to share music across both apps!</p><p><span><a href="https://socialhub.activitypub.rocks/u/petitminion">@<span>petitminion</span></a></span></p>]]></description><link>https://fedi.wiki/post/https://mastodon.social/users/benpate/statuses/116278578857964872</link><guid isPermaLink="true">https://fedi.wiki/post/https://mastodon.social/users/benpate/statuses/116278578857964872</guid><dc:creator><![CDATA[benpate@mastodon.social]]></dc:creator><pubDate>Mon, 23 Mar 2026 12:51:47 GMT</pubDate></item><item><title><![CDATA[Reply to FEP-be68: Audio Objects on Mon, 23 Mar 2026 11:17:19 GMT]]></title><description><![CDATA[<p>Thanks for having a look ! It’s a single word.</p>]]></description><link>https://fedi.wiki/post/https://socialhub.activitypub.rocks/ap/object/9a260ece4e0fb2ad654a7048dde2f2d3</link><guid isPermaLink="true">https://fedi.wiki/post/https://socialhub.activitypub.rocks/ap/object/9a260ece4e0fb2ad654a7048dde2f2d3</guid><dc:creator><![CDATA[petitminion@socialhub.activitypub.rocks]]></dc:creator><pubDate>Mon, 23 Mar 2026 11:17:19 GMT</pubDate></item><item><title><![CDATA[Reply to FEP-be68: Audio Objects on Mon, 23 Mar 2026 11:09:40 GMT]]></title><description><![CDATA[<p>Looks good, thank you for writing it!</p><p>Is privacy level represented as a single word? Or is it actually an URL?</p>]]></description><link>https://fedi.wiki/post/https://socialhub.activitypub.rocks/ap/object/183d66ae87ed96b1a1ec13abf40313b4</link><guid isPermaLink="true">https://fedi.wiki/post/https://socialhub.activitypub.rocks/ap/object/183d66ae87ed96b1a1ec13abf40313b4</guid><dc:creator><![CDATA[silverpill@socialhub.activitypub.rocks]]></dc:creator><pubDate>Mon, 23 Mar 2026 11:09:40 GMT</pubDate></item></channel></rss>