-
Notifications
You must be signed in to change notification settings - Fork 35
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
add proposals for notifications/spaces/triggers
these all go hand-in-hand so they have the same RFC number and are in the same PR, but they each deserve their own proposals Signed-off-by: Alex Suraci <suraci.alex@gmail.com>
- Loading branch information
Showing
9 changed files
with
172 additions
and
39 deletions.
There are no files selected for viewing
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,53 @@ | ||
# Artifact Resources | ||
|
||
This proposal uses the [generalized resource interface](../024-generalized-resources/proposal.md) to show how the interface would be implemented and interpreted by Concourse to support "artifact resources", today's primary use case for v1 resources. | ||
|
||
## Motivation | ||
|
||
* Support for creating multiple versions from `put`: [concourse/concourse#2660](https://github.com/concourse/concourse/issues/2660) | ||
|
||
* Support for deleting versions: [concourse/concourse#362](https://github.com/concourse/concourse/issues/362), [concourse/concourse#524](https://github.com/concourse/concourse/issues/524) | ||
|
||
* Make the `get` after `put` opt-in: [concourse/concourse#3299](https://github.com/concourse/concourse/issues/3299), [concourse/registry-image-resource#16](https://github.com/concourse/registry-image-resource/issues/16) | ||
|
||
## Examples | ||
|
||
* A basic implementation of the `git` resource can be found in [`git-v2`](examples/git-v2). | ||
|
||
## Proposal | ||
|
||
A v2 resource type can be used as a versioned artifact resource by treating the **config fragments** as **versions** and emitting them in chronological order from `check`. This way the resource type is used to model change in an external resource over time. | ||
|
||
### `check`: discover versions in order | ||
|
||
The `check` action will first be run with a "naked" config, containing only what the user specified. In this situation `check` must emit an `ActionResponse` for all versions discovered in the config, in chronological order. | ||
|
||
Subsequent calls to `check` will be given a config that has been spliced with the last emitted version config fragment. The `check` script must an `ActionResponse` for the given version if it still exists, followed by a response for any versions that came after it. | ||
|
||
If the specified version is no longer present, the `check` action must go back to returning all versions, as if the version was not specified in the first place. Concourse will detect this scenario by noticing that the first `ActionResponse` emitted does not match the requested version. All versions that existed before that were emitted will be automatically marked "deleted". | ||
|
||
The `check` action can use the **bits** directory to cache state between runs of the `check` on that worker. On the first run, the directory will be empty. | ||
|
||
### `get`: fetch a version of an artifact | ||
|
||
The `get` action will always be invoked with a spliced config specifying which version to fetch. It is given an empty **bits** directory in which to fetch the data. | ||
|
||
An `ActionResponse` must be emitted for all versions that have been fetched into the bits directory. Each version will be recorded as an input to the build. | ||
|
||
### `put`: idempotently create artifact versions | ||
|
||
The `put` action will be invoked with user-provided configuration and arbitrary bits. | ||
|
||
An `ActionResponse` must be emitted for all versions that have been created/updated. Each version will be recorded as an output of the build. | ||
|
||
### `delete`: idempotently destroy artifact versions | ||
|
||
The `delete` action will be invoked with user-provided configuration and arbitrary bits. | ||
|
||
An `ActionResponse` must be emitted for all versions that have been destroyed. These versions will be marked "deleted" and no longer be available for use in other builds. | ||
|
||
## Open Questions | ||
|
||
* [resource-determined triggerability of versions?](https://github.com/concourse/rfcs/issues/11) | ||
* webhooks? | ||
* should these instead be something supported by *Concourse*? |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,36 @@ | ||
# Notification Resources | ||
|
||
This proposal uses the [generalized resource interface](../024-generalized-resources/proposal.md) to show how the interface would be implemented and interpreted by Concourse to support "notification resources", which are composed with another resource to emit notifications for build status. | ||
|
||
## Motivation | ||
|
||
* Support notifications in a way that doesn't pollute pipeline config and UI: [concourse/concourse#1052](https://github.com/concourse/concourse/issues/1052), [concourse/rfcs#10](https://github.com/concourse/rfcs/issues/10) | ||
|
||
## Proposal | ||
|
||
> Describe your proposal. | ||
> | ||
> Things that can help: clearly defining terms, providing example content, | ||
> pseudocode, etc. | ||
> | ||
> Feel free to mention key implementation concerns. | ||
## Open Questions | ||
|
||
> Raise any concerns here for things you aren't sure about yet. | ||
## Answered Questions | ||
|
||
> If there were any major concerns that have already (or eventually, through | ||
> the RFC process) reached consensus, it can still help to include them along | ||
> with their resolution, if it's otherwise unclear. | ||
> | ||
> This can be especially useful for RFCs that have taken a long time and there | ||
> were some subtle yet important details to get right. | ||
> | ||
> This may very well be empty if the proposal is simple enough. | ||
## New Implications | ||
|
||
> What is the impact of this change, outside of the change itself? How might it | ||
> change peoples' workflows today, good or bad? |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
# Spatial Resources | ||
|
||
This proposal uses the [generalized resource interface](../024-generalized-resources/proposal.md) to show how the interface would be implemented and interpreted by Concourse to support "spatial resources", which model change over *space*, not time (as with [artifact resources](../024-artifact-resources/proposal.md)). | ||
|
||
## Motivation | ||
|
||
* Support multi-branch workflows: [concourse/concourse#1172](https://github.com/concourse/concourse/issues/1172) | ||
|
||
* Begin phasing out `version: every` in by reframing the problem as 'pipeline per commit': [concourse/concourse#736](https://github.com/concourse/concourse/issues/736) | ||
|
||
## Proposal | ||
|
||
> Describe your proposal. | ||
> | ||
> Things that can help: clearly defining terms, providing example content, | ||
> pseudocode, etc. | ||
> | ||
> Feel free to mention key implementation concerns. | ||
## Open Questions | ||
|
||
> Raise any concerns here for things you aren't sure about yet. | ||
## Answered Questions | ||
|
||
> If there were any major concerns that have already (or eventually, through | ||
> the RFC process) reached consensus, it can still help to include them along | ||
> with their resolution, if it's otherwise unclear. | ||
> | ||
> This can be especially useful for RFCs that have taken a long time and there | ||
> were some subtle yet important details to get right. | ||
> | ||
> This may very well be empty if the proposal is simple enough. | ||
## New Implications | ||
|
||
> What is the impact of this change, outside of the change itself? How might it | ||
> change peoples' workflows today, good or bad? |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,36 @@ | ||
# Trigger Resources | ||
|
||
This proposal uses the [generalized resource interface](../024-generalized-resources/proposal.md) to show how the interface would be implemented and interpreted by Concourse to support "trigger resources", are tied to a job and perform `check`s to determine whether the job should trigger. | ||
|
||
## Motivation | ||
|
||
* Support for trigger-only resources that don't result in fetching anything - they just trigger the job: [concourse/concourse#3572](https://github.com/concourse/concourse/issues/3572), [concourse/concourse#3595](https://github.com/concourse/concourse/issues/3595) | ||
|
||
## Proposal | ||
|
||
> Describe your proposal. | ||
> | ||
> Things that can help: clearly defining terms, providing example content, | ||
> pseudocode, etc. | ||
> | ||
> Feel free to mention key implementation concerns. | ||
## Open Questions | ||
|
||
> Raise any concerns here for things you aren't sure about yet. | ||
## Answered Questions | ||
|
||
> If there were any major concerns that have already (or eventually, through | ||
> the RFC process) reached consensus, it can still help to include them along | ||
> with their resolution, if it's otherwise unclear. | ||
> | ||
> This can be especially useful for RFCs that have taken a long time and there | ||
> were some subtle yet important details to get right. | ||
> | ||
> This may very well be empty if the proposal is simple enough. | ||
## New Implications | ||
|
||
> What is the impact of this change, outside of the change itself? How might it | ||
> change peoples' workflows today, good or bad? |