Skip to content

cisagov/action-lineage

Folders and files

NameName
Last commit message
Last commit date

Latest commit

6d45cc9 · Feb 28, 2025
Feb 12, 2025
Feb 12, 2025
Feb 12, 2025
Jun 7, 2023
Sep 13, 2023
May 1, 2020
May 1, 2020
May 3, 2019
May 5, 2022
Oct 19, 2020
Feb 25, 2022
Feb 10, 2025
Jun 7, 2019
Nov 9, 2022
Aug 1, 2024
Jan 9, 2022
Jun 24, 2019
Jan 9, 2023
May 5, 2022
Jan 9, 2023
Sep 24, 2024
Sep 25, 2024
Sep 28, 2020
Apr 15, 2021
Jan 31, 2025
Feb 10, 2025
Jan 10, 2020

Repository files navigation

action-lineage

GitHub Build Status Lineage Scan Status CodeQL Coverage Status Known Vulnerabilities

A GitHub Action to automatically generate PR requests from upstream repositories regardless of the fork network.

Repository Lineage configuration

Lineage is configured using .github/lineage.yml in a repository. Each upstream repository is listed in the lineage section.

Key Description Required
local-branch The branch that will receive new changes. No
remote-url The https URL of the upstream repository. Yes
remote-branch The branch in the upstream repository. No

Below is an example configuration that defines two upstream repositories. The skeleton repository specifies both the source and destination branches, while the extra-sauce repository uses the default branches for both repositories.

---
version: "1"

lineage:
  skeleton:
    local-branch: develop
    remote-url: https://github.com/cisagov/skeleton-generic.git
    remote-branch: develop
  extra-sauce:
    remote-url: https://github.com/felddy/extra-skel-sauce.git

Usage

Inputs

Name Description Interpreted Type Default Required
access_token GitHub personal access token (see GitHub's documentation). string n/a yes
mask_non_public_repos Whether to mask the names of non-public (private and internal) repositories in the GitHub Actions logs. boolean true no
include_non_public_repos Whether to process non-public (private and internal) repositories. boolean false no
repo_query GitHub search query to use when finding repositories for which to create pull requests (e.g. "org:cisagov archived:false"). string n/a yes

Outputs

None.

Sample GitHub Actions workflow

The Lineage action requires a personal access token so that it may open pull requests. For public repositories this token must have the public_repo permission enabled. The token is provided using the repository secrets.

---
name: lineage_scan

on:
  schedule:
    - cron: "0 0 * * *"

env:
  ACCESS_TOKEN: ${{ secrets.ACCESS_TOKEN }}

jobs:
  cisagov:
    runs-on: ubuntu-latest
    steps:
      - name: Check all organization repositories
        uses: cisagov/action-lineage@develop
        with:
          access_token: ${{ env.ACCESS_TOKEN }}
          repo_query: "org:cisagov archived:false"

Contributing

We welcome contributions! Please see CONTRIBUTING.md for details.

License

This project is in the worldwide public domain.

This project is in the public domain within the United States, and copyright and related rights in the work worldwide are waived through the CC0 1.0 Universal public domain dedication.

All contributions to this project will be released under the CC0 dedication. By submitting a pull request, you are agreeing to comply with this waiver of copyright interest.