Service to provide consistent file numbering and naming for unrelated data acquisition applications.
The service is written in rust and requires the default toolchain and recent version of the compiler (1.81+). This is available from rustup.rs.
-
Clone this repository
$ git clone [email protected]:DiamondLightSource/numtracker.git Cloning into 'numtracker'... ... $ cd numtracker
-
Build the project
$ cargo build Compiling numtracker v0.1.0 (./path/to/numtracker) ... Finished 'dev' profile [unoptimized + debuginfo] target(s) in 11.56s
-
Run the service
$ cargo run serve 2024-11-04T11:29:05.887214Z INFO connect{filename="numtracker.db"}: numtracker::db_service: Connecting to SQLite DB
At this point the service is running and can be queried via the graphQL
endpoints (see the graphiql front-end available at
localhost:8000/graphiql
by default) but there are no beamlines configured.
Additional logging output is available via -v
verbose flags.
Flags | Level |
---|---|
-q |
None |
Error | |
-v |
Info |
-vv |
Debug |
-vvv |
Trace |
The schema is available via the schema
command. This is also available via the
graphiql interface.
cargo run schema
Testing queries from terminal
While the graphiql front-end can be useful for exploring the API schema, running
from the terminal is sometimes quicker/easier. This only requires curl
although jq can make it
easier to parse output.
The query to run should be made as a POST request to /graphql
wrapped in a
JSON object as {"query": "<query-string>"}
taking care to escape quotes as
required. Using curl
and a basic visit directory query (see below), this
looks something like
echo '{ 17:15:56
"query": "{
paths(beamline: \"i22\", visit: \"cm37278-5\") {
directory
}
}"
}'| curl -s -X POST 127.0.0.1:8000/graphql -H "Content-Type: application/json" -d @- | jq
There are two read only queries, one to get the visit directory for a given visit and beamline and one to get the current configuration for a given beamline.
Get the visit directory for a beamline and visit
{
paths(beamline: "i22", visit: "cm12345-6") {
directory
visit
}
}
{
"paths": {
"directory": "/data/i22/data/2024/cm37278-5",
"visit": "cm37278-5"
}
}
Get the current configuration values for the given beamline
{
configuration(beamline: "i22") {
visitTemplate
scanTemplate
detectorTemplate
latestScanNumber
}
}
{
"configuration": {
"visitTemplate": "/data/{instrument}/data/{year}/{visit}",
"scanTemplate": "{subdirectory}/{instrument}-{scan_number}",
"detectorTemplate": "{subdirectory}/{instrument}-{scan_number}-{detector}",
"latestScanNumber": 20839
}
}
mutation {
scan(beamline: "i22", visit: "cm12345-2", subdirectory: "sub/tree") {
scanFile
scanNumber
detectors(names: ["det1", "det2"] ) {
name
path
}
}
}
{
"scan": {
"scanFile": "sub/tree/i22-20840",
"scanNumber": 20840,
"detectors": [
{
"name": "det1",
"path": "sub/tree/i22-20840-det1"
},
{
"name": "det2",
"path": "sub/tree/i22-20840-det2"
}
]
}
}
mutation {
configure(beamline: "i11", config: {
visit:"/tmp/{instrument}/data/{year}/{visit}"
scan:"{subdirectory}/{instrument}-{scan_number}"
detector:"{subdirectory}/{instrument}-{scan_number}-{detector}"
scanNumber: 12345
}) {
visitTemplate
scanTemplate
detectorTemplate
latestScanNumber
}
}
}
{
"configure": {
"visitTemplate": "/tmp/{instrument}/data/{year}/{visit}",
"scanTemplate": "{subdirectory}/{instrument}-{scan_number}",
"detectorTemplate": "{subdirectory}/{instrument}-{scan_number}-{detector}",
"latestScanNumber": 12345
}
}