Add filter task to filter jsonl events by policy
This commit is contained in:
parent
420a086f1d
commit
8dc9f73bfd
20
README.md
20
README.md
@ -177,6 +177,26 @@ Please look directly at `src/policies` in this repo. The files include detailed
|
|||||||
|
|
||||||
![Policies TypeScript](https://gitlab.com/soapbox-pub/strfry-policies/uploads/dfb993b3464af5ed78bb8e5db8677458/Kazam_screencast_00090.webm)
|
![Policies TypeScript](https://gitlab.com/soapbox-pub/strfry-policies/uploads/dfb993b3464af5ed78bb8e5db8677458/Kazam_screencast_00090.webm)
|
||||||
|
|
||||||
|
## Filtering jsonl events with your policy
|
||||||
|
|
||||||
|
It is not currently possible to retroactively filter events on your strfry relay. You can however export the events with `strfry export`, filter them locally, and then import them into a fresh database. You can also use this command to filter Nostr events from any source, not just strfry.
|
||||||
|
|
||||||
|
To do so, run:
|
||||||
|
|
||||||
|
```sh
|
||||||
|
cat [EVENTS_FILE] | deno task filter [POLICY_CMD] > [OUT_FILE]
|
||||||
|
```
|
||||||
|
|
||||||
|
For example:
|
||||||
|
|
||||||
|
```sh
|
||||||
|
cat events.jsonl | deno task filter ./my-policy.ts > filtered.jsonl
|
||||||
|
```
|
||||||
|
|
||||||
|
Accepted messages will be written to stdout, while rejected messages will be skipped. Also, `[POLICY_CMD]` can be _any_ strfry policy, not just one created from this repo.
|
||||||
|
|
||||||
|
The command wraps each event in a strfry message of type `new`, with an `IP4` source of `127.0.0.1`, and a timestamp of the current UTC time. Therefore you may want to avoid certain policies such as the `rateLimitPolicy` that don't makes sense in this context.
|
||||||
|
|
||||||
## License
|
## License
|
||||||
|
|
||||||
This is free and unencumbered software released into the public domain.
|
This is free and unencumbered software released into the public domain.
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
{
|
{
|
||||||
"tasks": {
|
"tasks": {
|
||||||
"test": "deno test --allow-read --allow-write"
|
"test": "deno test --allow-read --allow-write",
|
||||||
|
"filter": "deno run -A scripts/filter.ts"
|
||||||
},
|
},
|
||||||
"lint": {
|
"lint": {
|
||||||
"files": {
|
"files": {
|
||||||
|
0
entrypoint.example.ts
Normal file → Executable file
0
entrypoint.example.ts
Normal file → Executable file
32
scripts/filter.ts
Normal file
32
scripts/filter.ts
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
import { readLines } from '../src/deps.ts';
|
||||||
|
|
||||||
|
import type { Event, InputMessage, OutputMessage } from '../mod.ts';
|
||||||
|
|
||||||
|
for await (const line of readLines(Deno.stdin)) {
|
||||||
|
const event: Event = JSON.parse(line);
|
||||||
|
|
||||||
|
const input: InputMessage = {
|
||||||
|
type: 'new',
|
||||||
|
event: event,
|
||||||
|
receivedAt: Date.now() / 1000,
|
||||||
|
sourceType: 'IP4',
|
||||||
|
sourceInfo: '127.0.0.1',
|
||||||
|
};
|
||||||
|
|
||||||
|
const policy = Deno.run({
|
||||||
|
cmd: Deno.args,
|
||||||
|
stdin: 'piped',
|
||||||
|
stdout: 'piped',
|
||||||
|
});
|
||||||
|
|
||||||
|
await policy.stdin.write(new TextEncoder().encode(JSON.stringify(input)));
|
||||||
|
policy.stdin.close();
|
||||||
|
|
||||||
|
for await (const out of readLines(policy.stdout)) {
|
||||||
|
const msg: OutputMessage = JSON.parse(out);
|
||||||
|
|
||||||
|
if (msg.action === 'accept') {
|
||||||
|
console.log(JSON.stringify(event));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user