Skip to content

Latest commit

 

History

History
133 lines (87 loc) · 4.17 KB

README.md

File metadata and controls

133 lines (87 loc) · 4.17 KB

Archipelago

SemApps

Fostering interconnections between communities by creating synergies between their platforms

archipelago

A collaborative, interoperable and modular knowledge management system, compliant with most semantic web specifications: LDP, SPARQL, ActivityPub, WAC, WebID.

Based on linked data & semantic web technologies, it allows the co-production of knowledge graphs. Built on open standards, it enables the development of interoperable information systems. Designed on a modular architecture, it gives everyone the opportunity to build and customize platforms on demand. Thanks to the micro-service architecture of SemApps, it is easy to extend it with your own business logic.

Getting started

Triple store

Launch the Jena Fuseki triplestore on port 3030:

docker-compose up -d fuseki

Middleware

Add a .env.local file in the /middleware directory and fill the required OIDC configurations:

SEMAPPS_OIDC_ISSUER=
SEMAPPS_OIDC_CLIENT_ID=
SEMAPPS_OIDC_CLIENT_SECRET=

Launch the middleware on port 3000:

cd middleware
yarn install
yarn run dev

This will launch Moleculer in REPL mode, allowing you to call actions directly.

Frontend

Launch the frontend on port 4000:

cd frontend
yarn install
yarn start

Archipelago customization

If you need to customize your Archipelago, you can follow the docs below:

Linking to SemApps packages

To modify packages on the SemApps repository and see the changes before they are published on NPM, see the following instructions.

Linking backend packages

To link backend packages, you can use yarn link.

cd /SEMAPPS_REPO/src/middleware
yarn run link-all
cd /ARCHIPELAGO_REPO
yarn run link-semapps-packages

Linking frontend packages

Linking frontend packages with yarn link doesn't work because it causes version mismatch errors for React and MUI (see this PR for explainations). So you should use Yalc instead. Fortunately, we make it easy for you.

cd /SEMAPPS_REPO/src/frontend
yarn run yalc:publish
cd /ARCHIPELAGO_REPO/frontend
yarn run link-semapps-packages

Additionally, frontend packages need to be rebuilt on every changes, or they will not be taken into account by Archipelago. You can use yarn run build to build a package once, or yarn run watch to rebuild a package on every change. On every build, the new package will be published to Yalc.

Thanks to git hooks, the frontend packages will also be published to Yalc whenever git branches are changed.

Run database migrations

You can use dbMigrate script to create database migrations and/or runs them. Migrations files are created by default in middleware/migrations folder.

cd middleware
yarn run dbMigrate

# To create a new migration file
yarn run dbMigrate create --name archipelago-changeResourceAttribute

# To list all migrations
yarn run dbMigrate status

# To apply next not applied migration
yarn run dbMigration up

# To apply a given migration
yarn run dbMigration up --name archipelago-changeResourceAttribute

# To apply all not applied migrations
yarn run dbMigration up --latest

# To rollback previous applied migration
yarn run dbMigration down

# To rollback a migration
yarn run dbMigration down --name archipelago-changeResourceAttribute

# To rollback all applied migrations
yarn run dbMigration down --earliest

You can also call dbMigration actions from REPL middleware with call dbMigration.status for example.

Deploying to production

Follow the guide here.