Skip to content
This repository has been archived by the owner on Dec 5, 2024. It is now read-only.

[remote-resolution] Proof-of-Concept Controller #806

Closed
wants to merge 1 commit into from
Closed

[remote-resolution] Proof-of-Concept Controller #806

wants to merge 1 commit into from

Conversation

ghost
Copy link

@ghost ghost commented Oct 21, 2021

Changes

This commit adds a controller, several reconcilers, and a set of helpers that
all work in tandem to provide a framework for resolving Tekton resources from
places like git repos. For this proof of concept only Tekton's Pipeline type is
resolvable but in principle the solutions included here are agnostic to the
content being requested.

In more concrete terms this project will take a PipelineRun that looks like
this:

kind: PipelineRun
metadata:
  annotations:
    resolution.tekton.dev/resolver: git
    git.repo: https://github.com/sbwsg/experimental.git
    git.commit: 326ad1a1432b2144fb50f2bfd56875181a407c6b
    git.path: /remote-resolution/pipeline.yaml
spec:
  status: PipelineRunPending

and turn it in to one that looks like this:

kind: PipelineRun
metadata:
  # <same as above>
status:
  # this pipelineSpec has been pulled in from git
  pipelineSpec:
    tasks:
    - name: foo
      taskSpec:
        metadata: {}
        spec: null
        steps:
        - # ... etc ...

Here's a high level overview of the different parts in play:

  1. (Shown in the YAML above) PipelineRuns get a new syntax to indicate the
    place that a pipelineSpec should be fetched from. In this proof of concept
    that syntax takes the form of some specific annotations.

  2. A component interprets the syntax from (1) and converts it into a generic
    request for a resource. In this proof of concept the "generic request" is
    either an HTTP call or an instance of a new CRD called a ResourceRequest.
    Both have been implemented to try and figure out which approach better suits
    the project's needs.

  3. A resolver sees the request from (2) and figures out if it can respond. The
    resolver fetches the resource if so. In this proof of concept three resolvers
    have been implemented: a "noop" resolver for testing, an "in-cluster" resolver
    that can fetch pipelines from inside the cluster, and a "git" resolver that can
    fetch from public git repos.

The idea for (3) is to make writing a Resolver easy and to do so in a way that's
independent of the request format in (2). A resolver shouldn't care if the request
is coming in via HTTP or a CRD or anything else. To that end a go interface has
been introduced in the pkg/reconciler/framework directory that resolvers can
implement to hide all the boilerplate.

See remote-resolution/README.md for more details on installing and trying out
this controller.

Submitter Checklist

These are the criteria that every PR should meet, please check them off as you
review them:

  • Includes docs (if user facing)
  • Commit messages follow commit message best practices
  • Commit messages includes a project tag in the subject - e.g. [OCI], [hub], [results], [task-loops]

@tekton-robot
Copy link

[APPROVALNOTIFIER] This PR is NOT APPROVED

This pull-request has been approved by:
To complete the pull request process, please assign bobcatfish
You can assign the PR to them by writing /assign @bobcatfish in a comment when ready.

The full list of commands accepted by this bot can be found here.

Needs approval from an approver in each of these files:

Approvers can indicate their approval by writing /approve in a comment
Approvers can cancel approval by writing /approve cancel in a comment

@tekton-robot tekton-robot added size/XXL Denotes a PR that changes 1000+ lines, ignoring generated files. do-not-merge/invalid-owners-file Indicates that a PR should not merge because it has an invalid OWNERS file in it. labels Oct 21, 2021
This commit adds a controller, several reconcilers, and a set of helpers that
all work in tandem to provide a framework for resolving Tekton resources from
places like git repos. For this proof of concept only Tekton's Pipeline type is
resolvable but in principle the solutions included here are agnostic to the
content being requested.

In more concrete terms this project will take a PipelineRun that looks like
this:

```yaml
kind: PipelineRun
metadata:
  annotations:
    resolution.tekton.dev/resolver: git
    git.repo: https://github.com/sbwsg/experimental.git
    git.commit: 326ad1a
    git.path: /remote-resolution/pipeline.yaml
spec:
  status: PipelineRunPending
```

and turn it in to one that looks like this:

```yaml
kind: PipelineRun
metadata:
  # <same as above>
status:
  # this pipelineSpec has been pulled in from git
  pipelineSpec:
    tasks:
    - name: fetch-from-git
      taskSpec:
        metadata: {}
        spec: null
        steps:
        - image: alpine/git
          name: ""
          resources: {}
          script: |
            git clone https://github.com/tektoncd/results
```

