Rust implementation of outpack
.
This crate provides an outpack
command which can be used to create and operate on Outpack repositories.
The command can be built with cargo build
, after which it can be found in target/debug/outpack
.
Alternatively it can be started directly by using cargo run
.
outpack init --use-file-store <path>
outpack query --root <path> <query>
The outpack
command includes an API server which can be used to expose the
repository over an HTTP interface.
outpack start-server --root <path>
docker run --name outpack_server -v /full/path/to/root:/outpack -p 8000:8000 -d mrcide/outpack_server:main
The outpack schema is imported into this package by running ./scripts/import_schema
,
and needs to be kept manually up to date by re-running that script as needed.
Run all tests with cargo test
.
{
"status": "succcess",
"data": {
"schema_version": "0.0.1"
},
"errors": null
}
Returns hash of all current packet ids, ordered alphanumerically and concatenated. This will use the hashing algorithm specified
in the outpack
config, unless a query parameter specifying an alternative is passed:
e.g. /checksum?alg=md5
.
{
"status": "succcess",
"data": "md5:117723186364b4b409081b1bd347d406"
"errors": null
}
{
"status": "success",
"errors": null,
"data": [
{
"packet": "20220812-155808-c873e405",
"time": "2022-08-12 15:58:08",
"hash": "sha256:df6edb3d6cd50f5aec9308a357111592cde480f45a5f46341877af21ae30d93e"
},
{
"packet": "20220812-155808-d5747caf",
"time": "2022-08-12 15:58:08",
"hash": "sha256:edc70ef51e69f2cde8238142af29a9419bb27c94b320b87e88f617dfc977a46b"
},
{
"packet": "20220812-155808-dbd3ce81",
"time": "2022-08-12 15:58:08",
"hash": "sha256:a7da8c3464a2da4722b9d15daa98eb13f4f8c1949c6d00100428b2e9d0668f29"
},
{
"packet": "20220812-155808-e21bc5fc",
"time": "2022-08-12 15:58:08",
"hash": "sha256:df1b91aaf3393483515ac61596aa35117891eacc533a55ec2f4759d0036514f9"
}
]
}
Returns a list of (truncated) packet metadata.
Accepts an optional query parameter known_since
specifying a Unix epoch time
from which to return results. This will filter packets by the time
property of the
location metadata, i.e. the point at which they were inserted into the index.
e.g. /packit/metadata?known_since=1683117048
.
{
"status": "success",
"errors": null,
"data": [
{
"id": "20220812-155808-c873e405",
"name": "depends",
"custom": { "orderly": { "display": "Report with dependencies" }}
"parameters": null
},
{
"id": "20220812-155808-d5747caf",
"name": "params",
"custom": { "orderly": { "display": "Report with parameters" }},
"parameters": { "alpha": 1 }
}
]
}
{
"status": "success",
"errors": null,
"data": {
"custom": null,
"depends": [],
"files": [
{
"hash": "sha256:e9aa9f2212aba6fba4464212800a2927afa02eda688cf13131652da307e3d7c1",
"path": "orderly.yml",
"size": 955
},
{
"hash": "sha256:11a2cd93493defa673b198d5be7a180cef7b133baaacc046923e1e2da77c6f75",
"path": "modified_update.R",
"size": 1133
},
{
"hash": "sha256:c4d4c95af9da912f2f20c65a0502c7da19a5712767a39e07a2dd1ea7fcb615b0",
"path": "R/util.R",
"size": 2757
}
],
"id": "20170818-164043-7cdcde4b",
"name": "modup-201707",
"parameters": null,
"schema_version": "0.0.1",
"script": [
"modified_update.R"
],
"session": {
"packages": [
{
"attached": true,
"package": "RcppRoll",
"version": "0.2.2"
},
{
"attached": false,
"package": "Rcpp",
"version": "0.12.12"
},
{
"attached": false,
"package": "ids",
"version": "1.0.1"
}
],
"platform": {
"os": "Debian GNU/Linux 9 (stretch)",
"system": "x86_64, linux-gnu",
"version": "R version 3.4.0 (2017-04-21)"
}
},
"time": {
"end": 1503074545.8687,
"start": 1503074545.8687
}
}
}
Returns the same as GET /metadata/<id>/json
but just the data as plain text.
Downloads the file with the provided hash. 404 if it doesn't exist.
{
"ids": ["20220812-155808-c873e405","20220812-155808-d5747caf"],
"unpacked": false
}
Given a list of ids, returns those that are missing in the current root. If unpacked
is true
returns missing unpacked packets, otherwise just looks at missing metadata.
{
"status": "success",
"errors": null,
"data": ["20220812-155808-c873e405", "20220812-155808-d5747caf"]
}
{
"hashes": [
"sha256:b189579a9326f585d308304bd9e03326be5d395ac71b31df359ab8bac408d248",
"sha256:a189579a9326f585d308304bd9e03326be5d395ac71b31df359ab8bac408d247"
]
}
Given a list of file hashes, returns those that are missing in the current root.
{
"status": "success",
"errors": null,
"data": ["sha256:a189579a9326f585d308304bd9e03326be5d395ac71b31df359ab8bac408d24"]
}
Upload a file with the given hash. Returns a 400 if the hash does not match the file contents. This method is idempotent; if the file already exists it will not do anything.
The file contents should be written directly to the request body.
{
"status": "success",
"errors": null,
"data": null
}
Upload packet metadata with the given hash. Returns a 400 if the hash does not match the contents. This method is idempotent; if the file already exists it will not do anything.
The metadata should be written directly to the request body.
{
"status": "success",
"errors": null,
"data": null
}
Does a git fetch on the repository (relevant for when runners clone down git repositories). Expects an empty json body.
Returns an array of branches with their name
, commit_hash
(where branch pointer is), time
(of last commit) and message
(of last commit in a string array split with respect to newline characters)
{
"status": "success",
"data": {
"default_branch": "main",
"branches": [
{
"name": "main",
"commit_hash": "ede307e23b2137ba2c7c3270e52f354f224942af",
"time": 1722436575,
"message": ["First commit"]
},
{
"name": "other",
"commit_hash": "e9078cf779584168c3781379380a3b1352545cda",
"time": 1722436640,
"message": ["Second commit"]
}
]
},
"errors": null
}
This crate provides Python bindings for its query parser. See README.python.md for details.
- Increment the version field in
Cargo.toml
. - Run
cargo fetch
to update the version field ofCargo.lock
. - Create a new pull request with these changes.
- Get the PR approved and merged to main.
- Create a GitHub release:
- Set the tag name as
vX.Y.Z
, matching the version used inCargo.toml
. - Write some release notes (possibly using the
Generate release notes
button). - Publish the release!
- Set the tag name as
- Sit back and relax while the release gets built and published.
- Check that the new version is available on PyPI.
MIT © Imperial College of Science, Technology and Medicine