Skip to content

Commit

Permalink
Merge branch 'main' into feat/api-gateway-cors
Browse files Browse the repository at this point in the history
  • Loading branch information
williamputraintan committed Sep 4, 2024
2 parents ccf38b2 + 24f56f9 commit 7092580
Show file tree
Hide file tree
Showing 37 changed files with 1,468 additions and 36 deletions.
14 changes: 9 additions & 5 deletions .github/workflows/prbuild.yml
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@ env:
#
# And from pyenv docs setting this PYENV_VERSION as env-var would set the python version globally
PYENV_VERSION: '3.12'
GOENV_VERSION: '1.22'

jobs:
pre-commit-lint-security:
Expand Down Expand Up @@ -82,21 +83,24 @@ jobs:
runs-on: codebuild-orcabus-codebuild-gh-runner-${{ github.run_id }}-${{ github.run_attempt }}
if: ${{ !github.event.pull_request.draft }}
steps:
- name: Rust installation
uses: actions-rust-lang/setup-rust-toolchain@v1
with:
components: rustfmt

- name: Print toolchain versions
run: |
node -v
python -V
pip3 -V
rustc --version
go version
make --version
docker version
- name: Checkout code
uses: actions/checkout@v4

- name: Rust installation
uses: actions-rust-lang/setup-rust-toolchain@v1
with:
components: rustfmt

- name: Install dependencies
run: |
yarn install --immutable
Expand Down
1 change: 1 addition & 0 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,7 @@ test-stateless-app-suite:
@(cd lib/workload/stateless/stacks/sequence-run-manager && $(MAKE) test)
@(cd lib/workload/stateless/stacks/metadata-manager && $(MAKE) test)
@(cd lib/workload/stateless/stacks/filemanager && $(MAKE) test)
@(cd lib/workload/stateless/stacks/fmannotator && $(MAKE) test)
@(cd lib/workload/stateless/stacks/bclconvert-manager && $(MAKE) test)
@(cd lib/workload/stateless/stacks/workflow-manager && $(MAKE) test)

Expand Down
2 changes: 2 additions & 0 deletions config/config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,7 @@ import {
getRnasumIcav2PipelineManagerStackProps,
getRnasumIcav2PipelineTableStackProps,
} from './stacks/rnasumPipelineManager';
import { getFmAnnotatorProps } from './stacks/fmAnnotator';

interface EnvironmentConfig {
name: string;
Expand Down Expand Up @@ -102,6 +103,7 @@ export const getEnvironmentConfig = (stage: AppStage): EnvironmentConfig | null
bclConvertManagerStackProps: getBclConvertManagerStackProps(stage),
workflowManagerStackProps: getWorkflowManagerStackProps(stage),
stackyMcStackFaceProps: getGlueStackProps(stage),
fmAnnotatorProps: getFmAnnotatorProps(),
},
};

Expand Down
10 changes: 10 additions & 0 deletions config/stacks/fmAnnotator.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
import { FMAnnotatorConfigurableProps } from '../../lib/workload/stateless/stacks/fmannotator/deploy/stack';
import { eventBusName, jwtSecretName, vpcProps } from '../constants';

export const getFmAnnotatorProps = (): FMAnnotatorConfigurableProps => {
return {
vpcProps,
eventBusName,
jwtSecretName,
};
};
13 changes: 13 additions & 0 deletions lib/pipeline/statelessPipelineStack.ts
Original file line number Diff line number Diff line change
Expand Up @@ -91,6 +91,7 @@ export class StatelessPipelineStack extends cdk.Stack {
install: {
'runtime-versions': {
python: '3.12',
golang: '1.22',
},
},
},
Expand Down Expand Up @@ -126,6 +127,18 @@ export class StatelessPipelineStack extends cdk.Stack {
resources: ['*'],
}),
],
partialBuildSpec: codebuild.BuildSpec.fromObject({
phases: {
install: {
'runtime-versions': {
// Don't strictly need golang here as CDK can do docker bundling, but `local`
// bundling tends to be faster.
golang: '1.22',
},
},
},
version: '0.2',
}),
});

