PHPackages                             pfefferle/wordpress-salmon - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. pfefferle/wordpress-salmon

AbandonedArchivedWordpress-plugin

pfefferle/wordpress-salmon
==========================

A Salmon plugin for WordPress http://wordpress.org/plugins/salmon/

0.9.2(6y ago)9165MITPHPPHP &gt;=5.6.0

Since Feb 3Pushed 6y ago1 watchersCompare

[ Source](https://github.com/pfefferle/wordpress-salmon)[ Packagist](https://packagist.org/packages/pfefferle/wordpress-salmon)[ RSS](/packages/pfefferle-wordpress-salmon/feed)WikiDiscussions master Synced 3d ago

READMEChangelog (3)Dependencies (2)Versions (4)Used By (0)

Salmon
======

[](#salmon)

**Contributors:** [pfefferle](https://profiles.wordpress.org/pfefferle)
**Donate link:**
**Tags:** diso, OStatus, Mastodon, Diaspora, federated, StatusNET, Gnu.Social, Salmon, Comments
**Requires at least:** 3.0
**Tested up to:** 5.4
**Stable tag:** 0.9.2
**License:** MIT
**License URI:**

Salmon for WordPress

Description
-----------

[](#description)

*This is a very early state of a salmon-plugin for WordPress. There are still some bugs and problems... Please let me know if you found some.*

> As updates and content flow in real time around the Web, conversations around the content are becoming increasingly fragmented into individual silos. Salmon aims to define a standard protocol for comments and annotations to swim upstream to original update sources -- and spawn more commentary in a virtuous cycle. It's open, decentralized, abuse resistant, and user centric.

You can find more informations about Salmon here:

The plugin currently only supports receiving Salmons, but I am working on a bidirectional version.

This plugin requires the following plugins:

- the `host-meta`-plugin:
- the `webfinger`-plugin:

and I recommend to use it in combination with OStatus:

Changelog
---------

[](#changelog)

Project and support maintained on github at [pfefferle/wordpress-salmon](https://github.com/pfefferle/wordpress-salmon).

### 0.9.2

[](#092)

- fix php warning

### 0.9.1

[](#091)

- Fixed E-Mail spamming problem

### 0.9.0

[](#090)

- general refactoring
- refactored the code to use openssl instead of custom PHP code
- simpler avatar code
- fixed admin pages

### 0.5

[](#05)

- version problems

### 0.4.1

[](#041)

- fixed feed links (thanks to Stephen Paul Weber)

### 0.4

[](#04)

- some changes

### 0.3

[](#03)

- fixed rss bug
- WordPress 3.1 fixes

### 0.2

[](#02)

- fixed "custom comment types"
- added mailer

### 0.1

[](#01)

- Initial release

Installation
------------

[](#installation)

1. Upload and install the `salmon`-plugin
2. Install all dependencies through the `salmon`-settings-page

Frequently Asked Questions
--------------------------

[](#frequently-asked-questions)

The FAQ is taken from the Salom Protocol homepage:

### How does Salmon deal with abuse and spam?

[](#how-does-salmon-deal-with-abuse-and-spam)

Early Internet protocols and systems were vulnerable to trivial forgery, and fixing this after the protocols were widely deployed is painful, partial, and slow. On the other hand, it's also possible to add too much security and make a protocol too restrictive or too complex for large-scale adoption.

Salmon tries to find a good balance. Salmon adopts a defense-in-depth strategy, assumes that there will be abuse and spammers, but builds in protocol hooks to make an active in-depth defense both cheap and effective with few false positives.

Specifically, spammers can not forge signatures from legitimate users, and it is very hard for them to mint massive numbers of fake identities without detection. So as a first line of defense, anything whose authorship check fails, is simply dropped. We're building this in from the start so that we'll never have an installed base of clients doing things insecurely.

Salmon disallows completely anonymous and untraceable messages. It requires pseudonyms from verifiable identity providers. This feature allows receivers to rate limit the messages per hour per pseudonym and per identity provider. (Identity providers themselves have verifiable identities and can gain or lose reputation based on what their users do; every identity provider has to at least have a domain name, raising the bar for spammers significantly, and meaning that simple rate limiting can force the spammers to acquire and "burn" many domain names.)

Assuming wide deployment, we expect that spammers will attack Salmon with the same vigor they throw at email. However, Salmon implementors can cheaply and easily deal with the simpler techniques the spammers currently use to inject email. They will also mount active defenses based both on the years of experience in spam-blocking email and the new tools (guaranteed identity, identity providers, distributed reputation) that Salmon enables.

All of this is possible to do, and has been done, with closed systems. Salmon provides a way to do this with an open protocol that anyone can implement and anyone can interoperate with.

### Does Salmon support threading?

[](#does-salmon-support-threading)

Yes, the thr:in-reply-to ID can be the ID of a comment (which can itself be a Salmon with a xpost:source element that points at the ultimate source). While the protocol supports threading, recipients can of course flatten salmon in the feeds that they re-publish -- though the thr:in-reply-to element can be used to reconstitute threads as needed.

### How is Salmon different from using AtomPub to post to a comment feed?

[](#how-is-salmon-different-from-using-atompub-to-post-to-a-comment-feed)

Salmon is in fact based on and compatible with AtomPub. Salmon greatly enhances interoperability and usability by specifying a distributed identity mechanism for identifying the author and intermediary involved, provides a discovery mechanism, and specifies how things should be linked together. By not requiring pre-registration or federation but still allowing for verifiable identification, it provides a usable, level playing field for all parties involved.

### Why are you using this new crosspost extension instead of just using, and retaining, atom:id?

[](#why-are-you-using-this-new-crosspost-extension-instead-of-just-using-and-retaining-atomid)

See .

### What else is Salmon useful for?

[](#what-else-is-salmon-useful-for)

The payload can define any kind of message, so Salmon can be extended in arbitrary ways. It is already being used to communicate mentions to mentionees. It has also been used to signal cross-site following (by sending a follow message) or to send requests (by sending requests rather than notifications, e.g., a friend request). It is best used when there is not necessarily predefined relationship or subscription between the source and destination; if there is, PubSubHubbub may be a better choice.

###  Health Score

26

—

LowBetter than 43% of packages

Maintenance20

Infrequent updates — may be unmaintained

Popularity14

Limited adoption so far

Community12

Small or concentrated contributor base

Maturity50

Maturing project, gaining track record

 Bus Factor1

Top contributor holds 93.3% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~404 days

Total

3

Last Release

2213d ago

### Community

Maintainers

![](https://www.gravatar.com/avatar/2e3d56273f319d19d7492f8ba06a01fd64a5724e3553b2d1f2ac0f4e399b2cfa?d=identicon)[pfefferle](/maintainers/pfefferle)

---

Top Contributors

[![pfefferle](https://avatars.githubusercontent.com/u/2373?v=4)](https://github.com/pfefferle "pfefferle (28 commits)")[![hinaloe](https://avatars.githubusercontent.com/u/5253290?v=4)](https://github.com/hinaloe "hinaloe (2 commits)")

---

Tags

ostatuspluginsalmonsalmon-protocolwordpresswordpress-plugin

###  Code Quality

TestsPHPUnit

### Embed Badge

![Health badge](/badges/pfefferle-wordpress-salmon/health.svg)

```
[![Health](https://phpackages.com/badges/pfefferle-wordpress-salmon/health.svg)](https://phpackages.com/packages/pfefferle-wordpress-salmon)
```

###  Alternatives

[elgg/elgg

Elgg is an award-winning social networking engine, delivering the building blocks that enable businesses, schools, universities and associations to create their own fully-featured social networks and applications.

1.7k15.7k5](/packages/elgg-elgg)[pressbooks/pressbooks

Pressbooks is an open source book publishing tool built on a WordPress multisite platform. Pressbooks outputs books in multiple formats, including PDF, EPUB, web, and a variety of XML flavours, using a theming/templating system, driven by CSS.

44643.1k1](/packages/pressbooks-pressbooks)[johnbillion/user-switching

Instant switching between user accounts in WordPress and WooCommerce.

19768.3k2](/packages/johnbillion-user-switching)[rainlab/blog-plugin

Blog plugin for October CMS

17257.7k](/packages/rainlab-blog-plugin)[rainlab/user-plugin

User plugin for October CMS

11954.3k13](/packages/rainlab-user-plugin)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
