Instarr Network
  • Login
  • Home

    • Home
  • Docs

    • Help
    • About
    • FAQ
    • Contact
    • Tags
    • Groups
    • API
    • OpenID
  • Atompub

    The Atom Publishing Protocol (AtomPub) is an application-level protocol for publishing and editing Web resources. The protocol is based on HTTP transfer of Atom-formatted representations. The Atom format is documented in the Atom Syndication Format.

    You can find more information about AtomPub in RFC5023.

    Activity Streams is an open format specification for activity stream protocols, which are used to syndicate activities taken in social web applications and services.

    You can find more information about Activity Streams at activitystrea.ms.

    Authentication

    The API supports both HTTP Basic and OAuth.

    Service document

    The service document for an account is found at /api/statusnet/app/service/<nickname>.xml

    Each service document has one workspace ('Main') and four collections:

    • notices: notices generated by the user
    • subscriptions: subscriptions by the user
    • favorites: the user's favorites
    • memberships: the user's group memberships

    Collections are identified by the <activity:verb> element(s) in their <collection> element.

    Notices

    Notice feeds, in reverse-chronological order, are at /api/statuses/user_timeline/<id>.atom.

    This is a partial feed; navigation links are included in the feed to scroll forward and back.

    Notices are represented as Activity Streams events with the "Post" verb and "Note" object-type:

    <entry>
     <activity:object-type>
       http://activitystrea.ms/schema/1.0/note
     </activity:object-type>
     [...]
     <activity:verb>
       http://activitystrea.ms/schema/1.0/post
     </activity:verb>
     [...]
    </entry>
    

    Repeats are be represented as Activity Streams events with the "Share" verb, and with the activity object being an entry representing a Notice:

    <entry>
     <activity:verb>
       http://activitystrea.ms/schema/1.0/share
     </activity:verb>
     [...]
     <activity:object>
      <activity:object-type>
        http://activitystrea.ms/schema/1.0/activity
      </activity:object-type>
      [...]
      <activity:verb>
        http://activitystrea.ms/schema/1.0/post
      </activity:verb>
      [...]
      <activity:object>
       <activity:object-type>
         http://activitystrea.ms/schema/1.0/note
       </activity:object-type>
       [...]
      </activity:object>
      [...]
     </activity:object>
     [...]
    </entry>
    

    Posted files will be represented by the "Post" verb and "Image, File, Video" object-type.

    Single-notice URL

    Single notices are be available as an Activity Streams event at /api/statuses/show/<notice-id>.atom.

    <entry>
     <activity:object-type>
      http://activitystrea.ms/schema/1.0/note
     </activity:object-type>
     [...]
     <activity:verb>
      http://activitystrea.ms/schema/1.0/post
     </activity:verb>
     <author>
      <activity:object-type>
       http://activitystrea.ms/schema/1.0/person
      </activity:object-type>
      [...]
     </author>
    </entry>
    

    Posting a notice

    A notice can be posted by sending a POST request containing a single <entry> element to the URL of the notice feed. These should have a "Post" verb, and a "Note" object-type, but since these are the default values, Atom entries that aren't marked up as Activity Streams objects should be fine to post.

    The resulting entry will be returned, per the APP, in Activity Streams format. The location of the notice can be read from the Content-Location HTTP header of the result or from the rel=self URL in the resulting entry.

    Editing a notice

    Notices cannot be edited. PUT requests to a notice URL will fail.

    Deleting a notice

    A single notice can be deleted by posting a DELETE HTTP request to the notice's Atom representation.

    Example with cURL:

    curl -u username:password -X DELETE \
      http://example.org/api/statuses/show/<notice-id>.atom
    

    Subscriptions

    The subscriptions feed, in reverse-chronological order, is at /api/statusnet/app/subscriptions/<id>.atom.

    This is a partial feed; it includes the navigation links necessary to scroll forward and back.

    Subscriptions are represented as Activity Streams entries with the "Follow" verb and "Person" object-type.

    Subscription URL

    A subscription has an URL at /api/statusnet/app/subscriptions/<subscriber id>/<subscribed id>.atom.

    Adding a new subscription

    To add a new subscription, POST an Activity Streams <entry> with a "Follow" verb and "Person" object-type.

    The resulting entry will be returned, per the APP, in Activity Streams format. The location of the subscription can be read from the Content-Location HTTP header of the result or from the rel=self URL in the resulting entry.

    Editing a subscription

    Subscriptions cannot be edited. PUT requests to the subscription URL will result in an error.

    Deleting a subscription

    To delete a subscription, send a DELETE HTTP request to the Subscription URL.

    Favorites

    The feed of the user's favorites, in reverse-chronological order, is at /api/statusnet/app/favorites/<user id>.atom.

    This is a partial feed; it includes the navigation links necessary to scroll forward and back.

    Favorites are represented as Activity Streams entries with the "Favorite" verb and "Note" object-type.

    Favorite URL

    Favorite entries have a self URL at /api/statusnet/app/favorites/<user id>/<notice id>.atom.

    Favoriting a notice

    To favorite a notice, POST an Activity Streams <entry> with the "Favorite" verb and "Note" object-type.

    The resulting favorite will be returned, per the APP, in Activity Streams format. The location of the favorite can be read from the Content-Location HTTP header of the result or from the rel=self URL in the resulting entry.

    Editing a favorite

    Favorites cannot be edited. PUT requests to a favorite URL will fail.

    Deleting a favorite

    To "unfavorite" a notice, POST a DELETE request to the URL for the favorite.

    Groups

    A feed of group memberships, in reverse-chron order, is available at /api/statusnet/app/memberships/<user id>.atom.

    This is a partial feed; it includes the navigation links necessary to scroll forward and back.

    Memberships are represented as Activity Streams entries with the "Join" ber and "Group" object-type.

    Membership URL

    Each membership has a representation at /api/statusnet/app/memberships/<user id>/<group id>.atom.

    Joining a group

    To join a group, POST an activity entry with a "Join" verb and "Group" object-type to the memberships feed.

    The resulting membership will be returned, per the APP, in Activity Streams format. The location of the membership can be read from the Content-Location HTTP header of the result or from the rel=self URL in the resulting entry.

    Editing group membership

    Group memberships cannot be edited. PUT requests to a membership feed will fail.

    Leaving a group

    To leave a group, send a DELETE request to the membership URL.

    • Help
    • About
    • FAQ
    • Privacy
    • Source
    • Version
    • Contact

    Instarr Network is a social network. It runs on GNU social, version 1.20.9-release, available under the GNU Affero General Public License.

    Creative Commons Attribution 3.0 All Instarr Network content and data are available under the Creative Commons Attribution 3.0 license.