This package is available since Fedify 2.0.0.
This package provides Deno Lint and ESLint plugin with lint rules specifically designed for Fedify applications. It helps you catch common mistakes and enforce best practices when building federated server apps with Fedify.
The plugin includes rules that check for:
- Proper actor ID configuration
- Required actor properties (inbox, outbox, followers, etc.)
- Correct URL patterns for actor collections
- Public key and assertion method requirements
- Collection filtering implementation
// deno.json
{
"lint": {
"plugins": {
"@fedify/lint": "jsr:@fedify/lint"
},
"rules": {
"@fedify/lint/actor-id-required": "error",
"@fedify/lint/actor-id-mismatch": "error",
"@fedify/lint/actor-inbox-property-required": "warn"
// ... other rules
}
}
}// eslint.config.ts
import fedifyLint from "@fedify/lint";
export default fedifyLint;The @fedify/lint package provides comprehensive linting rules for Fedify
federation code:
actor-id-required: Ensures all actors have anidpropertyactor-id-mismatch: Validates that actor IDs match the expected URI fromContext.getActorUri()actor-public-key-required: Ensures actors have public keys for HTTP Signaturesactor-assertion-method-required: Validates assertion methods for Object Integrity Proofs
actor-inbox-property-required: Ensures inbox is defined whensetInboxListenersis setactor-inbox-property-mismatch: Validates inbox URI fromgetInboxUriactor-outbox-property-required: Ensures outbox is defined whensetOutboxDispatcheris setactor-outbox-property-mismatch: Validates outbox URI fromgetOutboxUriactor-followers-property-required: Ensures followers is defined whensetFollowersDispatcheris setactor-followers-property-mismatch: Validates followers URI fromgetFollowersUriactor-following-property-required: Ensures following is defined whensetFollowingDispatcheris setactor-following-property-mismatch: Validates following URI fromgetFollowingUriactor-liked-property-required: Ensures liked is defined whensetLikedDispatcheris setactor-liked-property-mismatch: Validates liked URI fromgetLikedUriactor-featured-property-required: Ensures featured is defined whensetFeaturedDispatcheris setactor-featured-property-mismatch: Validates featured URI fromgetFeaturedUriactor-featured-tags-property-required: Ensures featuredTags is defined whensetFeaturedTagsDispatcheris setactor-featured-tags-property-mismatch: Validates featuredTags URI fromgetFeaturedTagsUriactor-shared-inbox-property-required: Ensures sharedInbox is defined whensetInboxListenersis setactor-shared-inbox-property-mismatch: Validates sharedInbox URI fromgetInboxUri
collection-filtering-not-implemented: Warns about missing collection filtering implementation (setFollowersDispatcheronly for now)
::: code-group
deno add jsr:@fedify/lintnpm add -D @fedify/lintpnpm add -D @fedify/lintyarn add -D @fedify/lintbun add -D @fedify/lint:::
Add the plugin to your deno.json configuration file:
{
"lint": {
"plugins": ["jsr:@fedify/lint"]
}
}By default, this enables all recommended rules.
You can customize which rules to enable and their severity levels:
{
"lint": {
"plugins": ["jsr:@fedify/lint"],
"rules": {
"tags": ["recommended"],
"include": [
"@fedify/lint/actor-id-required",
"@fedify/lint/actor-id-mismatch"
],
"exclude": [
"@fedify/lint/actor-featured-property-required"
]
}
}
}After setting up the configuration, run Deno's linter:
deno lintYou can also specify which files to lint:
deno lint federation.ts
deno lint src/federation/Add the plugin to your ESLint configuration file (e.g., eslint.config.ts or eslint.config.js):
import fedifyLint from "@fedify/lint";
// If your `createFederation` code is in `federation.ts` or `federation/**.ts`
export default fedifyLint;
// Or specify your own federation files
export default {
...fedifyLint,
files: ["my-own-federation.ts"],
};
// If you use other ESLint configurations
export default [
otherConfig,
fedifyLint,
];The default configuration applies recommended rules to files that match common federation-related patterns (e.g., federation.ts, federation/*.ts).
You can customize which files to lint and which rules to enable:
import { plugin } from "@fedify/lint";
export default [{
files: ["src/federation/**/*.ts"], // Your federation code location
plugins: {
"@fedify/lint": plugin,
},
rules: {
"@fedify/lint/actor-id-required": "error",
"@fedify/lint/actor-id-mismatch": "error",
"@fedify/lint/actor-inbox-property-required": "warn",
// ... other rules
},
}];The plugin provides two preset configurations:
Enables critical rules as errors and optional rules as warnings:
import fedifyLint from "@fedify/lint";
export default fedifyLint;Enables all rules as errors:
import { plugin } from "@fedify/lint";
export default [{
files: ["**/*.ts"],
...plugin.configs.strict,
}];Here's an example of code that would trigger lint errors:
// ❌ Wrong: Using relative URL for actor ID
import { createFederation, Person } from "@fedify/fedify";
const federation = createFederation({ /* ... */ });
federation.setActorDispatcher(
"/{identifier}",
(_ctx, identifier) => {
return new Person({
id: new URL(`/${identifier}`), // ❌ Should use ctx.getActorUri()
name: "Example User",
});
},
);Corrected version:
// ✅ Correct: Using Context.getActorUri() for actor ID
import { createFederation, Person } from "@fedify/fedify";
const federation = createFederation({ /* ... */ });
federation.setActorDispatcher(
"/{identifier}",
(ctx, identifier) => {
return new Person({
id: ctx.getActorUri(identifier), // ✅ Correct
name: "Example User",
inbox: ctx.getInboxUri(identifier),
outbox: ctx.getOutboxUri(identifier),
followers: ctx.getFollowersUri(identifier),
// ... other required properties
});
},
);Run Deno's linter with the plugin enabled:
deno lintYou can also specify which files or directories to lint:
deno lint federation.ts
deno lint src/federation/Set up your ESLint configuration as shown above and add a follwing script on
package.json:
After setting up the configuration, run ESLint on your codebase:
::: code-group
npm run lintpnpm lintyarn lintbun lint:::
or run the linter directly via command line:
::: code-group
npx eslint .pnpx eslint .yarn eslint .bunx eslint .:::
{ "scripts": { "lint": "eslint ." } }