You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
Drew Short 9d0af0a5e6 Remove size only restriction for link copying 6 years ago
assets Remove size only restriction for link copying 6 years ago
.dockerignore Initial commit 6 years ago
.gitignore Setup to use the loaded config file 6 years ago
Dockerfile Removed deprecated MAINTAINER field 6 years ago
LICENSE Initial commit 6 years ago
README.md Adding linkDestination feature 6 years ago
pipeline.yml Pointed pipeline to public resource 6 years ago
tag Remove size only restriction for link copying 6 years ago
upload_pipeline.sh Address shell check complaints 6 years ago

README.md

concourse-rclone-resource

A Concourse CI resource that executes rclone against a remote host.

See Docker Hub for tagged image versions available.

Resource Type Configuration

resource_types:
- name: rclone
  type: docker-image
  source:
    repository: sothr/concourse-rclone-resource
    tag: latest

Source Configuration

  • config: Required. The rclone config file contents to use.
  • password: Optional. Encryption password used for encrypted rclone configurations. Please use secrets management for this value.
  • files: Optional. Additional files to write to the /tmp/rclone directory. This is a map of key/value pairs for the filename and contents of that file.

Example

resources:
- name: rclone
  type: rclone
  source:
    config: |
      [remote]
      client_id = <Your ID>
      client_secret = <Your Secret>
      scope = drive
      root_folder_id = <Your root folder id>
      service_account_file = /tmp/rclone/serviceAccountFile
      token = {"access_token":"XXX","token_type":"Bearer","refresh_token":"XXX","expiry":"2014-03-16T13:57:58.955387075Z"}
    files:
      serviceAccountFile: |
        ...contents...

Note

It's highly recommended to use secrets mangement to avoid storing sensitive credentials in the pipeline

Behaviour

check: No-Op

in: No-Op

out: Execute rclone

Parameters

  • source: Required. The path to the source files.
  • destination: Required. A list of destinations to copy files to.
    • dir: Required. A rclone destination for the files. ex. remote:some/location
    • subdir: Optional. A file that includes additional path information to be appended to the end of destination.
    • command: Optional. The rclone command to run. Default copy
      • copy (default)
      • copyto (default)
      • move
      • sync
    • args: Optional. An array of additional arguments to pass to rclone.
    • dedupe: Optional. Run rsync dedupe after syncing files. Default false
    • dedupeMode: Optional. The dedupe mode to use. Default newest. rclone dedupe
      • skip
      • first
      • newest (default)
      • oldest
      • largest
      • rename
    • link: Optional. Create a link to the resource if possible. Default false
    • linkFilter: Optional. A find filter on the source directory for files to generate links to. Default -maxdepth 1 -type f
    • allowFailure: Optional. Allow this destination to fail without failing the job. Default false
  • linkDestination: Optional. Rclone location to store the generated link data.
  • linkDestinationSubDir: Optional. A file that includes additional path information to be appened to the end of the linkDestination.

Example

# Extends example in Source Configuration

jobs:
- name:
  plan:
  - do:
    - get: code # git resource
    - put: rclone
      params:
        source: code
        destination: 
          - dir: "remote:backup"
            subdir: code/target
          - dir: "remote2:release"

License

Copyright 2020 Drew Short

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.