Serlo editor as LTI tool
Requirements:
- Docker 24.0.0 or later
- Node LTS
- Create a copy of
.env.template
as.env
- (optional) Add secret values to
.env
yarn
to install dependenciesyarn dev
to start the databases and the express backend & build the frontend
Now, the editor is running locally. On code changes the express server will restart and the frontend will be rebuilt.
- Go to https://saltire.lti.app/platform, sign in, navigate to "Advanced
options" and upload file
saltire-platform_[TYPE].config
of thesaltire-configs/
directory.TYPE=LTIDeepLinking
shows flow of creating a new Serlo Editor element.TYPE=LTIResourceLink_Instructor
shows flow of opening an existing Serlo Editor element as Instructor (editable).TYPE=LTIResourceLink_Learner
shows flow of opening an existing Serlo Editor element as Learner (non-editable). - Click "Connect"
yarn dev-mocks
to start the edu-sharing/itslearning mocks- Open
http://localhost:8100
(edu-sharing) orhttp://localhost:8101
(itslearning)
LTI launch is handled by ltijs.
ltijs sets up an express server.
React frontend is bundled with Vite and then provided by the /app
route in
express.
On a successful LTI launch the server returns a signed accessToken
jwt that
the client can then later use to authenticate saving content.
If you need to add a new mandatory environment variable in the .env
file, add
a type checking at src/utils/config.ts
.
The easiest way to update the .env
of the development, staging and production
environments is to do it directly in them.
- Ssh into the environment, v.g.
ssh [email protected]
if you need to change the development environment. cd ~/serlo-editor-as-lti-tool
- Modify the
.env
file, testing it accordingly if possible. Remember to restart the serlo-app servicesupervisorctl restart serlo-app
in order that the changes take place. - Upload the file to the bucket v.g.
s3cmd put .env s3://edtr-env/$USER/.env
. That way you will not only backup it but also guarantee that in the next deployment the file in the bucket will be used.
If you prefer or need to do the changes in your local machine, you have two options:
A. UI: If you have the permissions, you can login into IONOS and manage the
.env
files there using the UI. You need to download, modify and upload them.
B. CLI:
-
Ask the admin to include you into the IONOS contract and update to policy of the corresponding bucket. Alternatively, you can use the credentials of the dev or admin user.
-
Install a S3 client CLI (we recommend
s3cmd
, https://docs.ionos.com/cloud/storage-and-backup/s3-object-storage/s3-tools/s3cmd) and configure it accordingly. For access and secret keys go to https://dcd.ionos.com/latest/#/key-management. Some other info:Default Region: eu-central-3 S3 Endpoint: s3.eu-central-3.ionoscloud.com DNS-style: s3.eu-central-3.ionoscloud.com
-
Download the file you want to modify, v.g.
s3cmd get s3://edtr-env/edtrdev/.env .env.edtrdev
, change it and upload it v.g.s3cmd put .env.edtrdev s3://edtr-env/edtrdev/.env
.
If it is important for development to have something already existent in the
MariaDB, you can first add the content, and then dump it with and commit the
result in docker-entrypoint-initdb.d
.
$ yarn mariadb-reset # that way you are sure the database will be in the initial state in the next step
$ yarn mariadb # Go to the database and change whatever you need. Alternatively you can write a migration script.
$ yarn mariadb-dump # That way you don't need to change ./docker-entrypoint-initdb.d/001-init.sql by hand
$ git add ./docker-entrypoint-initdb.d
$ git commit
$ git push
Iframes can limit access to required functionality (especially for cross-origin
embedding). Make sure the iframe embedding the Serlo editor allows access to the
clipboard & allows full screen. Also, if the sandbox
attribute is present make
sure to allow allow-forms
, allow-modals
, allow-popups
, allow-scripts
and
maybe some more.
<!-- Allow for all origins (can be unsave) -->
<iframe allow="clipboard-read *; clipboard-write *; fullscreen *"></iframe>
<!-- Allow for only https://editor.serlo.org and https://editor.serlo-staging.dev -->
<iframe
allow="
clipboard-read https://editor.serlo.org https://editor.serlo-staging.dev;
clipboard-write https://editor.serlo.org https://editor.serlo-staging.dev;
fullscreen https://editor.serlo.org https://editor.serlo-staging.dev
"
></iframe>