FOLIO Workflow CLI
git submodule update --init --recursive
yarn install
yarn build
yarn link
fw
Provides mock /authn/login
and /user-import
.
yarn okapi
vagrant up release
Update Vagrantfile
with a synced directory to fw-cli for mod-workflow and mod-camunda development.
snapshot.vm.synced_folder "C:/Users/FOLIO/Development/work/FOLIO/fw-cli", "/home/vagrant/fw-cli", owner: "vagrant", group: "vagrant", mount_options: ["uid=1000", "gid=1000"]
Be sure to update the host machine path.
vagrant up snapshot
Wait for Okapi to start all the modules.
vagrant ssh snapshot
Check to see if Okapi is ready.
docker logs okapi -n 100 -f
Goto http://localhost:3000 and login.
cd spring-module-core
# git checkout <branch>
mvn clean package
cd ../mod-workflow
# git checkout <branch>
mvn clean package
cd ../mod-camunda
# git checkout <branch>
mvn clean package
vagrant ssh snapshot
From /home/vagrant
:
cd fw-cli
cd mod-workflow
docker build -t docker.ci.folio.org/mod-workflow:1.2.0-SNAPSHOT .
cd ../mod-camunda
docker build -t docker.ci.folio.org/mod-camunda:1.2.0-SNAPSHOT .
Update versions according to corresponding pom.xml
A bare minimum setup script setup.js
is available to perform the necessary requests to run the modules with Okapi. This requires the previous steps of building jar files and module descriptors on the host and building the Docker images on the Vagrant VM.
From /home/vagrant/fw-cli
:
node ./setup.js
The following permissions are required. There is additional ui-workflow permissions required when bundling and running ui-workflow with stripes. This is not yet available in folio/snapshot and is not provided here.
"workflow.actions.all",
"workflow.events.all",
"workflow.nodes.all",
"workflow.nodes.item.post",
"workflow.triggers.all",
"workflow.tasks.all",
"workflow.workflows.all",
"camunda.history.all",
"camunda.message.all",
"camunda.process.all",
"camunda.process-definition.all",
"camunda.decision-definition.all",
"camunda.task.all",
"camunda.workflow-engine.workflows.all"
docker run -d --name kafka-ui --user 1000:1000 -p 8080:8080 -e KAFKA_CLUSTERS_0_NAME=folio -e KAFKA_CLUSTERS_0_BOOTSTRAPSERVERS=10.0.2.15:9092 -e KAFKA_CLUSTERS_0_ZOOKEEPER=10.0.2.15:2181 provectuslabs/kafka-ui:latest
Open http://localhost:8080 in the browser to see the kafka-ui interface.
cd mod-workflow
cd components
mvn clean install
cd ..
cd service
mvn clean spring-boot:run
In another terminal from fw-cli
.
cd mod-camunda
mvn clean spring-boot:run
remember to update your config working directory and configuration,
fw -c
Set the appropriate configurations.
Abbreviated config:
fw -c
{
"wd": "./fw-registry",
"okapi": "https://folio-okapi-r1.library.tamu.edu",
"tenant": "tamu",
"username": "tamu_admin",
"password": "***",
"mod-camunda": "https://folio-edge.library.tamu.edu/mod-camunda"
}
e.g.
fw config set tenant tamu
Login to get a Okapi token.
fw login
Lookup user.
fw user tamu_admin
Follow configuration, build, activate and run commands for workflows.
Cron triggered workflow to import create/update patrons from central IT database.
Manual triggered workflow to build orcid report for Scholars.
Cron triggered workflow to build ISBN report for GOBI.
Manual triggered workflow to build e-resource views in central IT database.
Manual triggered workflow to create composite purchase orders and the inventory from MARC records.
Cron triggered workflow to build and email circulation fees/fines paid daily report.
Cron triggered workflow to build and gzip Rapid ILS monthly print serials report.
Cron triggered workflow to build and gzip Rapid ILS monthly print monos report.
Cron triggered workflow to copy SFX Utility output and gzip Rapid ILS monthly electronic serials report.
Cron triggered workflow to run coral extract to create/update instances and holdings in FOLIO.
Manual triggered workflow to build multiple reports for HathiTrust upload.
Manual triggered workflow to create Notes within FOLIO.
Manual triggered workflow to create Tags within FOLIO.
Manual triggered workflow to build, zip, and email shelflist (holdings level) report.
Cron triggered workflow to run update item history.
Cron triggered workflow to run adding a special Note to New Bookshelf Items.
Manual triggered workflow to build, zip, and email list of checked out books by call number.
Manual triggered workflow with CSV of call numbers input that updates corresponding items temporary location and temporary loan type effectively removing them from the new bookshelf.
Cron triggered workflow to send monthly report to email specified by 'evansPresReprFrom' variable. The report includes items having 'temporary location' set to "Eva Pres Repr".
Cron triggered workflow to email quarterly instance duplication report.