const pipeline = new pipelines.CodePipeline(this, 'Pipeline', {
Expand Down
11 changes: 8 additions & 3 deletions lib/workload/components/api-gateway/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,7 @@ export interface ApiGatewayConstructProps {

export class ApiGatewayConstruct extends Construct {
private readonly _httpApi: HttpApi;
private readonly _domainName: string;

constructor(scope: Construct, id: string, props: ApiGatewayConstructProps) {
super(scope, id);
Expand All @@ -67,9 +68,9 @@ export class ApiGatewayConstruct extends Construct {
);
const hostedZoneId = StringParameter.valueForStringParameter(this, '/hosted_zone/umccr/id');

const domainName = `${props.customDomainNamePrefix}.${hostedDomainName}`;
this._domainName = `${props.customDomainNamePrefix}.${hostedDomainName}`;
const apiGWDomainName = new DomainName(this, 'UmccrDomainName', {
domainName: `${props.customDomainNamePrefix}.${hostedDomainName}`,
domainName: this.domainName,
certificate: Certificate.fromCertificateArn(this, 'cert', umccrAcmArn),
});

Expand Down Expand Up @@ -106,7 +107,7 @@ export class ApiGatewayConstruct extends Construct {
hostedZoneId,
zoneName: hostedDomainName,
}),
recordName: domainName,
recordName: this.domainName,
target: RecordTarget.fromAlias(
new ApiGatewayv2DomainProperties(
apiGWDomainName.regionalDomainName,
Expand Down Expand Up @@ -192,4 +193,8 @@ export class ApiGatewayConstruct extends Construct {
get httpApi(): HttpApi {
return this._httpApi;
}

get domainName(): string {
return this._domainName;
}
}
1 change: 1 addition & 0 deletions lib/workload/stateless/stacks/filemanager/.env.example
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ FILEMANAGER_DATABASE_HOST=0.0.0.0
FILEMANAGER_DATABASE_PORT=4321

DATABASE_URL=postgresql://filemanager:filemanager@${FILEMANAGER_DATABASE_HOST}:${FILEMANAGER_DATABASE_PORT}/filemanager #pragma: allowlist secret
API_PORT=8000

FILEMANAGER_LINKS_URL=localhost:8000
FILEMANAGER_API_CORS_ALLOW_ORIGINS=http://localhost:8000
Expand Down
2 changes: 1 addition & 1 deletion lib/workload/stateless/stacks/filemanager/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ docker-find:
@docker ps --filter name=$(DOCKER_PROJECT_NAME)-postgres --latest --format "{{.ID}}" | xargs -I {} docker port {} | tail -n 1 | awk '{print $$NF}'
docker-api: docker-postgres
# Run the local API server in a docker container.
@docker compose -p "$(DOCKER_PROJECT_NAME)" up api
@docker compose -p "$(DOCKER_PROJECT_NAME)" -f compose-api.yml up api

## Build related commands
build: docker-postgres
Expand Down
20 changes: 20 additions & 0 deletions lib/workload/stateless/stacks/filemanager/compose-api.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
services:
api:
build:
context: .
args:
# The build itself needs access to the database.
- DATABASE_URL=${BUILD_DATABASE_URL:-postgresql://filemanager:[email protected]:4321/filemanager} # pragma: allowlist secret
environment:
# Container database address for running server inside a docker container.
- DATABASE_URL=${DATABASE_URL:-postgresql://filemanager:filemanager@postgres:4321/filemanager}
- RUST_LOG=debug
- FILEMANAGER_API_CORS_ALLOW_ORIGINS=${FILEMANAGER_API_CORS_ALLOW_ORIGINS:-http://localhost:3000}
- FILEMANAGER_API_CORS_ALLOW_HEADERS=${FILEMANAGER_API_CORS_ALLOW_HEADERS:-accept,authorization,content-type,user-agent,x-csrftoken,x-requested-with,x-amz-security-token,x-amz-date,content-disposition}
- AWS_ACCESS_KEY_ID=${AWS_ACCESS_KEY_ID:-access_key_id}
- AWS_SECRET_ACCESS_KEY=${AWS_SECRET_ACCESS_KEY:-secret_access_key}
- AWS_DEFAULT_REGION=${AWS_DEFAULT_REGION:-ap-southeast-2}
- AWS_SESSION_TOKEN=${AWS_SESSION_TOKEN:-session_token}
ports:
- '${API_PORT}:8000'
restart: always
23 changes: 1 addition & 22 deletions lib/workload/stateless/stacks/filemanager/compose.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,30 +3,9 @@ services:
build: database
restart: always
environment:
- POSTGRES_DATABASE=filemanager
- POSTGRES_DB=filemanager
- POSTGRES_USER=filemanager
- POSTGRES_PASSWORD=filemanager
- PGPORT=4321
ports:
- "${FILEMANAGER_DATABASE_HOST}:${FILEMANAGER_DATABASE_PORT}:4321"
api:
build:
context: .
args:
# The build itself needs access to the database.
DATABASE_URL: postgresql://filemanager:[email protected]:4321/filemanager # pragma: allowlist secret
environment:
# Container database address for running server inside a docker container.
- DATABASE_URL=postgresql://filemanager:filemanager@postgres:4321/filemanager
- RUST_LOG=debug
- FILEMANAGER_API_CORS_ALLOW_ORIGINS=${FILEMANAGER_API_CORS_ALLOW_ORIGINS:-http://localhost:3000}
- FILEMANAGER_API_CORS_ALLOW_HEADERS=${FILEMANAGER_API_CORS_ALLOW_HEADERS:-accept,authorization,content-type,user-agent,x-csrftoken,x-requested-with,x-amz-security-token,x-amz-date,content-disposition}
- AWS_ACCESS_KEY_ID=${AWS_ACCESS_KEY_ID:-access_key_id}
- AWS_SECRET_ACCESS_KEY=${AWS_SECRET_ACCESS_KEY:-secret_access_key}
- AWS_DEFAULT_REGION=${AWS_DEFAULT_REGION:-ap-southeast-2}
- AWS_SESSION_TOKEN=${AWS_SESSION_TOKEN:-session_token}
ports:
- "8000:8000"
depends_on:
- postgres
restart: always
12 changes: 8 additions & 4 deletions lib/workload/stateless/stacks/filemanager/deploy/stack.ts
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@ export class Filemanager extends Stack {
private readonly host: string;
private readonly securityGroup: ISecurityGroup;
private readonly queue: IQueue;
readonly domainName: string;

constructor(scope: Construct, id: string, props: FilemanagerProps) {
super(scope, id, props);
Expand Down Expand Up @@ -89,8 +90,9 @@ export class Filemanager extends Stack {
);

this.createIngestFunction(props);
this.createApiFunction(props);
this.createInventoryFunction(props);

this.domainName = this.createApiFunction(props);
}

private createIngestRole(name: string) {
Expand Down Expand Up @@ -126,9 +128,9 @@ export class Filemanager extends Stack {
}

/**
* Query function and API Gateway fronting the function.
* Query function and API Gateway fronting the function. Returns the configured domain name.
*/
private createApiFunction(props: FilemanagerProps) {
private createApiFunction(props: FilemanagerProps): string {
let apiLambda = new ApiFunction(this, 'ApiFunction', {
vpc: this.vpc,
host: this.host,
Expand All @@ -137,7 +139,7 @@ export class Filemanager extends Stack {
...props,
});

const ApiGateway = new ApiGatewayConstruct(this, 'ApiGateway', props.apiGatewayCognitoProps);
const apiGateway = new ApiGatewayConstruct(this, 'ApiGateway', props.apiGatewayCognitoProps);
const httpApi = ApiGateway.httpApi;

const apiIntegration = new HttpLambdaIntegration('ApiIntegration', apiLambda.function);
Expand All @@ -159,5 +161,7 @@ export class Filemanager extends Stack {
integration: apiIntegration,
routeKey: HttpRouteKey.with('/{proxy+}', HttpMethod.POST),
});

return apiGateway.domainName;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,8 @@ use crate::Config;
pub async fn generate_entities() -> Result<()> {
let config = Config::load()?;

println!("{:#?}", config);

let out_dir = config.out_dir;
let command: &[&_] = &[
"sea-orm-cli",
Expand Down
1 change: 1 addition & 0 deletions lib/workload/stateless/stacks/fmannotator/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
build
28 changes: 28 additions & 0 deletions lib/workload/stateless/stacks/fmannotator/Makefile
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
## Default target
default: help

install: build
all: build

## Build related commands
build:
@go build -o build
test:
@go test
lint:
@go fmt
golangci-lint:
@golangci-lint run
check: lint golangci-lint

## Clean
clean:
@go mod tidy

## Help text
help:
@printf "The attribute annotator Makefile.\n\n"
@printf "Usage: make <target>\n"

# No targets are files, so they are all PHONY.
.PHONY: *
52 changes: 52 additions & 0 deletions lib/workload/stateless/stacks/fmannotator/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
# FMAnnotator

The FMAnnotator service annotates records using the FileManager API.

## Development

This service is written in Go, which should be [installed][golang]. Please also install [golangci-lint] to run lints on
the codebase.

This project is organised using the Go Lambda function CDK, and contains Lambda function handlers under [`cmd`][cmd]

Makefile is used to simplify development. Tests can be run by using:

```sh
make test
```

Lints and checks can be run using:

```sh
make check
```

To update the [go.mod][go-mod] and download any new go modules:

```sh
make clean
```

## Project layout

This service has the following structure:

* [cmd]: The Lambda handler `main.go` functions.
* [deploy]: CDK deployment code.
* [fixtures]: Database fixtures and test data.
* [internal]: Internal package containing common test code.
* [schema]: Generated EventBridge code-bindings.

Top-level `.go` files contain library related code which implements the functionality of the FMAnnotator.
Tests are defined using the `_test.go` suffix.

[golang]: https://go.dev/doc/install
[golangci-lint]: https://golangci-lint.run/welcome/install/#local-installation
[cmd]: cmd
[api]: api.go
[config]: config.go
[handlers]: handlers.go
[internal]: internal
[fixtures]: fixtures
[schema]: schema
[go-mod]: go.mod
Loading

0 comments on commit 7092580

Please sign in to comment.