-
Notifications
You must be signed in to change notification settings - Fork 175
Code Customization
See also:
- Updating your LORIS
- How to make a LORIS module
- Guide to Loris React components
- Developer's Instrument Guide
- About superuser
The project/ directory is designed to house project-specific code and some data such as documents. This includes instrument forms, instrument table schemas, and any customizations to other pages or modules in the Loris codebase.
The project/ folder and its subdirectories are created by the install script, which also installs the config.xml file there.
Instrument forms (.linst or php) should be stored under project/instruments/ and their table schemas (.sql) should be stored under project/tables_sql/
- Important: Commit your project/ directory and its contents to a separate private repo - e.g. on GitHub
- Equally Important: Exclude all data and the config.xml file (which contains a database credential) stored under project/ from commits/backups to your online repo (such as on GitHub). Back up this data and the config file elsewhere on another server, using a cronjob.
It is highly recommended to keep a Readme file under the project/ directory tracking all your project's customizations. This practice will help developers and also be useful at Release upgrade time, when merging any module updates in the codebase with your custom code.
Code stored under project/modules/ and project/libraries/ and project/templates/ will override the file of the same name found in the same path under Loris root php/librariies/
- /var/www/loris/project/libraries/filename.class.inc will override /var/www/loris/php/libraries/filename.class.inc)
For projects wishing to customize existing modules, the recommended best practice is to copy all module code from $lorisroot/modules/module_name/* to a new project/modules/ subdirectory (project/modules/module_name/* ) and modify code there.
This will use the project/ override functionality of Loris. These changes should be added and committed to your project-specific private repo.
See also: