1.0.2 • Published 9 months ago

@accellence/run-remote-task v1.0.2

Weekly downloads
-
License
MIT
Repository
github
Last release
9 months ago

Run remote task

Adapted version of \"@antelle/run-remote-task\", with some improvements and extended support for local path, e.g. when the WebDAV repro is running on the same machine as the server instance.

=== Runs tasks on a remote machine with communication over a WebDAV server.

All messages are signed, which means you can use it even if you don't trust the WebDAV server. If data is modified in between, the task won't be executed or the result won't be accepted. It's also fine to use HTTP, unless you're concerned about data being accessible to someone else.

How it works

This diagram explains the interaction without going too deep into details:

Usage

  1. Generate two keypairs:

    openssl genrsa -out private-key-client.pem 2048
    openssl rsa -in private-key-client.pem -outform PEM -pubout -out public-key-client.pem
    
    openssl genrsa -out private-key-server.pem 2048
    openssl rsa -in private-key-server.pem -outform PEM -pubout -out public-key-server.pem
  2. Upload the keys:

    • to client boxes:
      • private-key-client.pem
      • public-key-client.pem
      • public-key-server.pem
    • to the server box:
      • private-key-server.pem
      • public-key-client.pem
      • public-key-server.pem
  3. Create a json config:

    {
        "server": "http://your-webdav-server/with-path/",
        "user": "webdav-user",
        "password": "webdav-password",
        "clientPublicKey": "path/to/public-key-client.pem",
        "serverPublicKey": "path/to/public-key-server.pem",
        "clientPrivateKey": "path/to/private-key-client.pem",
        "serverPrivateKey": "path/to/private-key-server.pem",
        "pollMillis": 5000,
        "taskExpirationMillis": 600000,
        "command": "run_task.sh",
        "commandRetries": 10
    }

    If you're using Google Cloud Storage:

    {
        "gcp": {
            "projectId": "my-project",
            "bucketName": "my-bucket",
            "credentials": {
                "client_email": "...",
                "private_key": "..."
            }
        },
        "clientPublicKey": "path/to/public-key-client.pem",
        "serverPublicKey": "path/to/public-key-server.pem",
        "clientPrivateKey": "path/to/private-key-client.pem",
        "serverPrivateKey": "path/to/private-key-server.pem",
        "pollMillis": 5000,
        "taskExpirationMillis": 600000,
        "command": "run_task.sh",
        "commandRetries": 10
    }

    If you're using AWS S3:

    {
        "aws": {
            "accessKeyId": "...",
            "secretAccessKey": "...",
            "region": "eu-central-1",
            "bucket": "my-bucket"
        },
        "clientPublicKey": "path/to/public-key-client.pem",
        "serverPublicKey": "path/to/public-key-server.pem",
        "clientPrivateKey": "path/to/private-key-client.pem",
        "serverPrivateKey": "path/to/private-key-server.pem",
        "pollMillis": 5000,
        "taskExpirationMillis": 600000,
        "command": "run_task.sh",
        "commandRetries": 10
    }

    If you like to use local storage:

    {
        "path": "path/to/data/directory",
        "clientPublicKey": "path/to/public-key-client.pem",
        "serverPublicKey": "path/to/public-key-server.pem",
        "clientPrivateKey": "path/to/private-key-client.pem",
        "serverPrivateKey": "path/to/private-key-server.pem",
        "pollMillis": 5000,
        "taskExpirationMillis": 600000,
        "command": "run_task.sh",
        "commandRetries": 10
    }

    Upload this config to both server and clients.

  4. Write your task in run_task.sh. Your task receives two environment variables:

    • INPUT: file with input data received from the client
    • OUTPUT: expected output file name that will be sent back

    Here's a hello world example:

    name=$(<$INPUT); echo "Hello, $name!">$OUTPUT
  5. Run the server:

    npx @accellence/run-remote-task --config=config.json --server
  6. Test the client:

    npx @accellence/run-remote-task --config=config.json --client --input=input.txt --output=output.txt

License

MIT

1.0.2

9 months ago

1.0.1

9 months ago

0.5.0

9 months ago