CCF backend services
- Start the docker container:
docker run -p 1210:1210 --name=ccf --rm -it ghcr.io/knaw-huc/service-huc-editor:2.0-RC3
- Initialize the HelloWorld app:
curl -v -X PUT -H 'Authorization: Bearer foobar' http://localhost:1210/app/HelloWorld
- Visit the HelloWorld app:
http://localhost:1210/app/HelloWorld
- Visit the API documentation:
- Take a look at the logs:
Next to the docker container log there is a more extensive log inside the container at /home/huc/huc-editor-service/logs/huc-editor-service.log
- admin API key:
foobar
htp.test
: usertest
with passwordtest
ALWAYS change these when running a CCF production deployment!
Create or select a CMDI profile in/from the Component Registry
Note: CCF limitations!
- don't use attributes, as they are tied to XML and don't have a decent counterpart in JSON, RDF, ...
Remember the ID of your profile, which can be seen in its XML representation, e.g. clarin.eu:cr1:p_1721373444008
:
<ComponentSpec isProfile="true" CMDVersion="1.2" CMDOriginalVersion="1.2">
<Header>
<ID>clarin.eu:cr1:p_1721373444008</ID>
<Name>ShowcaseForm</Name>
<Description>A showcase profile for the CLARIAH CMDI Forms</Description>
<Status>development</Status>
</Header>
...
</ComponentSpec>
With release image:
docker run -v ./conf:/home/huc/huc-editor-service/conf -v ./data:/home/huc/huc-editor-service/data -p 1210:1210 --name=ccf --rm -it ghcr.io/knaw-huc/service-huc-editor:2.0-RC3
With local image:
docker build -t ccf .
docker run -v ./conf:/home/huc/huc-editor-service/conf -v ./data:/home/huc/huc-editor-service/data -p 1210:1210 --name=ccf --rm -it ccf
This mounts both the local
- conf directory, containing the global configuration
- data directory, which will contain the app configuration, the profile, its tweak(s) and records
curl -v -X PUT -H 'Authorization: Bearer foobar' http://0.0.0.0:1210/app/myApp?prof=clarin.eu:cr1:p_1721373444008&desrc="my Application"
To add cues to the profile you can download a template tweak file for your profile:
http://localhost:1210/app/helloWorld/profile/clarin.eu:cr1:p_1721373444008/tweak/template
This template replicates the full structure of the profile, but this is not needed: only the path to the components or the elements that are tweaked are needed.
<ComponentSpec xmlns:clariah="http://www.clariah.eu/" xmlns:cue="http://www.clarin.eu/cmd/cues/1" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" isProfile="true" CMDVersion="1.2" CMDOriginalVersion="1.2" xsi:noNamespaceSchemaLocation="https://infra.clarin.eu/CMDI/1.x/xsd/cmd-component.xsd">
<Header>
<ID>clarin.eu:cr1:p_1721373444008</ID>
<Name>ShowcaseForm</Name>
<Description>A showcase profile for the CLARIAH CMDI Forms</Description>
<Status>development</Status>
</Header>
<Component name="ShowcaseForm">
<Element name="Hello">
<clariah:label xml:lang="fr">Bonjour</clariah:label>
<clariah:label xml:lang="nl">Hallo</clariah:label>
</Element>
</Component>
</ComponentSpec>
To create a tweak file use:
curl -X POST -H 'Authorization: Bearer foobar' -H 'Content-Type: application/xml' http://localhost:1210/app/helloWorld/profile/clarin.eu:cr1:p_1721373444008/tweak -v --data-binary '@./tweak.xml'
This will return you the location of the tweak file created, e.g., http://localhost:1210/app/helloWorld/profile/clarin.eu:cr1:p_1721373444008/tweak/1
An specfic tweak file can be updated using PUT
, e.g.,
curl -X PUT -H 'Authorization: Bearer foobar' -H 'Content-Type: application/xml' http://localhost:1210/app/helloWorld/profile/clarin.eu:cr1:p_1721373444008/tweak/1 -v --data-binary '@./tweak.xml'
Or deleted, e.g.:
curl -v -X PUT -H 'Authorization: Bearer foobar' http://localhost:1210/app/helloWorld/profile/clarin.eu:cr1:p_1721373444008/tweak/1
Note: the tweak file is not actually deleted on disk, but marked as such.
Multiple tweak files can exist and will be applied in order. The (future) purpose is to have dedicated tweak files for labels in specific languages, or a tweak file for indexing details. The result can be seen by requesting the profile, e.g., http://localhost:1210/app/helloWorld/profile/clarin.eu:cr1:p_1721373444008
Here some example tweak files can be found:
- clariah vocabulary
- hi data envelopes
- hi nde
- iisg adoptie (HuC only)
- iisg afstand (HuC only)
- niod yugo dre
The next sections list the cues you can add to elements and components.
Since CMDI 1.2 cues for tools can be specified. CCF supports the following cues using this mechanism:
cue:class
: will add this as a CSS class, which can be used to style the elememt or component or to associate JavaScript triggers;cue:displayOrder
: change the order of the elements or components; this allows to mix them in the editor, which can't be done in the profile specificationcue:hide
: if set totrue
this element or component won't be shown in the editor.cue:inputHeight
: change how many lines an input box is;cue:inputWidth
: change how many characters width an input box is;cue:readonly
: if set totrue
the value of this element can't be changed;
Cues are attributes in the namespace http://www.clarin.eu/cmd/cues/1
on the element or component tag, e.g.,
<Element name="begeleidendeInstantiesPersonen" xmlns:cue="http://www.clarin.eu/cmd/cues/1" cue:displayOrder="45" cue:inputWidth="80" cue:inputHeight="6">
CMDI cues being attributes don't work together with xml:lang
language attributes. To resolve this CCF uses the label
element in the http://www.clariah.eu/
namespace for multilingual labels, e.g.,
<Element name="Hello" xmlns:clariah="http://www.clariah.eu/">
<clariah:label xml:lang="fr">Bonjour</clariah:label>
<clariah:label xml:lang="nl">Hallo</clariah:label>
</Element>
Note: CCF doesn't support the CMDI external vocabularies syntax yet!
Currently you can specify an autocompleteURL
in the http://www.clariah.eu/
namespace:
<Element name="researchActivity" cue:class="skosType" xmlns:clariah="http://www.clariah.eu/">
<clariah:autoCompleteURI>/proxy/skosmos/sd/tadirah</clariah:autoCompleteURI>
</Element>
The URI follows the follow pattern:
proxy
: use the CCF proxy- the proxy
recipe
, e.g.,skosmos
- a specific
instance
of the recipe, e.g.,sd
(see ./resources/proxies/ for an overview) - a vocab in that instance, e.g.,
tadirah
Note: add the cue:class="skosType"
to get an icon to open up a dialog for browsing the vocabulary next to the default autocomplete.
CMDI 1.2 also added a way to specify auto values for an element, here the CCF supports:
now
for a date value scheme, will set the element to the current date
<Element name="modified">
<AutoValue>now</AutoValue>
</Element>
In the tweak file propererties of elements can be changed within limits:
- minimum and maximum cardinality within the original bounds
- a vocabulary can be added as long as the values match the original value scheme
The configuration of the app can be retrieved:
curl -v -X GT -H 'Authorization: Bearer foobar' http://localhost:1210/app/HelloWorld/config
.toml
To update the config.toml
use PUT
with application/toml
as the Content-Type
:
curl -X PUT -H 'Authorization: Bearer foobar' -H 'Content-Type: application/toml' http://localhost:1210/app/HelloWorld/config -v --data-binary '@./config.toml'
Here are some example configurations:
- clariah vocabulary
- hi data envelopes
- hi nde
- iisg adoptie (HuC only)
- iisg afstand (HuC only)
- niod yugo dre
Set the version of CMDI to be used for record serialisation.
[app]
cmdi_version="1.2" #or 1.1, which is (for legacy reasons) the default
An app is based on one or more CMD profiles. There should be at least one profile and one profile should be the default:
[app]
def_prof="clarin.eu:cr1:p_1721373444008"
Each profile needs to have an id, e.g. HelloWorld
and a main entry in the config:
[app.prof.HelloWorld]
prof="clarin.eu:cr1:p_1721373444008"
title="string((/cmd:CMD/cmd:Components//cmd:*[empty(cmd:*)][normalize-space(text())!=''])[1])" #for CMDI version 1.1
#title="string((/cmd:CMD/cmd:Components//cmdp:*[empty(cmdp:*)][normalize-space(text())!=''])[1])" #for CMDI version 1.2
The title
XPath is used to retrieve the title of the record in the HTML and PDF views (note: the cmd
and cmdp
namespace prefixes are available and set compliant with the configured CMDI version).
The per profile record list contains by default the creation date of the record, but other fields can be added in the apps configuration, e.g.,
[app.prof.HelloWorld.list.who]
xpath="string(/cmd:CMD/cmd:Components/cmd:ShowcaseForm/cmd:Hello)" # for CMDI 1.1
# xpath="string(/cmd:CMD/cmd:Components/cmdp:ShowcaseForm/cmdp:Hello)" # for CMDI 1.1
label="Hello"
sort="true"
filter="true"
where
who
is the id of the column;xpath
retrieves the value from the record (note: thecmd
andcmdp
namespace prefixes are available and set compliant with the configured CMDI version);label
is the header of the column;sort
indicates if the column is sortable by clicking on the headerfilter
indicates if the column has a filter where you can type (true
) or a dropdown of the possible values ('select'
, note: the single quotes are mandatory!)
Set a CSS style that overwrites the default CSS style, e.g.:
[app.html]
style="data-envelopes.css"
This CSS file should be placed in the static/css/
directory within the app
directory, e.g., .../apps/data-envelopes/static/css/data-envelopes.css
.
Note: CCF doesn't support SSO yet!
User based access control is currently supported via htpasswd, e.g.:
htpasswd -b -c ./htp test test
To configure access control in the config add an app.access
section, e.g.:
[app.access]
users="./htp"
read="users"
write="users"
where
users
points to the htpassword file;read
indicates who have read access: authenticatedusers
orany
(default)write
indicates who have write access: authenticatedusers
orany
(default)
Note: under development!
[app.hooks.record]
create="create_record"
#read=
#update=
#delete=
Place hooks.py
in in the src/
directory within the app
directory, e.g., .../apps/vocabs/src/hooks.py
.
import logging
def create_record(app: str, prof: str, rec: str):
logging.debug((f"record[{rec}] created!"))
Global settings can be edited in the TOML file.
The token for the admin API is set in the :
[default]
SERVICE_HUC_EDITOR_API_KEY="foobar"
Note: you MUST change this token in production!