Skip to content

Commit

Permalink
Merge branch 'main' into dev-feature-reporting-poc
Browse files Browse the repository at this point in the history
  • Loading branch information
mkrystof authored Nov 27, 2023
2 parents a0e74a9 + a4484a8 commit ddd4cc9
Show file tree
Hide file tree
Showing 17 changed files with 583 additions and 69 deletions.
236 changes: 236 additions & 0 deletions .github/workflows/ps-remote-cicd.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,236 @@
name: Trigger Processing Status CI/CD Workflow
on:
workflow_dispatch:
inputs:
data-exchange-hl7-workflow:
description: '(Required) Specify CI/CD workflow associated with one function app to trigger autodeploy from CDCEnt/data-exchange-hl7-devops repo'
required: true
type: choice
default: 'deploy-processing-status.yml'
options:
- deploy-processing-status.yml
commitID:
description: '(Optional) Enter Full Commit Hash to trigger redeploy of prior version'
required: false
type: string
data-exchange-hl7-branch:
description: '(Optional) Enter Source Branch to trigger deployment of tip revision to the development or test environment. Defaults to develop branch'
required: false
type: string
default: 'develop'
targetEnv:
description: 'Environment to deploy'
required: true
type: string
default: 'dev'

pull_request:
types:
- synchronize
- opened
branches:
- 'develop'
- 'main'
paths:
- processing-status-api-function-app/**
push:
branches:
- 'develop'
- 'main'
paths:
- processing-status-api-function-app/**

jobs:
invoke-manual-cicd-trigger:
if: github.event_name == 'workflow_dispatch'
runs-on: ubuntu-latest
name: Invoke ${{ inputs.data-exchange-hl7-workflow }}
environment: dev
env:
GH_TOKEN: ${{ github.token }}
steps:
- name: Gen GitHub App Access Token For Manual Trigger
id: github-app-token
run: |
echo ${{ github.workspace }}
if [ ! -d data-exchange-hl7 ]; then git clone https://github.com/kave/github-app-token.git; fi;
sudo tree -df
cd github-app-token
sudo gem install jwt
echo "${{ secrets.CDC_COE_BOTFREY_PEM }}" > app-private-key.pem
chmod +x ./get-github-app-access-token.sh;
. ./get-github-app-access-token.sh;
echo "access_token=${TOKEN}" >> "$GITHUB_ENV"
- name: Git Commit SHA
id: getsha
run: |
echo "sha=${{ inputs.commitID }}" >> "$GITHUB_ENV"
- name: Manually Dispatch Remote CICD Trigger Event
id: manual-devops-wkflow-dispatch
uses: aurelien-baudet/[email protected]
with:
workflow: '${{ github.event.inputs.data-exchange-hl7-workflow }}'
repo: cdcent/data-exchange-hl7-devops
token: ${{ env.access_token }}
inputs: '{ "targetEnv": "${{ github.event.inputs.targetEnv }}", "commitID": "${{ env.sha }}", "data-exchange-hl7-branch": "${{ github.event.inputs.data-exchange-hl7-branch }}" }'
ref: 'main'
wait-for-completion: true
wait-for-completion-timeout: 120m
wait-for-completion-interval: 300s
display-workflow-run-url: true
# workflow-logs: print --- This nice-to-have feature is documented in readme but apparantly not implemented in current version - follow up required
# uses: actions/[email protected]
# with:
# debug: ${{ secrets.ACTIONS_RUNNER_DEBUG }}
# github-token: '${{ env.access_token }}'
# script: |
# try {
# const result = await github.rest.actions.createWorkflowDispatch({
# owner: 'cdcent',
# repo: 'data-exchange-hl7-devops',
# workflow_id: '${{ github.event.inputs.data-exchange-hl7-workflow }}',
# ref: 'main',
# inputs: {
# commitID: '${{ steps.getsha.outputs.commitID }}',
# 'data-exchange-hl7-branch': '${{ github.event.inputs.data-exchange-hl7-branch }}'
# }
# })
# console.log(result);
# } catch(error) {
# console.error(error);
# core.setFailed(error);
# }
prepare-remote-cicd:
permissions: write-all
if: github.event_name != 'workflow_dispatch'
runs-on: ubuntu-latest
environment: dev
outputs:
matrix: ${{ steps.set-matrix.outputs.matrix }}
merge_branch: ${{ steps.gettargetbranch.outputs.target_branch }}
env:
GH_TOKEN: ${{ github.token }}
steps:
- name: Get PR Commits
if: ${{ github.event_name }} == 'pull_request'
uses: actions/checkout@v3
with:
ref: ${{ github.event.pull_request.head.sha }}
fetch-depth: 0
- name: Get User Commits
uses: actions/checkout@v3
with:
ref: ${{ github.ref }}
fetch-depth: 0
- name: Get PR Merge Target Branch
id: gettargetbranch
run: |
if [[ ${{ github.event_name }} == 'pull_request' ]];
then
echo "target_branch=${{ github.base_ref }}" >> "$GITHUB_ENV"
echo "target_branch=${{ github.base_ref }}" >> "$GITHUB_OUTPUT"
else
echo "target_branch=${{ github.ref_name }}" >> "$GITHUB_ENV"
echo "target_branch=${{ github.ref_name }}" >> "$GITHUB_OUTPUT"
fi
# Create a list (matrix) of workflow IDs to trigger based on folders impacted by file changes in current branch
# Convert workflow shell array into a stringified JSON so it can be bound to matrix workflow_id property used in invoke job
# Autodeploy on Push (PR merge) to develop or main branch. All other Push events targeting feature branches will be trated as
# Pull_Request event and will trigger CI (unit test) workflow
- name: Determine Processing Status Workflow(s) to Trigger
id: set-matrix
run: |
workflows=()
commitfldrs=$(git log -m -1 --name-only --pretty="format:"${{ github.sha }})
echo " Files Changed in PR commit: $commitfldrs"
if [[ ${{ github.event_name }} == 'push' && (${{ github.ref_name }} == 'develop' || ${{ github.ref_name }} == 'main' ) ]];
then
case $commitfldrs in
*processing-status-api-function-app*) workflows+=("deploy-processing-status.yml") ;;&
*) ;;
esac
else
case $commitfldrs in
*processing-status-api-function-app*) workflows+=("ci-processing-status.yml") ;;&
*) ;;
esac
fi
for value in "${workflows[@]}"
do
echo "$value will be triggered as part of this PR"
echo "matrix=${workflows[@]}" >> "$GITHUB_ENV"
echo "matrix=${workflows[@]}" >> "$GITHUB_OUTPUT"
done
echo "matrix=$(printf '%s\n' "${workflows[@]}" | jq -R . | jq -cs )" >> "$GITHUB_OUTPUT"
echo "matrix=$(printf '%s\n' "${workflows[@]}" | jq -R . | jq -cs )" >> "$GITHUB_ENV"
echo "deploy workflows=${workflows[@]}"
- name: No CI/CD Notification
id: no-cicd-notice
if: fromJson(env.matrix)[0] == null
run: |
echo "No testable,deployable changes Detected in Processing Status Build Workspace"
trigger-remote-cicd:
if: ${{ github.event_name != 'workflow_dispatch' && fromJson(needs.prepare-remote-cicd.outputs.matrix)[0] != null }}
needs: prepare-remote-cicd
runs-on: ubuntu-latest
name: Dispatch ${{ matrix.workflow_id }} Workflow
strategy:
fail-fast: false
matrix:
workflow_id: ${{fromJson(needs.prepare-remote-cicd.outputs.matrix)}}
environment: dev
steps:
- name: Gen GitHub App Access Token for Automated Trigger
id: github-app-token
run: |
echo ${{ github.workspace }}
if [ ! -d github-app-token ]; then git clone https://github.com/kave/github-app-token.git; fi;
sudo tree -df
cd github-app-token
sudo gem install jwt
echo "${{ secrets.CDC_COE_BOTFREY_PEM }}" > app-private-key.pem
chmod +x ./get-github-app-access-token.sh;
. ./get-github-app-access-token.sh;
echo "access_token=${TOKEN}" >> "$GITHUB_ENV"
- name: Get Commit SHA
id: getsha
run: |
echo "commitID=$(echo ${GITHUB_SHA})" >> $GITHUB_OUTPUT
- name: Automatically Dispatch Remote CICD Trigger Event
id: auto-devops-wkflow-dispatch
if: ${{ matrix.workflow_id != '' }}
uses: aurelien-baudet/[email protected]
with:
workflow: ${{ matrix.workflow_id }}
repo: cdcent/data-exchange-hl7-devops
token: ${{ env.access_token }}
inputs: '{ "targetEnv": "dev", "commitID": "${{ steps.getsha.outputs.commitID }}", "data-exchange-hl7-branch": "${{ needs.prepare-remote-cicd.outputs.merge_branch }}" }'
ref: 'main'
wait-for-completion: true
wait-for-completion-timeout: 120m
wait-for-completion-interval: 300s
display-workflow-run-url: true

# workflow-logs: print
# uses: actions/[email protected]
# with:
# debug: ${{ secrets.ACTIONS_RUNNER_DEBUG }}
# github-token: '${{ env.access_token }}'
# script: |
# try {
# const result = await github.rest.actions.createWorkflowDispatch({
# owner: 'cdcent',
# repo: 'data-exchange-hl7-devops',
# workflow_id: '${{ matrix.workflow_id }}',
# ref: 'main',
# inputs: {
# commitID: '${{ steps.getsha.outputs.commitID }}',
# 'data-exchange-hl7-branch': '${{ needs.prepare-remote-cicd.outputs.merge_branch }}'
# }
# })
# console.log(result);
# } catch(error) {
# console.error(error);
# core.setFailed(error);
# }
3 changes: 3 additions & 0 deletions processing-status-api-function-app/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,9 @@ dependencies {
implementation 'com.azure:azure-messaging-servicebus:7.13.3'
implementation 'com.azure:azure-identity:1.8.0'

implementation 'org.danilopianini:khttp:1.3.1'
implementation group: 'com.google.code.gson', name: 'gson', version: '2.7'

agent "io.opentelemetry.javaagent:opentelemetry-javaagent:1.29.0"

testImplementation "org.mockito:mockito-core:5.2.0"
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,7 @@
import java.util.*;
import com.microsoft.azure.functions.annotation.*;
import com.microsoft.azure.functions.*;
import gov.cdc.ocio.processingstatusapi.functions.AddSpanToTraceFunction;
import gov.cdc.ocio.processingstatusapi.functions.HealthCheckFunction;
import gov.cdc.ocio.processingstatusapi.functions.TraceFunction;
import gov.cdc.ocio.processingstatusapi.functions.reports.*;
import gov.cdc.ocio.processingstatusapi.functions.*;

public class FunctionJavaWrappers {

Expand All @@ -26,26 +23,47 @@ public HttpResponseMessage trace(
@HttpTrigger(
name = "req",
methods = {HttpMethod.POST},
route = "trace/{spanName}",
//authLevel = AuthorizationLevel.FUNCTION) HttpRequestMessage<Optional<String>> request,
route = "trace",
authLevel = AuthorizationLevel.ANONYMOUS) HttpRequestMessage<Optional<String>> request,
@BindingName("spanName") String spanName,
final ExecutionContext context) {
return new TraceFunction().run(request, spanName, context);
return new TraceFunction().run(request, context);
}

@FunctionName("AddSpanToTrace")
public HttpResponseMessage addSpanToTrace(
@HttpTrigger(
name = "req",
methods = {HttpMethod.PUT},
route = "span/{traceId}/{spanId}/{spanName}",
route = "trace/addSpan/{traceId}/{spanId}",
authLevel = AuthorizationLevel.ANONYMOUS) HttpRequestMessage<Optional<String>> request,
@BindingName("traceId") String traceId,
@BindingName("spanId") String spanId,
@BindingName("spanName") String spanName,
final ExecutionContext context) {
return new AddSpanToTraceFunction().run(request, traceId, spanId, spanName, context);
return new AddSpanToTraceFunction().run(request, traceId, spanId, context);
}

@FunctionName("GetTrace")
public HttpResponseMessage getTraceById(
@HttpTrigger(
name = "req",
methods = {HttpMethod.GET},
route = "trace/traceId/{traceId}",
authLevel = AuthorizationLevel.ANONYMOUS) HttpRequestMessage<Optional<String>> request,
@BindingName("traceId") String traceId,
final ExecutionContext context) {
return new GetTraceFunction().run(request, traceId, context);
}

@FunctionName("GetTraceByUploadId")
public HttpResponseMessage getTraceByUploadId(
@HttpTrigger(
name = "req",
methods = {HttpMethod.GET},
route = "trace/uploadId/{uploadId}",
authLevel = AuthorizationLevel.ANONYMOUS) HttpRequestMessage<Optional<String>> request,
@BindingName("uploadId") String uploadId,
final ExecutionContext context) {
return new GetTraceByUploadIdFunction().run(request, uploadId, context);
}

@FunctionName("CreateReport")
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
package gov.cdc.ocio.processingstatusapi

object Constants {
const val PARENT_SPAN = "PARENT_SPAN"
}
Loading

0 comments on commit ddd4cc9

Please sign in to comment.