Go to file
Sascha Nitsch 0d3a7c871b support for local users with extra-data needed for activity-pub 2024-07-19 20:37:09 +02:00
.phan mainenance functionality to run database updates for new releases 2024-07-19 18:41:44 +02:00
htdocs fixed errors found by phan 2024-07-17 21:37:02 +02:00
php support for local users with extra-data needed for activity-pub 2024-07-19 20:37:09 +02:00
plugins support for local users with extra-data needed for activity-pub 2024-07-19 20:37:09 +02:00
sql support for local users with extra-data needed for activity-pub 2024-07-19 20:37:09 +02:00
.gitignore documentation updates 2024-07-17 15:45:19 +02:00
Doxyfile documentation updates 2024-07-17 15:45:19 +02:00
README.md mainenance functionality to run database updates for new releases 2024-07-19 18:41:44 +02:00
composer.json initial import 2024-07-17 00:03:39 +02:00
config.ini mainenance functionality to run database updates for new releases 2024-07-19 18:41:44 +02:00
maintenance.php mainenance functionality to run database updates for new releases 2024-07-19 18:41:44 +02:00
phpdoc.dist.xml documentation updates 2024-07-17 15:45:19 +02:00
progress.md support for local users with extra-data needed for activity-pub 2024-07-19 20:37:09 +02:00
rediscache.ini support for local users with extra-data needed for activity-pub 2024-07-19 20:37:09 +02:00
release.sh documentation updates 2024-07-17 15:45:19 +02:00

README.md

A system to connect non-federated system to federation (ActivityPub)

NOTE: this is work in progress, it is nowhere near completion nor function

installation

install dependencies by using

composer install

Upload/copy the files to a directory where php can be run from. The files in the htdocs should be the only reachable, the others should not be served via the web server. Structure:

  • htdocs <= reachable
  • php <= implementation
  • plugins <= plugin directory for well - plugins
  • config.ini <= the configuration

The default config includes a dummy plugin to connect to a non-exisitng server. It accepts any session id and profile name. The database is not used yet, but it must be created and the user with given account data must be able to reach it.

Needed SQL commands:

create database federator;
create user if not exists 'federator'@'localhost' identified by '*change*me*';
grant select,insert,update,delete on federator.* to 'federator'@'localhost';
create user if not exists 'federatoradmin'@'localhost' identified by '*change*me*as*well';
grant all privileges on federator.* to 'federatoradmin'@'localhost';

This will be changed, but works for the current develop verison.

If the include redis cache is enabled, create a users.acl for redis with the content:

user federator on ~u_* +get +set >redis*change*password

change password in the rediscache.ini to match your given password.

To configure an apache server, add the following rewrite rules:

<Directory /where/ever/you/put/it>
  RewriteEngine on
  RewriteBase /
  RewriteRule ^api/(.+)$ api.php?_call=$1 [L]
</Directory>

With the dummy plugin and everything installed correctly a

curl -v http://localhost/api/v1/dummy/moo -H "X-Session: somethingvalid" -H "X-Profile: ihaveone"

should return a piece of ascii art.