Skip to content

Latest commit

 

History

History
99 lines (69 loc) · 3.91 KB

Developing.md

File metadata and controls

99 lines (69 loc) · 3.91 KB

Developing with the server

The easiest way to get going with custom development of the Alkemio Server is to leverage the Docker Compose script as detailed in the Running the server document.

In this setup you are then using the docker composed stack for:

  • Database container
  • Ory Kratos stack for development:
    • ory/kratos
    • ory/oathkeeper
    • ory/mailslurper (not used on production)

Note that the CT Server from the docker composed stack is listening on port 4001 instead of port 4000, so it will not collide with running a second server locally - but do keep in mind those two server instances are sharing the same data / authentication provider.

Assuming you have a suitable database server and authentication provider available then please follow the following steps:

Steps

  • Install dependencies
npm install
  • Start the server
npm start

There should now be a running Alkemio server!

MySQL Database

It is of course also possible to use a separate MySQL database server.

If installing MySQL locally, please refer to the data management document if using MySQL 8.

Authentication

The authentication is handled by Ory Kratos and Ory Oathkeepr.

Best way to run the ory stack is to the use provided docker scripts. See Running the server document.

The configuration for the Ory can be found in ./build/ory. The verification and recovery flows templates can be edited in ./build/ory/kratos/courier-templates. More information how to customize them here. They are using golang templates format.

The registration and the recovery flows include sending emails to the registered users. For development purposes the fake smtp server Mailslurper is used. Can be accessed on http://localhost:4436/ (if the docker compose method has been used to setup the development environment).

File uploads

In order to upload files, a file stream is created through GraphQL Upload to the server /uploads folder. From there the file is pinned in IPFS and CID is returned.

Install jq (on linux) if you don't have it:

sudo apt-get install jq

Login with demo auth provider and extract the access token:

actionUrl=$(\
    curl -s -X GET -H "Accept: application/json" \
    "http://localhost:3000/ory/kratos/public/self-service/login/api" \
    | jq -r '.ui.action'\
    )
sessionToken=$(\
curl -s -X POST -H  "Accept: application/json" -H "Content-Type: application/json" \
    -d '{"password_identifier": "[email protected]", "password": "your_password", "method": "password"}' \
    "$actionUrl" | jq -r '.session_token' \
    )

You can test (assuming default endpoint configuration) creating a file and then uploading it with the following CURL request:

touch hello-alkemio.pdf

curl http://localhost:3000/api/private/non-interactive/graphql \
  -H "x-apollo-operation-name: UploadFile" \
  -H "Authorization: Bearer $sessionToken" \
  -F 'operations={
    "query":"mutation ($file: Upload!, $uploadData: StorageBucketUploadFileOnReferenceInput!) { uploadFileOnReference(file: $file, uploadData: $uploadData) { id } }",
    "variables": {
      "file": null,
      "uploadData": {
        "referenceID": "YOUR_REFERENCE_ID"
      }
    }
  }' \
  -F 'map={"0":["variables.file"]}' \
  -F [email protected]

You should get a response: {"data":{"uploadFile":"https://ipfs.io/ipfs/QmYt9ypyGsR1BKdaCGPdwdBgAiuXK5AYN2bGSNZov7YXuk"}}. This file should be accessible (assuming default IPFS installation) on http://localhost:8080/ipfs/QmYt9ypyGsR1BKdaCGPdwdBgAiuXK5AYN2bGSNZov7YXuk or on a public IPFS on https://ipfs.io/ipfs/QmYt9ypyGsR1BKdaCGPdwdBgAiuXK5AYN2bGSNZov7YXuk. If the upload worked, you should see 'Hello Alkemio!' in the browser :)