Skip to content

Latest commit

 

History

History
87 lines (58 loc) · 2.32 KB

README.md

File metadata and controls

87 lines (58 loc) · 2.32 KB

AWS CodePipeline Notification

A simple notification application sending different status of your AWS CodePipeline to Slack or MS Teams using an incoming Webhook. You will get notified for any failed state and the approval action only (additional states need new CW Event Rules).

Cloudwatch Events Rule trigger a Lambda which sends out information about the state of your CodePipeline to either Slack or MS Teams in the appropriate Format using an incoming Webhook API.

Webhook Notification Diagramm


Table of contents

  1. Preview
  2. AWS Lambda Function
  3. Prerequisites
  4. Installation

Preview

Slack

Slack

MS Teams

MS Teams


AWS Lambda Function

  • Runtime: Python 3.8
  • Code: PipelineNotification.py
  • Environment variables:
KEY VALUE SCOPE
WebhookUrl https://your_webhook_url Required
Messenger slack / msteams Required

Prerequisites

The messages will send via incoming webooks, which need to be configured on Slack or Microsoft Teams

Installation

The installation is automated with Infrastructure as Code using CloudFormation.

The stack includes:

  • Lambda basic execution role
  • Permission for Cloudwatch Events to invoke Lambda
  • CW Event Rules
  • Python Lambda

AWS CLI

Package and upload to S3:

aws cloudformation package \
    --template-file  CF-PipelineNotification.yaml\
    --s3-bucket <YourBucketName> \
    --output-template-file packaged-PipelineNotification.yaml

Deploy as a Cloudformation stack:

aws cloudformation deploy \
    --template-file packaged-PipelineNotification.yaml \
    --stack-name CF-PipelineNotification \
    --capabilities CAPABILITY_IAM \
    --parameter-overrides \
        WebhookUrl=<YourWebhookUrl> \
        Env=<slack/msteams>