Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add ability to disable trigger on changes for S3/CC/GH source providers #357

Merged
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
32 changes: 32 additions & 0 deletions docs/providers-guide.md
Original file line number Diff line number Diff line change
Expand Up @@ -76,6 +76,17 @@ Provider type: `codecommit`.
> The role to use to fetch the contents of the CodeCommit repository.
> Only specify when you need a specific role to access it. By default ADF
> will use its own role to access it instead.
- *trigger_on_changes* - *(Boolean)* default: `True`.
> Whether CodePipeline should release a change and trigger the pipeline.
> When set to False, you either need to trigger the pipeline manually,
> through a schedule, or through the completion of another pipeline.
>
> This disables the triggering of changes all together when set to False.
> In other words, when you don't want to rely on polling or event
> based triggers of changes pushed into the repository.
>
> By default, it will trigger on changes using the event triggered by
> CodeCommit when an update to the repository took place.

### GitHub

Expand Down Expand Up @@ -104,6 +115,17 @@ Provider type: `github`.
- *json_field* - *(String)* **(required)**
> The name of the JSON key in the object that is stored in AWS Secrets
> Manager that holds the OAuth Token.
- *trigger_on_changes* - *(Boolean)* default: `True`.
> Whether CodePipeline should release a change and trigger the pipeline.
> When set to False, you either need to trigger the pipeline manually,
> through a schedule, or through the completion of another pipeline.
>
> This disables the triggering of changes when set to False.
> It will not deploy the web hook that GitHub would otherwise use to
> trigger the pipeline on changes.
>
> By default, it will trigger deploy the web hook and trigger on changes
> using web hook call executed by GitHub.

### S3

Expand All @@ -126,6 +148,16 @@ Provider type: `s3`.
- *object_key* - *(String)* **(required)**
> The Specific Object within the bucket that will trigger the pipeline
> execution.
- *trigger_on_changes* - *(Boolean)* default: `True`.
> Whether CodePipeline should release a change and trigger the pipeline
> if a change was detected in the S3 object.
>
> When set to False, you either need to trigger the pipeline manually,
> through a schedule, or through the completion of another pipeline.
>
> By default, it will trigger on changes using the polling mechanism
> of CodePipeline. Monitoring the S3 object so it can trigger a release
> when an update took place.

### CodeStar

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -69,7 +69,8 @@ def _generate_configuration(self): #pylint: disable=R0912, R0911, R0915
if self.provider == "S3" and self.category == "Source":
return {
"S3Bucket": self.map_params.get('default_providers', {}).get('source', {}).get('properties', {}).get('bucket_name'),
"S3ObjectKey": self.map_params.get('default_providers', {}).get('source', {}).get('properties', {}).get('object_key')
"S3ObjectKey": self.map_params.get('default_providers', {}).get('source', {}).get('properties', {}).get('object_key'),
"PollForSourceChanges": self.map_params.get('default_providers', {}).get('source', {}).get('properties', {}).get('trigger_on_changes', True),
}
if self.provider == "S3" and self.category == "Deploy":
return {
Expand Down Expand Up @@ -249,7 +250,10 @@ def _generate_configuration(self): #pylint: disable=R0912, R0911, R0915
return {
"BranchName": self.map_params['default_providers']['source'].get('properties', {}).get('branch', 'master'),
"RepositoryName": self.map_params['default_providers']['source'].get('properties', {}).get('repository', {}) or self.map_params['name'],
"PollForSourceChanges": self.map_params['default_providers']['source'].get('properties', {}).get('poll_for_changes', False)
"PollForSourceChanges": (
self.map_params['default_providers']['source'].get('properties', {}).get('trigger_on_changes', True)
and self.map_params['default_providers']['source'].get('properties', {}).get('poll_for_changes', False)
)
}
raise Exception("{0} is not a valid provider".format(self.provider))

Expand Down Expand Up @@ -424,7 +428,9 @@ def __init__(self, scope: core.Construct, id: str, map_params: dict, ssm_params:
"provider": map_params.get('default_providers', {}).get('source', {}).get('provider'),
"account_id": map_params.get('default_providers', {}).get('source', {}).get('properties', {}).get('account_id'),
"repo_name": map_params.get('default_providers', {}).get('source', {}).get('properties', {}).get('repository') or map_params['name'],
"branch": map_params.get('default_providers', {}).get('source', {}).get('properties', {}).get('branch', 'master')
"branch": map_params.get('default_providers', {}).get('source', {}).get('properties', {}).get('branch', 'master'),
"poll_for_changes": map_params.get('default_providers', {}).get('source', {}).get('properties', {}).get('poll_for_changes', False),
"trigger_on_changes": map_params.get('default_providers', {}).get('source', {}).get('properties', {}).get('trigger_on_changes', True),
}
})

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,13 @@ def __init__(self, scope: core.Construct, id: str, params: dict, **kwargs): #pyl
_pipeline = _codepipeline.Pipeline.from_pipeline_arn(self, 'pipeline', params["pipeline"])
_source_account = params.get('source', {}).get('account_id')
_provider = params.get('source', {}).get('provider')
if _source_account and _provider == 'codecommit':
_add_trigger_on_changes = (
_provider == 'codecommit'
and _source_account
and params.get('source', {}).get('trigger_on_changes')
and not params.get('source', {}).get('poll_for_changes')
)
if _add_trigger_on_changes:
_event = _events.Rule(
self,
'trigger_{0}'.format(params["name"]),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,12 @@ def __init__(self, scope: core.Construct, id: str, map_params: dict, **kwargs):
)

@staticmethod
def create_webhook(scope, pipeline, map_params):
def create_webhook_when_required(scope, pipeline, map_params):
trigger_on_changes = map_params.get("default_providers", {}).get(
"source", {}).get("properties", {}).get("trigger_on_changes", True)
if not trigger_on_changes:
return

_version = pipeline.get_att('Version')
_codepipeline.CfnWebhook(
scope,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ def generate_adf_default_pipeline(scope: core.Stack, stack_input):
scope, "code_pipeline", stack_input["input"], stack_input["ssm_params"], _stages
)
if "github" in _source_name:
adf_github.GitHub.create_webhook(scope, _pipeline.cfn, stack_input["input"])
adf_github.GitHub.create_webhook_when_required(scope, _pipeline.cfn, stack_input["input"])


def generate_source_stage_for_pipeline(_stages, scope, stack_input):
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,8 @@
Optional("branch"): str,
Optional("poll_for_changes"): bool,
Optional("owner"): str,
Optional("role"): str
Optional("role"): str,
Optional("trigger_on_changes"): bool,
}
CODECOMMIT_SOURCE = {
"provider": 'codecommit',
Expand All @@ -62,7 +63,8 @@
Optional("branch"): str,
"owner": str,
"oauth_token_path": str,
"json_field": str
"json_field": str,
Optional("trigger_on_changes"): bool,
}
GITHUB_SOURCE = {
"provider": 'github',
Expand All @@ -86,7 +88,8 @@
S3_SOURCE_PROPS = {
"account_id": AWS_ACCOUNT_ID_SCHEMA,
"bucket_name": str,
"object_key": str
"object_key": str,
Optional("trigger_on_changes"): bool,
}
S3_SOURCE = {
"provider": 's3',
Expand Down