Skip to content

Microservice that serves the contents of a Github repo over HTTP

License

Notifications You must be signed in to change notification settings

sesam-community/github-service

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

26 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

GitHub service

A microservice that provides the contents of a file in a given GitHub repository. The contents are base64 encoded and served over HTTP. For private repositories, a deploy token with sufficient access rights must be provided.

Environment variables

GIT_REPO - The SSH URL to the repository containing the target file. Example: git@github.com:some-community/your-repo.git

DEPLOY_TOKEN - The private deploy key with clone repo rights. The same key should be added to your Sesam node so that it can be specified as a secret. Example: $SECRET(your-deploy-token)

REFRESH - If true, the repository will be cloned after each request, even if the repository already exists. Default: true

BRANCH - Which branch of the repository to retrieve files from. Default: master

SPARSE - If true, only the specified files are retrieved, rather than cloning the entire repository. Default: false

Example setup

System:

{
  "_id": "my-github-service",
  "type": "system:microservice",
  "docker": {
    "environment": {
      "DEPLOY_TOKEN": "$SECRET(deploy-token)",
      "GIT_REPO": "git@github.com:my_community/my_repo.git"
    },
    "image": "sesamcommunity/github-service:<version>",
    "port": 5000
  }
}

Pipe:

Specify the path to the file or folder relative to the root of the repository in the url parameter. The path must be prepended with /filelisting.

WARNING: If your file path contains spaces, you MUST replace them with the URL-encoded form of a space, '%20'. For example, the path /filelisting/file with spaces.txt should be /filelisting/file%20with%20spaces.txt when specifying the url parameter.

...
  {
  "source": {
    "type": "json",
    "system": "my-github-service",
    "url": "/filelisting/path/to/file"
  },
...

About

Microservice that serves the contents of a Github repo over HTTP

Resources

License

Stars

Watchers

Forks

Packages

No packages published