Here's a high level overview of the different parts in play:

1. (Shown in the YAML above) PipelineRuns get a new syntax to indicate the
place that a `pipelineSpec` should be fetched from. In this proof of concept
that syntax takes the form of some specific labels and annotations.

2. A component interprets the syntax from (1) and converts it into a generic
request for a resource. In this proof of concept the "generic request" is
either an HTTP call or an instance of a new CRD called a `ResourceRequest`.
Both have been implemented to try and figure out which approach better suits
the project's needs.

3. A resolver sees the request from (2) and figures out if it can respond. The
resolver fetches the resource if so. In this proof of concept three resolvers
have been implemented: a "noop" resolver for testing, an "in-cluster" resolver
that can fetch pipelines from inside the cluster, and a "git" resolver that can
fetch from public git repos.

The idea for (3) is to make writing a Resolver easy and to do so in a way that's
independent of the request format in (2). A resolver shouldn't care if the request
is coming in via HTTP or a CRD or anything else. To that end a go interface has
been introduced in the `pkg/reconciler/framework` directory that resolvers can
implement to hide all the boilerplate.

See remote-resolution/README.md for more details on installing and trying out
this controller.
@tekton-robot
Copy link

The following users are mentioned in OWNERS file(s) but are not members of the tektoncd org.

  • productivity-writers
    • remote-resolution/hack/OWNERS
    • remote-resolution/hack/OWNERS

@tekton-robot
Copy link

Issues go stale after 90d of inactivity.
Mark the issue as fresh with /remove-lifecycle stale with a justification.
Stale issues rot after an additional 30d of inactivity and eventually close.
If this issue is safe to close now please do so with /close with a justification.
If this issue should be exempted, mark the issue as frozen with /lifecycle frozen with a justification.

/lifecycle stale

Send feedback to tektoncd/plumbing.

@tekton-robot tekton-robot added the lifecycle/stale Denotes an issue or PR has remained open with no activity and has become stale. label Jan 19, 2022
@ghost
Copy link
Author

ghost commented Jan 19, 2022

/close

@tekton-robot
Copy link

@sbwsg: Closed this PR.

In response to this:

/close

Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes/test-infra repository.

dibyom added a commit to dibyom/experimental that referenced this pull request Feb 9, 2022
Depends on tektoncd#806 for annotation based remote resolution to work
dibyom added a commit to dibyom/experimental that referenced this pull request Sep 29, 2022
Depends on tektoncd#806 for annotation based remote resolution to work
dibyom added a commit to dibyom/experimental that referenced this pull request Sep 29, 2022
Depends on tektoncd#806 for annotation based remote resolution to work
dibyom added a commit to dibyom/experimental that referenced this pull request Sep 29, 2022
toTriggerTemplate()

add spec.params to tt.params conversion

add toTriggers

add el/rbac for workflows

add repos/events

Add interceptor based on eventType

Update example for demo

small changes for demo

Add gitRef fields

Depends on tektoncd#806 for annotation based remote resolution to work

Add minimal + example.yaml

remove illegal char
dibyom added a commit to dibyom/experimental that referenced this pull request Sep 29, 2022
toTriggerTemplate()

add spec.params to tt.params conversion

add toTriggers

add el/rbac for workflows

add repos/events

Add interceptor based on eventType

Update example for demo

small changes for demo

Add gitRef fields

Depends on tektoncd#806 for annotation based remote resolution to work

Add minimal + example.yaml

remove illegal char

update triggers version

Update autogen
dibyom added a commit to dibyom/experimental that referenced this pull request Oct 5, 2022
toTriggerTemplate()

add spec.params to tt.params conversion

add toTriggers

add el/rbac for workflows

add repos/events

Add interceptor based on eventType

Update example for demo

small changes for demo

Add gitRef fields

Depends on tektoncd#806 for annotation based remote resolution to work

Add minimal + example.yaml

remove illegal char

update triggers version

Update autogen

add comments

convert package + first unit test
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
do-not-merge/invalid-owners-file Indicates that a PR should not merge because it has an invalid OWNERS file in it. lifecycle/stale Denotes an issue or PR has remained open with no activity and has become stale. size/XXL Denotes a PR that changes 1000+ lines, ignoring generated files.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant