Compare commits
11 Commits
dev
...
feature/en
Author | SHA1 | Date | |
---|---|---|---|
|
1d8ad96839 | ||
|
5b4adb7235 | ||
|
19a3735c09 | ||
|
576ce3165d | ||
|
c5298158ef | ||
|
49aac0ce77 | ||
|
5bf33b26fb | ||
|
c10b4ac934 | ||
|
0a66edc61b | ||
|
d93f6c2f89 | ||
|
0972643c5f |
132
.editorconfig
132
.editorconfig
@ -1,132 +0,0 @@
|
|||||||
###############################
|
|
||||||
# Core EditorConfig Options #
|
|
||||||
###############################
|
|
||||||
root = true
|
|
||||||
# All files
|
|
||||||
[*]
|
|
||||||
indent_style = space
|
|
||||||
|
|
||||||
# XML project files
|
|
||||||
[*.{csproj,vbproj,vcxproj,vcxproj.filters,proj,projitems,shproj}]
|
|
||||||
indent_size = 2
|
|
||||||
|
|
||||||
# XML config files
|
|
||||||
[*.{props,targets,ruleset,config,nuspec,resx,vsixmanifest,vsct}]
|
|
||||||
indent_size = 2
|
|
||||||
|
|
||||||
# Code files
|
|
||||||
[*.{cs,csx,vb,vbx}]
|
|
||||||
indent_size = 4
|
|
||||||
insert_final_newline = true
|
|
||||||
charset = utf-8-bom
|
|
||||||
###############################
|
|
||||||
# .NET Coding Conventions #
|
|
||||||
###############################
|
|
||||||
[*.{cs,vb}]
|
|
||||||
# Organize usings
|
|
||||||
dotnet_sort_system_directives_first = true
|
|
||||||
# this. preferences
|
|
||||||
dotnet_style_qualification_for_field = false:silent
|
|
||||||
dotnet_style_qualification_for_property = false:silent
|
|
||||||
dotnet_style_qualification_for_method = false:silent
|
|
||||||
dotnet_style_qualification_for_event = false:silent
|
|
||||||
# Language keywords vs BCL types preferences
|
|
||||||
dotnet_style_predefined_type_for_locals_parameters_members = true:silent
|
|
||||||
dotnet_style_predefined_type_for_member_access = true:silent
|
|
||||||
# Parentheses preferences
|
|
||||||
dotnet_style_parentheses_in_arithmetic_binary_operators = always_for_clarity:silent
|
|
||||||
dotnet_style_parentheses_in_relational_binary_operators = always_for_clarity:silent
|
|
||||||
dotnet_style_parentheses_in_other_binary_operators = always_for_clarity:silent
|
|
||||||
dotnet_style_parentheses_in_other_operators = never_if_unnecessary:silent
|
|
||||||
# Modifier preferences
|
|
||||||
dotnet_style_require_accessibility_modifiers = for_non_interface_members:silent
|
|
||||||
dotnet_style_readonly_field = true:suggestion
|
|
||||||
# Expression-level preferences
|
|
||||||
dotnet_style_object_initializer = true:suggestion
|
|
||||||
dotnet_style_collection_initializer = true:suggestion
|
|
||||||
dotnet_style_explicit_tuple_names = true:suggestion
|
|
||||||
dotnet_style_null_propagation = true:suggestion
|
|
||||||
dotnet_style_coalesce_expression = true:suggestion
|
|
||||||
dotnet_style_prefer_is_null_check_over_reference_equality_method = true:silent
|
|
||||||
dotnet_style_prefer_inferred_tuple_names = true:suggestion
|
|
||||||
dotnet_style_prefer_inferred_anonymous_type_member_names = true:suggestion
|
|
||||||
dotnet_style_prefer_auto_properties = true:silent
|
|
||||||
dotnet_style_prefer_conditional_expression_over_assignment = true:silent
|
|
||||||
dotnet_style_prefer_conditional_expression_over_return = true:silent
|
|
||||||
###############################
|
|
||||||
# Naming Conventions #
|
|
||||||
###############################
|
|
||||||
# Style Definitions
|
|
||||||
dotnet_naming_style.pascal_case_style.capitalization = pascal_case
|
|
||||||
# Use PascalCase for constant fields
|
|
||||||
dotnet_naming_rule.constant_fields_should_be_pascal_case.severity = suggestion
|
|
||||||
dotnet_naming_rule.constant_fields_should_be_pascal_case.symbols = constant_fields
|
|
||||||
dotnet_naming_rule.constant_fields_should_be_pascal_case.style = pascal_case_style
|
|
||||||
dotnet_naming_symbols.constant_fields.applicable_kinds = field
|
|
||||||
dotnet_naming_symbols.constant_fields.applicable_accessibilities = *
|
|
||||||
dotnet_naming_symbols.constant_fields.required_modifiers = const
|
|
||||||
###############################
|
|
||||||
# C# Coding Conventions #
|
|
||||||
###############################
|
|
||||||
[*.cs]
|
|
||||||
# var preferences
|
|
||||||
csharp_style_var_for_built_in_types = true:silent
|
|
||||||
csharp_style_var_when_type_is_apparent = true:silent
|
|
||||||
csharp_style_var_elsewhere = true:silent
|
|
||||||
# Expression-bodied members
|
|
||||||
csharp_style_expression_bodied_methods = false:silent
|
|
||||||
csharp_style_expression_bodied_constructors = false:silent
|
|
||||||
csharp_style_expression_bodied_operators = false:silent
|
|
||||||
csharp_style_expression_bodied_properties = true:silent
|
|
||||||
csharp_style_expression_bodied_indexers = true:silent
|
|
||||||
csharp_style_expression_bodied_accessors = true:silent
|
|
||||||
# Pattern matching preferences
|
|
||||||
csharp_style_pattern_matching_over_is_with_cast_check = true:suggestion
|
|
||||||
csharp_style_pattern_matching_over_as_with_null_check = true:suggestion
|
|
||||||
# Null-checking preferences
|
|
||||||
csharp_style_throw_expression = true:suggestion
|
|
||||||
csharp_style_conditional_delegate_call = true:suggestion
|
|
||||||
# Modifier preferences
|
|
||||||
csharp_preferred_modifier_order = public,private,protected,internal,static,extern,new,virtual,abstract,sealed,override,readonly,unsafe,volatile,async:suggestion
|
|
||||||
# Expression-level preferences
|
|
||||||
csharp_prefer_braces = true:silent
|
|
||||||
csharp_style_deconstructed_variable_declaration = true:suggestion
|
|
||||||
csharp_prefer_simple_default_expression = true:suggestion
|
|
||||||
csharp_style_prefer_local_over_anonymous_function = true:suggestion
|
|
||||||
csharp_style_inlined_variable_declaration = true:suggestion
|
|
||||||
###############################
|
|
||||||
# C# Formatting Rules #
|
|
||||||
###############################
|
|
||||||
# New line preferences
|
|
||||||
csharp_new_line_before_open_brace = all
|
|
||||||
csharp_new_line_before_else = true
|
|
||||||
csharp_new_line_before_catch = true
|
|
||||||
csharp_new_line_before_finally = true
|
|
||||||
csharp_new_line_before_members_in_object_initializers = true
|
|
||||||
csharp_new_line_before_members_in_anonymous_types = true
|
|
||||||
csharp_new_line_between_query_expression_clauses = true
|
|
||||||
# Indentation preferences
|
|
||||||
csharp_indent_case_contents = true
|
|
||||||
csharp_indent_switch_labels = true
|
|
||||||
csharp_indent_labels = flush_left
|
|
||||||
# Space preferences
|
|
||||||
csharp_space_after_cast = false
|
|
||||||
csharp_space_after_keywords_in_control_flow_statements = true
|
|
||||||
csharp_space_between_method_call_parameter_list_parentheses = false
|
|
||||||
csharp_space_between_method_declaration_parameter_list_parentheses = false
|
|
||||||
csharp_space_between_parentheses = false
|
|
||||||
csharp_space_before_colon_in_inheritance_clause = true
|
|
||||||
csharp_space_after_colon_in_inheritance_clause = true
|
|
||||||
csharp_space_around_binary_operators = before_and_after
|
|
||||||
csharp_space_between_method_declaration_empty_parameter_list_parentheses = false
|
|
||||||
csharp_space_between_method_call_name_and_opening_parenthesis = false
|
|
||||||
csharp_space_between_method_call_empty_parameter_list_parentheses = false
|
|
||||||
# Wrapping preferences
|
|
||||||
csharp_preserve_single_line_statements = true
|
|
||||||
csharp_preserve_single_line_blocks = true
|
|
||||||
###############################
|
|
||||||
# VB Coding Conventions #
|
|
||||||
###############################
|
|
||||||
[*.vb]
|
|
||||||
# Modifier preferences
|
|
||||||
visual_basic_preferred_modifier_order = Partial,Default,Private,Protected,Public,Friend,NotOverridable,Overridable,MustOverride,Overloads,Overrides,MustInherit,NotInheritable,Static,Shared,Shadows,ReadOnly,WriteOnly,Dim,Const,WithEvents,Widening,Narrowing,Custom,Async:suggestion
|
|
35
.github/workflows/basket-api-deploy.yml
vendored
35
.github/workflows/basket-api-deploy.yml
vendored
@ -1,35 +0,0 @@
|
|||||||
name: Deploy basket-api
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
repository_dispatch:
|
|
||||||
types:
|
|
||||||
- deploy
|
|
||||||
workflow_run:
|
|
||||||
workflows: ["basket-api"]
|
|
||||||
branches: [dev]
|
|
||||||
types: [completed]
|
|
||||||
|
|
||||||
env:
|
|
||||||
CHART: basket-api
|
|
||||||
NAMESPACE: eshop
|
|
||||||
CHART_ROOT: deploy/k8s/helm
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
deploy-to-k8s:
|
|
||||||
#if: ${{ github.event_name == 'workflow_dispatch' || github.event_name == 'repository_dispatch' || github.event.workflow_run.conclusion == 'success' }}
|
|
||||||
if: false
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v2
|
|
||||||
|
|
||||||
- uses: ./.github/workflows/composite/deploy-helm
|
|
||||||
with:
|
|
||||||
azure_credentials: ${{ secrets.AZURE_CREDENTIALS }}
|
|
||||||
cluster_name: ${{ secrets.CLUSTER_NAME }}
|
|
||||||
resource_group: ${{ secrets.RESOURCE_GROUP }}
|
|
||||||
registry_host: ${{ secrets.REGISTRY_HOST }}
|
|
||||||
chart: ${{ env.CHART }}
|
|
||||||
chart_root: ${{ env.CHART_ROOT }}
|
|
||||||
namespace: ${{ env.NAMESPACE }}
|
|
52
.github/workflows/basket-api.yml
vendored
52
.github/workflows/basket-api.yml
vendored
@ -1,52 +0,0 @@
|
|||||||
name: basket-api
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
|
|
||||||
paths:
|
|
||||||
- src/BuildingBlocks/**
|
|
||||||
- src/Services/Basket/**
|
|
||||||
- .github/workflows/basket-api.yml
|
|
||||||
|
|
||||||
pull_request:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
|
|
||||||
paths:
|
|
||||||
- src/BuildingBlocks/**
|
|
||||||
- src/Services/Basket/**
|
|
||||||
- .github/workflows/basket-api.yml
|
|
||||||
env:
|
|
||||||
SERVICE: basket-api
|
|
||||||
IMAGE: basket.api
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
|
|
||||||
BuildContainersForPR_Linux:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: ${{ github.event_name == 'pull_request' }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- uses: ./.github/workflows/composite/build
|
|
||||||
with:
|
|
||||||
service: ${{ env.SERVICE }}
|
|
||||||
registry_endpoint: ${{ secrets.REGISTRY_ENDPOINT }}
|
|
||||||
|
|
||||||
BuildLinux:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: ${{ github.event_name != 'pull_request' }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- uses: ./.github/workflows/composite/build-push
|
|
||||||
with:
|
|
||||||
service: ${{ env.SERVICE }}
|
|
||||||
registry_host: ${{ secrets.REGISTRY_HOST }}
|
|
||||||
registry_endpoint: ${{ secrets.REGISTRY_ENDPOINT }}
|
|
||||||
image_name: ${{ env.IMAGE }}
|
|
||||||
registry_username: ${{ secrets.USERNAME }}
|
|
||||||
registry_password: ${{ secrets.PASSWORD }}
|
|
35
.github/workflows/catalog-api-deploy.yml
vendored
35
.github/workflows/catalog-api-deploy.yml
vendored
@ -1,35 +0,0 @@
|
|||||||
name: Deploy catalog-api
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
repository_dispatch:
|
|
||||||
types:
|
|
||||||
- deploy
|
|
||||||
workflow_run:
|
|
||||||
workflows: ["catalog-api"]
|
|
||||||
branches: [dev]
|
|
||||||
types: [completed]
|
|
||||||
|
|
||||||
env:
|
|
||||||
CHART: catalog-api
|
|
||||||
NAMESPACE: eshop
|
|
||||||
CHART_ROOT: deploy/k8s/helm
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
deploy-to-k8s:
|
|
||||||
#if: ${{ github.event_name == 'workflow_dispatch' || github.event_name == 'repository_dispatch' || github.event.workflow_run.conclusion == 'success' }}
|
|
||||||
if: false
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v2
|
|
||||||
|
|
||||||
- uses: ./.github/workflows/composite/deploy-helm
|
|
||||||
with:
|
|
||||||
azure_credentials: ${{ secrets.AZURE_CREDENTIALS }}
|
|
||||||
cluster_name: ${{ secrets.CLUSTER_NAME }}
|
|
||||||
resource_group: ${{ secrets.RESOURCE_GROUP }}
|
|
||||||
registry_host: ${{ secrets.REGISTRY_HOST }}
|
|
||||||
chart: ${{ env.CHART }}
|
|
||||||
chart_root: ${{ env.CHART_ROOT }}
|
|
||||||
namespace: ${{ env.NAMESPACE }}
|
|
58
.github/workflows/catalog-api.yml
vendored
58
.github/workflows/catalog-api.yml
vendored
@ -1,58 +0,0 @@
|
|||||||
name: catalog-api
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
|
|
||||||
paths:
|
|
||||||
- src/BuildingBlocks/**
|
|
||||||
- src/Services/Catalog/**
|
|
||||||
- .github/workflows/catalog-api.yml
|
|
||||||
|
|
||||||
pull_request:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
|
|
||||||
paths:
|
|
||||||
- src/BuildingBlocks/**
|
|
||||||
- src/Services/Catalog/**
|
|
||||||
- .github/workflows/catalog-api.yml
|
|
||||||
env:
|
|
||||||
SERVICE: catalog-api
|
|
||||||
IMAGE: catalog.api
|
|
||||||
DOTNET_VERSION: 7.0.x
|
|
||||||
PROJECT_PATH: Services/Catalog/Catalog.API
|
|
||||||
TESTS_PATH: Services/Catalog/Catalog.UnitTests
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
|
|
||||||
BuildContainersForPR_Linux:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: ${{ github.event_name == 'pull_request' }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- uses: ./.github/workflows/composite/build-test
|
|
||||||
with:
|
|
||||||
service: ${{ env.SERVICE }}
|
|
||||||
registry_endpoint: ${{ secrets.REGISTRY_ENDPOINT }}
|
|
||||||
dotnet_version: ${{ env.DOTNET_VERSION }}
|
|
||||||
project_path: ${{ env.PROJECT_PATH }}
|
|
||||||
tests_path: ${{ env.TESTS_PATH }}
|
|
||||||
|
|
||||||
BuildLinux:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: ${{ github.event_name != 'pull_request' }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- uses: ./.github/workflows/composite/build-push
|
|
||||||
with:
|
|
||||||
service: ${{ env.SERVICE }}
|
|
||||||
registry_host: ${{ secrets.REGISTRY_HOST }}
|
|
||||||
registry_endpoint: ${{ secrets.REGISTRY_ENDPOINT }}
|
|
||||||
image_name: ${{ env.IMAGE }}
|
|
||||||
registry_username: ${{ secrets.USERNAME }}
|
|
||||||
registry_password: ${{ secrets.PASSWORD }}
|
|
@ -1,71 +0,0 @@
|
|||||||
name: "Build and push image"
|
|
||||||
description: "Builds and pushes an image to a registry"
|
|
||||||
|
|
||||||
inputs:
|
|
||||||
service:
|
|
||||||
description: "Service to build"
|
|
||||||
required: true
|
|
||||||
registry_host:
|
|
||||||
description: "Image registry host e.g. myacr.azureacr.io"
|
|
||||||
required: true
|
|
||||||
registry_endpoint:
|
|
||||||
description: "Image registry repo e.g. myacr.azureacr.io/eshop"
|
|
||||||
required: true
|
|
||||||
image_name:
|
|
||||||
description: "Name of image"
|
|
||||||
required: true
|
|
||||||
registry_username:
|
|
||||||
description: "Registry username"
|
|
||||||
required: true
|
|
||||||
registry_password:
|
|
||||||
description: "Registry password"
|
|
||||||
required: true
|
|
||||||
|
|
||||||
runs:
|
|
||||||
using: "composite"
|
|
||||||
steps:
|
|
||||||
- name: Enable experimental features for the Docker daemon and CLI
|
|
||||||
shell: bash
|
|
||||||
run: |
|
|
||||||
echo $'{\n "experimental": true\n}' | sudo tee /etc/docker/daemon.json
|
|
||||||
mkdir -p ~/.docker
|
|
||||||
echo $'{\n "experimental": "enabled"\n}' | sudo tee ~/.docker/config.json
|
|
||||||
sudo service docker restart
|
|
||||||
docker version -f '{{.Client.Experimental}}'
|
|
||||||
docker version -f '{{.Server.Experimental}}'
|
|
||||||
|
|
||||||
- name: Login to Container Registry
|
|
||||||
uses: docker/login-action@v1
|
|
||||||
with:
|
|
||||||
registry: ${{ inputs.registry_host }}
|
|
||||||
username: ${{ inputs.registry_username }}
|
|
||||||
password: ${{ inputs.registry_password }}
|
|
||||||
|
|
||||||
- name: Set branch name as env variable
|
|
||||||
run: |
|
|
||||||
currentbranch=$(echo ${GITHUB_REF##*/})
|
|
||||||
echo "running on $currentbranch"
|
|
||||||
echo "BRANCH=$currentbranch" >> $GITHUB_ENV
|
|
||||||
shell: bash
|
|
||||||
|
|
||||||
- name: Compose build ${{ inputs.service }}
|
|
||||||
shell: bash
|
|
||||||
run: sudo -E docker-compose build ${{ inputs.service }}
|
|
||||||
working-directory: ./src
|
|
||||||
env:
|
|
||||||
TAG: ${{ env.BRANCH }}
|
|
||||||
REGISTRY: ${{ inputs.registry_endpoint }}
|
|
||||||
|
|
||||||
- name: Compose push ${{ inputs.service }}
|
|
||||||
shell: bash
|
|
||||||
run: sudo -E docker-compose push ${{ inputs.service }}
|
|
||||||
working-directory: ./src
|
|
||||||
env:
|
|
||||||
TAG: ${{ env.BRANCH }}
|
|
||||||
REGISTRY: ${{ inputs.registry_endpoint }}
|
|
||||||
|
|
||||||
- name: Create multiarch manifest
|
|
||||||
shell: bash
|
|
||||||
run: |
|
|
||||||
docker --config ~/.docker manifest create ${{ inputs.registry_endpoint }}/${{ inputs.image_name }}:${{ env.BRANCH }} ${{ inputs.registry_endpoint }}/${{ inputs.image_name }}:linux-${{ env.BRANCH }}
|
|
||||||
docker --config ~/.docker manifest push ${{ inputs.registry_endpoint }}/${{ inputs.image_name }}:${{ env.BRANCH }}
|
|
@ -1,47 +0,0 @@
|
|||||||
name: "Build for PRe"
|
|
||||||
description: "Builds a docker image without pushing"
|
|
||||||
|
|
||||||
inputs:
|
|
||||||
service:
|
|
||||||
description: "Service to build"
|
|
||||||
required: true
|
|
||||||
registry_endpoint:
|
|
||||||
description: "Image registry repo e.g. myacr.azureacr.io/eshop"
|
|
||||||
required: true
|
|
||||||
dotnet_version:
|
|
||||||
description: "Version of dotnet to use for testing"
|
|
||||||
required: true
|
|
||||||
project_path:
|
|
||||||
description: "Path to project to test e.g. Services/Catalog/Catalog.API"
|
|
||||||
required: true
|
|
||||||
tests_path:
|
|
||||||
description: "Path to test project e.g. Services/Catalog/Catalog.UnitTests"
|
|
||||||
required: true
|
|
||||||
|
|
||||||
runs:
|
|
||||||
using: "composite"
|
|
||||||
steps:
|
|
||||||
- name: Setup dotnet
|
|
||||||
uses: actions/setup-dotnet@v1
|
|
||||||
with:
|
|
||||||
dotnet-version: ${{ inputs.dotnet_version }}
|
|
||||||
|
|
||||||
- name: Build and run unit tests
|
|
||||||
shell: bash
|
|
||||||
run: |
|
|
||||||
cd src
|
|
||||||
dotnet restore "eShopOnContainers-ServicesAndWebApps.sln"
|
|
||||||
cd ${{ inputs.project_path }}
|
|
||||||
dotnet build --no-restore
|
|
||||||
cd -
|
|
||||||
cd ${{ inputs.tests_path }}
|
|
||||||
dotnet build --no-restore
|
|
||||||
dotnet test --no-build -v=normal
|
|
||||||
|
|
||||||
- name: Compose build ${{ inputs.service }}
|
|
||||||
shell: bash
|
|
||||||
run: sudo -E docker-compose build ${{ inputs.service }}
|
|
||||||
working-directory: ./src
|
|
||||||
env:
|
|
||||||
TAG: ${{ env.BRANCH }}
|
|
||||||
REGISTRY: ${{ inputs.registry_endpoint }}
|
|
21
.github/workflows/composite/build/action.yml
vendored
21
.github/workflows/composite/build/action.yml
vendored
@ -1,21 +0,0 @@
|
|||||||
name: "Build for PRe"
|
|
||||||
description: "Builds a docker image without pushing"
|
|
||||||
|
|
||||||
inputs:
|
|
||||||
service:
|
|
||||||
description: "Service to build"
|
|
||||||
required: true
|
|
||||||
registry_endpoint:
|
|
||||||
description: "Image registry repo e.g. myacr.azureacr.io/eshop"
|
|
||||||
required: true
|
|
||||||
|
|
||||||
runs:
|
|
||||||
using: "composite"
|
|
||||||
steps:
|
|
||||||
- name: Compose build ${{ inputs.service }}
|
|
||||||
shell: bash
|
|
||||||
run: sudo -E docker-compose build ${{ inputs.service }}
|
|
||||||
working-directory: ./src
|
|
||||||
env:
|
|
||||||
TAG: ${{ env.BRANCH }}
|
|
||||||
REGISTRY: ${{ inputs.registry_endpoint }}
|
|
@ -1,54 +0,0 @@
|
|||||||
name: "Deploy Helm to AKS"
|
|
||||||
description: "Deploys a helm chart to AKS"
|
|
||||||
|
|
||||||
inputs:
|
|
||||||
azure_credentials:
|
|
||||||
description: "Credentials to connect to AKS"
|
|
||||||
required: true
|
|
||||||
cluster_name:
|
|
||||||
description: "Name of AKS cluster"
|
|
||||||
required: true
|
|
||||||
resource_group:
|
|
||||||
description: "Resource group of AKS cluster"
|
|
||||||
required: true
|
|
||||||
registry_host:
|
|
||||||
description: "Image registry host e.g. myacr.azureacr.io"
|
|
||||||
required: true
|
|
||||||
chart:
|
|
||||||
description: "Chart name"
|
|
||||||
required: true
|
|
||||||
chart_root:
|
|
||||||
description: "Root folder of chart"
|
|
||||||
required: true
|
|
||||||
namespace:
|
|
||||||
description: "Namespace to deploy to"
|
|
||||||
required: true
|
|
||||||
|
|
||||||
runs:
|
|
||||||
using: "composite"
|
|
||||||
steps:
|
|
||||||
- uses: azure/login@v1
|
|
||||||
with:
|
|
||||||
creds: ${{ inputs.azure_credentials }}
|
|
||||||
|
|
||||||
- uses: azure/aks-set-context@v1
|
|
||||||
name: Set AKS context
|
|
||||||
with:
|
|
||||||
creds: '${{ inputs.azure_credentials }}'
|
|
||||||
cluster-name: ${{ inputs.cluster_name }}
|
|
||||||
resource-group: ${{ inputs.resource_group }}
|
|
||||||
|
|
||||||
- name: Set branch name as env variable
|
|
||||||
shell: bash
|
|
||||||
run: |
|
|
||||||
currentbranch=$(echo ${GITHUB_REF##*/})
|
|
||||||
echo "running on $currentbranch"
|
|
||||||
echo "BRANCH=$currentbranch" >> $GITHUB_ENV
|
|
||||||
|
|
||||||
- name: Deploy Chart
|
|
||||||
shell: bash
|
|
||||||
run: |
|
|
||||||
./deploy-chart.sh -c ${{ inputs.chart }} --dns aks --aks-name ${{ inputs.clusteR_name }} --aks-rg ${{ inputs.resource_group }} -r ${{ inputs.registry_host }} -t $TAG --namespace ${{ inputs.namespace }} --acr-connected
|
|
||||||
env:
|
|
||||||
TAG: ${{ env.BRANCH }}
|
|
||||||
working-directory: ${{ inputs.chart_root }}
|
|
35
.github/workflows/identity-api-deploy.yml
vendored
35
.github/workflows/identity-api-deploy.yml
vendored
@ -1,35 +0,0 @@
|
|||||||
name: Deploy identity-api
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
repository_dispatch:
|
|
||||||
types:
|
|
||||||
- deploy
|
|
||||||
workflow_run:
|
|
||||||
workflows: ["identity-api"]
|
|
||||||
branches: [dev]
|
|
||||||
types: [completed]
|
|
||||||
|
|
||||||
env:
|
|
||||||
CHART: identity-api
|
|
||||||
NAMESPACE: eshop
|
|
||||||
CHART_ROOT: deploy/k8s/helm
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
deploy-to-k8s:
|
|
||||||
#if: ${{ github.event_name == 'workflow_dispatch' || github.event_name == 'repository_dispatch' || github.event.workflow_run.conclusion == 'success' }}
|
|
||||||
if: false
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v2
|
|
||||||
|
|
||||||
- uses: ./.github/workflows/composite/deploy-helm
|
|
||||||
with:
|
|
||||||
azure_credentials: ${{ secrets.AZURE_CREDENTIALS }}
|
|
||||||
cluster_name: ${{ secrets.CLUSTER_NAME }}
|
|
||||||
resource_group: ${{ secrets.RESOURCE_GROUP }}
|
|
||||||
registry_host: ${{ secrets.REGISTRY_HOST }}
|
|
||||||
chart: ${{ env.CHART }}
|
|
||||||
chart_root: ${{ env.CHART_ROOT }}
|
|
||||||
namespace: ${{ env.NAMESPACE }}
|
|
52
.github/workflows/identity-api.yml
vendored
52
.github/workflows/identity-api.yml
vendored
@ -1,52 +0,0 @@
|
|||||||
name: identity-api
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
|
|
||||||
paths:
|
|
||||||
- src/BuildingBlocks/**
|
|
||||||
- src/Services/Identity/**
|
|
||||||
- .github/workflows/identity-api.yml
|
|
||||||
|
|
||||||
pull_request:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
|
|
||||||
paths:
|
|
||||||
- src/BuildingBlocks/**
|
|
||||||
- src/Services/Identity/**
|
|
||||||
- .github/workflows/identity-api.yml
|
|
||||||
env:
|
|
||||||
SERVICE: identity-api
|
|
||||||
IMAGE: identity.api
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
|
|
||||||
BuildContainersForPR_Linux:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: ${{ github.event_name == 'pull_request' }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- uses: ./.github/workflows/composite/build
|
|
||||||
with:
|
|
||||||
service: ${{ env.SERVICE }}
|
|
||||||
registry_endpoint: ${{ secrets.REGISTRY_ENDPOINT }}
|
|
||||||
|
|
||||||
BuildLinux:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: ${{ github.event_name != 'pull_request' }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- uses: ./.github/workflows/composite/build-push
|
|
||||||
with:
|
|
||||||
service: ${{ env.SERVICE }}
|
|
||||||
registry_host: ${{ secrets.REGISTRY_HOST }}
|
|
||||||
registry_endpoint: ${{ secrets.REGISTRY_ENDPOINT }}
|
|
||||||
image_name: ${{ env.IMAGE }}
|
|
||||||
registry_username: ${{ secrets.USERNAME }}
|
|
||||||
registry_password: ${{ secrets.PASSWORD }}
|
|
35
.github/workflows/mobileshoppingagg-deploy.yml
vendored
35
.github/workflows/mobileshoppingagg-deploy.yml
vendored
@ -1,35 +0,0 @@
|
|||||||
name: Deploy mobileshoppingagg
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
repository_dispatch:
|
|
||||||
types:
|
|
||||||
- deploy
|
|
||||||
workflow_run:
|
|
||||||
workflows: ["mobileshoppingagg"]
|
|
||||||
branches: [dev]
|
|
||||||
types: [completed]
|
|
||||||
|
|
||||||
env:
|
|
||||||
CHART: mobileshoppingagg
|
|
||||||
NAMESPACE: eshop
|
|
||||||
CHART_ROOT: deploy/k8s/helm
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
deploy-to-k8s:
|
|
||||||
#if: ${{ github.event_name == 'workflow_dispatch' || github.event_name == 'repository_dispatch' || github.event.workflow_run.conclusion == 'success' }}
|
|
||||||
if: false
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v2
|
|
||||||
|
|
||||||
- uses: ./.github/workflows/composite/deploy-helm
|
|
||||||
with:
|
|
||||||
azure_credentials: ${{ secrets.AZURE_CREDENTIALS }}
|
|
||||||
cluster_name: ${{ secrets.CLUSTER_NAME }}
|
|
||||||
resource_group: ${{ secrets.RESOURCE_GROUP }}
|
|
||||||
registry_host: ${{ secrets.REGISTRY_HOST }}
|
|
||||||
chart: ${{ env.CHART }}
|
|
||||||
chart_root: ${{ env.CHART_ROOT }}
|
|
||||||
namespace: ${{ env.NAMESPACE }}
|
|
50
.github/workflows/mobileshoppingagg.yml
vendored
50
.github/workflows/mobileshoppingagg.yml
vendored
@ -1,50 +0,0 @@
|
|||||||
name: mobileshoppingagg
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
|
|
||||||
paths:
|
|
||||||
- src/ApiGateways/Mobile.Bff.Shopping/aggregator/**
|
|
||||||
- .github/workflows/mobileshoppingagg.yml
|
|
||||||
|
|
||||||
pull_request:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
|
|
||||||
paths:
|
|
||||||
- src/ApiGateways/Mobile.Bff.Shopping/aggregator/**
|
|
||||||
- .github/workflows/mobileshoppingagg.yml
|
|
||||||
env:
|
|
||||||
SERVICE: mobileshoppingagg
|
|
||||||
IMAGE: mobileshoppingagg
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
|
|
||||||
BuildContainersForPR_Linux:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: ${{ github.event_name == 'pull_request' }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- uses: ./.github/workflows/composite/build
|
|
||||||
with:
|
|
||||||
service: ${{ env.SERVICE }}
|
|
||||||
registry_endpoint: ${{ secrets.REGISTRY_ENDPOINT }}
|
|
||||||
|
|
||||||
BuildLinux:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: ${{ github.event_name != 'pull_request' }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- uses: ./.github/workflows/composite/build-push
|
|
||||||
with:
|
|
||||||
service: ${{ env.SERVICE }}
|
|
||||||
registry_host: ${{ secrets.REGISTRY_HOST }}
|
|
||||||
registry_endpoint: ${{ secrets.REGISTRY_ENDPOINT }}
|
|
||||||
image_name: ${{ env.IMAGE }}
|
|
||||||
registry_username: ${{ secrets.USERNAME }}
|
|
||||||
registry_password: ${{ secrets.PASSWORD }}
|
|
35
.github/workflows/ordering-api-deploy.yml
vendored
35
.github/workflows/ordering-api-deploy.yml
vendored
@ -1,35 +0,0 @@
|
|||||||
name: Deploy ordering-api
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
repository_dispatch:
|
|
||||||
types:
|
|
||||||
- deploy
|
|
||||||
workflow_run:
|
|
||||||
workflows: ["ordering-api"]
|
|
||||||
branches: [dev]
|
|
||||||
types: [completed]
|
|
||||||
|
|
||||||
env:
|
|
||||||
CHART: ordering-api
|
|
||||||
NAMESPACE: eshop
|
|
||||||
CHART_ROOT: deploy/k8s/helm
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
deploy-to-k8s:
|
|
||||||
#if: ${{ github.event_name == 'workflow_dispatch' || github.event_name == 'repository_dispatch' || github.event.workflow_run.conclusion == 'success' }}
|
|
||||||
if: false
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v2
|
|
||||||
|
|
||||||
- uses: ./.github/workflows/composite/deploy-helm
|
|
||||||
with:
|
|
||||||
azure_credentials: ${{ secrets.AZURE_CREDENTIALS }}
|
|
||||||
cluster_name: ${{ secrets.CLUSTER_NAME }}
|
|
||||||
resource_group: ${{ secrets.RESOURCE_GROUP }}
|
|
||||||
registry_host: ${{ secrets.REGISTRY_HOST }}
|
|
||||||
chart: ${{ env.CHART }}
|
|
||||||
chart_root: ${{ env.CHART_ROOT }}
|
|
||||||
namespace: ${{ env.NAMESPACE }}
|
|
58
.github/workflows/ordering-api.yml
vendored
58
.github/workflows/ordering-api.yml
vendored
@ -1,58 +0,0 @@
|
|||||||
name: ordering-api
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
|
|
||||||
paths:
|
|
||||||
- src/BuildingBlocks/**
|
|
||||||
- src/Services/Ordering/**
|
|
||||||
- .github/workflows/ordering-api.yml
|
|
||||||
|
|
||||||
pull_request:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
|
|
||||||
paths:
|
|
||||||
- src/BuildingBlocks/**
|
|
||||||
- src/Services/Ordering/**
|
|
||||||
- .github/workflows/ordering-api.yml
|
|
||||||
env:
|
|
||||||
SERVICE: ordering-api
|
|
||||||
IMAGE: ordering.api
|
|
||||||
DOTNET_VERSION: 7.0.x
|
|
||||||
PROJECT_PATH: Services/Ordering/Ordering.API
|
|
||||||
TESTS_PATH: Services/Ordering/Ordering.UnitTests
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
|
|
||||||
BuildContainersForPR_Linux:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: ${{ github.event_name == 'pull_request' }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- uses: ./.github/workflows/composite/build-test
|
|
||||||
with:
|
|
||||||
service: ${{ env.SERVICE }}
|
|
||||||
registry_endpoint: ${{ secrets.REGISTRY_ENDPOINT }}
|
|
||||||
dotnet_version: ${{ env.DOTNET_VERSION }}
|
|
||||||
project_path: ${{ env.PROJECT_PATH }}
|
|
||||||
tests_path: ${{ env.TESTS_PATH }}
|
|
||||||
|
|
||||||
BuildLinux:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: ${{ github.event_name != 'pull_request' }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- uses: ./.github/workflows/composite/build-push
|
|
||||||
with:
|
|
||||||
service: ${{ env.SERVICE }}
|
|
||||||
registry_host: ${{ secrets.REGISTRY_HOST }}
|
|
||||||
registry_endpoint: ${{ secrets.REGISTRY_ENDPOINT }}
|
|
||||||
image_name: ${{ env.IMAGE }}
|
|
||||||
registry_username: ${{ secrets.USERNAME }}
|
|
||||||
registry_password: ${{ secrets.PASSWORD }}
|
|
@ -1,35 +0,0 @@
|
|||||||
name: Deploy ordering-backgroundtasks
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
repository_dispatch:
|
|
||||||
types:
|
|
||||||
- deploy
|
|
||||||
workflow_run:
|
|
||||||
workflows: ["ordering-backgroundtasks"]
|
|
||||||
branches: [dev]
|
|
||||||
types: [completed]
|
|
||||||
|
|
||||||
env:
|
|
||||||
CHART: ordering-backgroundtasks
|
|
||||||
NAMESPACE: eshop
|
|
||||||
CHART_ROOT: deploy/k8s/helm
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
deploy-to-k8s:
|
|
||||||
#if: ${{ github.event_name == 'workflow_dispatch' || github.event_name == 'repository_dispatch' || github.event.workflow_run.conclusion == 'success' }}
|
|
||||||
if: false
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v2
|
|
||||||
|
|
||||||
- uses: ./.github/workflows/composite/deploy-helm
|
|
||||||
with:
|
|
||||||
azure_credentials: ${{ secrets.AZURE_CREDENTIALS }}
|
|
||||||
cluster_name: ${{ secrets.CLUSTER_NAME }}
|
|
||||||
resource_group: ${{ secrets.RESOURCE_GROUP }}
|
|
||||||
registry_host: ${{ secrets.REGISTRY_HOST }}
|
|
||||||
chart: ${{ env.CHART }}
|
|
||||||
chart_root: ${{ env.CHART_ROOT }}
|
|
||||||
namespace: ${{ env.NAMESPACE }}
|
|
52
.github/workflows/ordering-backgroundtasks.yml
vendored
52
.github/workflows/ordering-backgroundtasks.yml
vendored
@ -1,52 +0,0 @@
|
|||||||
name: ordering-backgroundtasks
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
|
|
||||||
paths:
|
|
||||||
- src/BuildingBlocks/**
|
|
||||||
- src/Services/Ordering/**
|
|
||||||
- .github/workflows/ordering-backgroundtasks.yml
|
|
||||||
|
|
||||||
pull_request:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
|
|
||||||
paths:
|
|
||||||
- src/BuildingBlocks/**
|
|
||||||
- src/Services/Ordering/**
|
|
||||||
- .github/workflows/ordering-backgroundtasks.yml
|
|
||||||
env:
|
|
||||||
SERVICE: ordering-backgroundtasks
|
|
||||||
IMAGE: ordering.backgroundtasks
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
|
|
||||||
BuildContainersForPR_Linux:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: ${{ github.event_name == 'pull_request' }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- uses: ./.github/workflows/composite/build
|
|
||||||
with:
|
|
||||||
service: ${{ env.SERVICE }}
|
|
||||||
registry_endpoint: ${{ secrets.REGISTRY_ENDPOINT }}
|
|
||||||
|
|
||||||
BuildLinux:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: ${{ github.event_name != 'pull_request' }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- uses: ./.github/workflows/composite/build-push
|
|
||||||
with:
|
|
||||||
service: ${{ env.SERVICE }}
|
|
||||||
registry_host: ${{ secrets.REGISTRY_HOST }}
|
|
||||||
registry_endpoint: ${{ secrets.REGISTRY_ENDPOINT }}
|
|
||||||
image_name: ${{ env.IMAGE }}
|
|
||||||
registry_username: ${{ secrets.USERNAME }}
|
|
||||||
registry_password: ${{ secrets.PASSWORD }}
|
|
35
.github/workflows/ordering-signalrhub-deploy.yml
vendored
35
.github/workflows/ordering-signalrhub-deploy.yml
vendored
@ -1,35 +0,0 @@
|
|||||||
name: Deploy ordering-signalrhub
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
repository_dispatch:
|
|
||||||
types:
|
|
||||||
- deploy
|
|
||||||
workflow_run:
|
|
||||||
workflows: ["ordering-signalrhub"]
|
|
||||||
branches: [dev]
|
|
||||||
types: [completed]
|
|
||||||
|
|
||||||
env:
|
|
||||||
CHART: ordering-signalrhub
|
|
||||||
NAMESPACE: eshop
|
|
||||||
CHART_ROOT: deploy/k8s/helm
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
deploy-to-k8s:
|
|
||||||
#if: ${{ github.event_name == 'workflow_dispatch' || github.event_name == 'repository_dispatch' || github.event.workflow_run.conclusion == 'success' }}
|
|
||||||
if: false
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v2
|
|
||||||
|
|
||||||
- uses: ./.github/workflows/composite/deploy-helm
|
|
||||||
with:
|
|
||||||
azure_credentials: ${{ secrets.AZURE_CREDENTIALS }}
|
|
||||||
cluster_name: ${{ secrets.CLUSTER_NAME }}
|
|
||||||
resource_group: ${{ secrets.RESOURCE_GROUP }}
|
|
||||||
registry_host: ${{ secrets.REGISTRY_HOST }}
|
|
||||||
chart: ${{ env.CHART }}
|
|
||||||
chart_root: ${{ env.CHART_ROOT }}
|
|
||||||
namespace: ${{ env.NAMESPACE }}
|
|
52
.github/workflows/ordering-signalrhub.yml
vendored
52
.github/workflows/ordering-signalrhub.yml
vendored
@ -1,52 +0,0 @@
|
|||||||
name: ordering-signalrhub
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
|
|
||||||
paths:
|
|
||||||
- src/BuildingBlocks/**
|
|
||||||
- src/Services/Ordering/**
|
|
||||||
- .github/workflows/ordering-signalrhub.yml
|
|
||||||
|
|
||||||
pull_request:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
|
|
||||||
paths:
|
|
||||||
- src/BuildingBlocks/**
|
|
||||||
- src/Services/Ordering/**
|
|
||||||
- .github/workflows/ordering-signalrhub.yml
|
|
||||||
env:
|
|
||||||
SERVICE: ordering-signalrhub
|
|
||||||
IMAGE: ordering.signalrhub
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
|
|
||||||
BuildContainersForPR_Linux:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: ${{ github.event_name == 'pull_request' }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- uses: ./.github/workflows/composite/build
|
|
||||||
with:
|
|
||||||
service: ${{ env.SERVICE }}
|
|
||||||
registry_endpoint: ${{ secrets.REGISTRY_ENDPOINT }}
|
|
||||||
|
|
||||||
BuildLinux:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: ${{ github.event_name != 'pull_request' }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- uses: ./.github/workflows/composite/build-push
|
|
||||||
with:
|
|
||||||
service: ${{ env.SERVICE }}
|
|
||||||
registry_host: ${{ secrets.REGISTRY_HOST }}
|
|
||||||
registry_endpoint: ${{ secrets.REGISTRY_ENDPOINT }}
|
|
||||||
image_name: ${{ env.IMAGE }}
|
|
||||||
registry_username: ${{ secrets.USERNAME }}
|
|
||||||
registry_password: ${{ secrets.PASSWORD }}
|
|
35
.github/workflows/payment-api-deploy.yml
vendored
35
.github/workflows/payment-api-deploy.yml
vendored
@ -1,35 +0,0 @@
|
|||||||
name: Deploy payment-api
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
repository_dispatch:
|
|
||||||
types:
|
|
||||||
- deploy
|
|
||||||
workflow_run:
|
|
||||||
workflows: ["payment-api"]
|
|
||||||
branches: [dev]
|
|
||||||
types: [completed]
|
|
||||||
|
|
||||||
env:
|
|
||||||
CHART: payment-api
|
|
||||||
NAMESPACE: eshop
|
|
||||||
CHART_ROOT: deploy/k8s/helm
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
deploy-to-k8s:
|
|
||||||
#if: ${{ github.event_name == 'workflow_dispatch' || github.event_name == 'repository_dispatch' || github.event.workflow_run.conclusion == 'success' }}
|
|
||||||
if: false
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v2
|
|
||||||
|
|
||||||
- uses: ./.github/workflows/composite/deploy-helm
|
|
||||||
with:
|
|
||||||
azure_credentials: ${{ secrets.AZURE_CREDENTIALS }}
|
|
||||||
cluster_name: ${{ secrets.CLUSTER_NAME }}
|
|
||||||
resource_group: ${{ secrets.RESOURCE_GROUP }}
|
|
||||||
registry_host: ${{ secrets.REGISTRY_HOST }}
|
|
||||||
chart: ${{ env.CHART }}
|
|
||||||
chart_root: ${{ env.CHART_ROOT }}
|
|
||||||
namespace: ${{ env.NAMESPACE }}
|
|
52
.github/workflows/payment-api.yml
vendored
52
.github/workflows/payment-api.yml
vendored
@ -1,52 +0,0 @@
|
|||||||
name: payment-api
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
|
|
||||||
paths:
|
|
||||||
- src/BuildingBlocks/**
|
|
||||||
- src/Services/Payment/**
|
|
||||||
- .github/workflows/payment-api.yml
|
|
||||||
|
|
||||||
pull_request:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
|
|
||||||
paths:
|
|
||||||
- src/BuildingBlocks/**
|
|
||||||
- src/Services/Payment/**
|
|
||||||
- .github/workflows/payment-api.yml
|
|
||||||
env:
|
|
||||||
SERVICE: payment-api
|
|
||||||
IMAGE: payment.api
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
|
|
||||||
BuildContainersForPR_Linux:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: ${{ github.event_name == 'pull_request' }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- uses: ./.github/workflows/composite/build
|
|
||||||
with:
|
|
||||||
service: ${{ env.SERVICE }}
|
|
||||||
registry_endpoint: ${{ secrets.REGISTRY_ENDPOINT }}
|
|
||||||
|
|
||||||
BuildLinux:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: ${{ github.event_name != 'pull_request' }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- uses: ./.github/workflows/composite/build-push
|
|
||||||
with:
|
|
||||||
service: ${{ env.SERVICE }}
|
|
||||||
registry_host: ${{ secrets.REGISTRY_HOST }}
|
|
||||||
registry_endpoint: ${{ secrets.REGISTRY_ENDPOINT }}
|
|
||||||
image_name: ${{ env.IMAGE }}
|
|
||||||
registry_username: ${{ secrets.USERNAME }}
|
|
||||||
registry_password: ${{ secrets.PASSWORD }}
|
|
35
.github/workflows/webhooks-api-deploy.yml
vendored
35
.github/workflows/webhooks-api-deploy.yml
vendored
@ -1,35 +0,0 @@
|
|||||||
name: Deploy webhooks-api
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
repository_dispatch:
|
|
||||||
types:
|
|
||||||
- deploy
|
|
||||||
workflow_run:
|
|
||||||
workflows: ["webhooks-api"]
|
|
||||||
branches: [dev]
|
|
||||||
types: [completed]
|
|
||||||
|
|
||||||
env:
|
|
||||||
CHART: webhooks-api
|
|
||||||
NAMESPACE: eshop
|
|
||||||
CHART_ROOT: deploy/k8s/helm
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
deploy-to-k8s:
|
|
||||||
#if: ${{ github.event_name == 'workflow_dispatch' || github.event_name == 'repository_dispatch' || github.event.workflow_run.conclusion == 'success' }}
|
|
||||||
if: false
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v2
|
|
||||||
|
|
||||||
- uses: ./.github/workflows/composite/deploy-helm
|
|
||||||
with:
|
|
||||||
azure_credentials: ${{ secrets.AZURE_CREDENTIALS }}
|
|
||||||
cluster_name: ${{ secrets.CLUSTER_NAME }}
|
|
||||||
resource_group: ${{ secrets.RESOURCE_GROUP }}
|
|
||||||
registry_host: ${{ secrets.REGISTRY_HOST }}
|
|
||||||
chart: ${{ env.CHART }}
|
|
||||||
chart_root: ${{ env.CHART_ROOT }}
|
|
||||||
namespace: ${{ env.NAMESPACE }}
|
|
52
.github/workflows/webhooks-api.yml
vendored
52
.github/workflows/webhooks-api.yml
vendored
@ -1,52 +0,0 @@
|
|||||||
name: webhooks-api
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
|
|
||||||
paths:
|
|
||||||
- src/BuildingBlocks/**
|
|
||||||
- src/Services/Webhooks/**
|
|
||||||
- .github/workflows/webhooks-api.yml
|
|
||||||
|
|
||||||
pull_request:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
|
|
||||||
paths:
|
|
||||||
- src/BuildingBlocks/**
|
|
||||||
- src/Services/Webhooks/**
|
|
||||||
- .github/workflows/webhooks-api.yml
|
|
||||||
env:
|
|
||||||
SERVICE: webhooks-api
|
|
||||||
IMAGE: webhooks.api
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
|
|
||||||
BuildContainersForPR_Linux:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: ${{ github.event_name == 'pull_request' }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- uses: ./.github/workflows/composite/build
|
|
||||||
with:
|
|
||||||
service: ${{ env.SERVICE }}
|
|
||||||
registry_endpoint: ${{ secrets.REGISTRY_ENDPOINT }}
|
|
||||||
|
|
||||||
BuildLinux:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: ${{ github.event_name != 'pull_request' }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- uses: ./.github/workflows/composite/build-push
|
|
||||||
with:
|
|
||||||
service: ${{ env.SERVICE }}
|
|
||||||
registry_host: ${{ secrets.REGISTRY_HOST }}
|
|
||||||
registry_endpoint: ${{ secrets.REGISTRY_ENDPOINT }}
|
|
||||||
image_name: ${{ env.IMAGE }}
|
|
||||||
registry_username: ${{ secrets.USERNAME }}
|
|
||||||
registry_password: ${{ secrets.PASSWORD }}
|
|
52
.github/workflows/webhooks-client.yml
vendored
52
.github/workflows/webhooks-client.yml
vendored
@ -1,52 +0,0 @@
|
|||||||
name: webhooks-client
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
|
|
||||||
paths:
|
|
||||||
- src/BuildingBlocks/**
|
|
||||||
- src/Web/WebhookClient/**
|
|
||||||
- .github/workflows/webhooks-client.yml
|
|
||||||
|
|
||||||
pull_request:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
|
|
||||||
paths:
|
|
||||||
- src/BuildingBlocks/**
|
|
||||||
- src/Web/WebhookClient/**
|
|
||||||
- .github/workflows/webhooks-client.yml
|
|
||||||
env:
|
|
||||||
SERVICE: webhooks-client
|
|
||||||
IMAGE: webhooks.client
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
|
|
||||||
BuildContainersForPR_Linux:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: ${{ github.event_name == 'pull_request' }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- uses: ./.github/workflows/composite/build
|
|
||||||
with:
|
|
||||||
service: ${{ env.SERVICE }}
|
|
||||||
registry_endpoint: ${{ secrets.REGISTRY_ENDPOINT }}
|
|
||||||
|
|
||||||
BuildLinux:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: ${{ github.event_name != 'pull_request' }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- uses: ./.github/workflows/composite/build-push
|
|
||||||
with:
|
|
||||||
service: ${{ env.SERVICE }}
|
|
||||||
registry_host: ${{ secrets.REGISTRY_HOST }}
|
|
||||||
registry_endpoint: ${{ secrets.REGISTRY_ENDPOINT }}
|
|
||||||
image_name: ${{ env.IMAGE }}
|
|
||||||
registry_username: ${{ secrets.USERNAME }}
|
|
||||||
registry_password: ${{ secrets.PASSWORD }}
|
|
39
.github/workflows/webmvc-deploy.yml
vendored
39
.github/workflows/webmvc-deploy.yml
vendored
@ -1,39 +0,0 @@
|
|||||||
name: Deploy webmvc
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
repository_dispatch:
|
|
||||||
types:
|
|
||||||
- deploy
|
|
||||||
workflow_run:
|
|
||||||
workflows: ["webmvc"]
|
|
||||||
branches: [dev]
|
|
||||||
types: [completed]
|
|
||||||
|
|
||||||
env:
|
|
||||||
CHART: webmvc
|
|
||||||
NAMESPACE: eshop
|
|
||||||
CHART_ROOT: deploy/k8s/helm
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
deploy-to-k8s:
|
|
||||||
#if: ${{ github.event_name == 'workflow_dispatch' || github.event_name == 'repository_dispatch' || github.event.workflow_run.conclusion == 'success' }}
|
|
||||||
if: false
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v2
|
|
||||||
|
|
||||||
- uses: azure/login@v1
|
|
||||||
with:
|
|
||||||
creds: ${{ secrets.AZURE_CREDENTIALS }}
|
|
||||||
|
|
||||||
- uses: ./.github/workflows/composite/deploy-helm
|
|
||||||
with:
|
|
||||||
azure_credentials: ${{ secrets.AZURE_CREDENTIALS }}
|
|
||||||
cluster_name: ${{ secrets.CLUSTER_NAME }}
|
|
||||||
resource_group: ${{ secrets.RESOURCE_GROUP }}
|
|
||||||
registry_host: ${{ secrets.REGISTRY_HOST }}
|
|
||||||
chart: ${{ env.CHART }}
|
|
||||||
chart_root: ${{ env.CHART_ROOT }}
|
|
||||||
namespace: ${{ env.NAMESPACE }}
|
|
53
.github/workflows/webmvc.yml
vendored
53
.github/workflows/webmvc.yml
vendored
@ -1,53 +0,0 @@
|
|||||||
name: webmvc
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
|
|
||||||
paths:
|
|
||||||
- src/BuildingBlocks/**
|
|
||||||
- src/Web/WebMVC/**
|
|
||||||
- .github/workflows/webmvc.yml
|
|
||||||
|
|
||||||
pull_request:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
paths:
|
|
||||||
|
|
||||||
- src/BuildingBlocks/**
|
|
||||||
- src/Web/WebMVC/**
|
|
||||||
- .github/workflows/webmvc.yml
|
|
||||||
|
|
||||||
env:
|
|
||||||
SERVICE: webmvc
|
|
||||||
IMAGE: webmvc
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
|
|
||||||
BuildContainersForPR_Linux:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: ${{ github.event_name == 'pull_request' }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- uses: ./.github/workflows/composite/build
|
|
||||||
with:
|
|
||||||
service: ${{ env.SERVICE }}
|
|
||||||
registry_endpoint: ${{ secrets.REGISTRY_ENDPOINT }}
|
|
||||||
|
|
||||||
BuildLinux:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: ${{ github.event_name != 'pull_request' }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- uses: ./.github/workflows/composite/build-push
|
|
||||||
with:
|
|
||||||
service: ${{ env.SERVICE }}
|
|
||||||
registry_host: ${{ secrets.REGISTRY_HOST }}
|
|
||||||
registry_endpoint: ${{ secrets.REGISTRY_ENDPOINT }}
|
|
||||||
image_name: ${{ env.IMAGE }}
|
|
||||||
registry_username: ${{ secrets.USERNAME }}
|
|
||||||
registry_password: ${{ secrets.PASSWORD }}
|
|
35
.github/workflows/webshoppingagg-deploy.yml
vendored
35
.github/workflows/webshoppingagg-deploy.yml
vendored
@ -1,35 +0,0 @@
|
|||||||
name: Deploy webshoppingagg
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
repository_dispatch:
|
|
||||||
types:
|
|
||||||
- deploy
|
|
||||||
workflow_run:
|
|
||||||
workflows: ["webshoppingagg"]
|
|
||||||
branches: [dev]
|
|
||||||
types: [completed]
|
|
||||||
|
|
||||||
env:
|
|
||||||
CHART: webshoppingagg
|
|
||||||
NAMESPACE: eshop
|
|
||||||
CHART_ROOT: deploy/k8s/helm
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
deploy-to-k8s:
|
|
||||||
#if: ${{ github.event_name == 'workflow_dispatch' || github.event_name == 'repository_dispatch' || github.event.workflow_run.conclusion == 'success' }}
|
|
||||||
if: false
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v2
|
|
||||||
|
|
||||||
- uses: ./.github/workflows/composite/deploy-helm
|
|
||||||
with:
|
|
||||||
azure_credentials: ${{ secrets.AZURE_CREDENTIALS }}
|
|
||||||
cluster_name: ${{ secrets.CLUSTER_NAME }}
|
|
||||||
resource_group: ${{ secrets.RESOURCE_GROUP }}
|
|
||||||
registry_host: ${{ secrets.REGISTRY_HOST }}
|
|
||||||
chart: ${{ env.CHART }}
|
|
||||||
chart_root: ${{ env.CHART_ROOT }}
|
|
||||||
namespace: ${{ env.NAMESPACE }}
|
|
50
.github/workflows/webshoppingagg.yml
vendored
50
.github/workflows/webshoppingagg.yml
vendored
@ -1,50 +0,0 @@
|
|||||||
name: webshoppingagg
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
|
|
||||||
paths:
|
|
||||||
- src/ApiGateways/Web.Bff.Shopping/aggregator/**
|
|
||||||
- .github/workflows/webshoppingagg.yml
|
|
||||||
|
|
||||||
pull_request:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
|
|
||||||
paths:
|
|
||||||
- src/ApiGateways/Web.Bff.Shopping/aggregator/**
|
|
||||||
- .github/workflows/webshoppingagg.yml
|
|
||||||
env:
|
|
||||||
SERVICE: webshoppingagg
|
|
||||||
IMAGE: webshoppingagg
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
|
|
||||||
BuildContainersForPR_Linux:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: ${{ github.event_name == 'pull_request' }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- uses: ./.github/workflows/composite/build
|
|
||||||
with:
|
|
||||||
service: ${{ env.SERVICE }}
|
|
||||||
registry_endpoint: ${{ secrets.REGISTRY_ENDPOINT }}
|
|
||||||
|
|
||||||
BuildLinux:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: ${{ github.event_name != 'pull_request' }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- uses: ./.github/workflows/composite/build-push
|
|
||||||
with:
|
|
||||||
service: ${{ env.SERVICE }}
|
|
||||||
registry_host: ${{ secrets.REGISTRY_HOST }}
|
|
||||||
registry_endpoint: ${{ secrets.REGISTRY_ENDPOINT }}
|
|
||||||
image_name: ${{ env.IMAGE }}
|
|
||||||
registry_username: ${{ secrets.USERNAME }}
|
|
||||||
registry_password: ${{ secrets.PASSWORD }}
|
|
35
.github/workflows/webspa-deploy.yml
vendored
35
.github/workflows/webspa-deploy.yml
vendored
@ -1,35 +0,0 @@
|
|||||||
name: Deploy webspa
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
repository_dispatch:
|
|
||||||
types:
|
|
||||||
- deploy
|
|
||||||
workflow_run:
|
|
||||||
workflows: ["webspa"]
|
|
||||||
branches: [dev]
|
|
||||||
types: [completed]
|
|
||||||
|
|
||||||
env:
|
|
||||||
CHART: webspa
|
|
||||||
NAMESPACE: eshop
|
|
||||||
CHART_ROOT: deploy/k8s/helm
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
deploy-to-k8s:
|
|
||||||
#if: ${{ github.event_name == 'workflow_dispatch' || github.event_name == 'repository_dispatch' || github.event.workflow_run.conclusion == 'success' }}
|
|
||||||
if: false
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v2
|
|
||||||
|
|
||||||
- uses: ./.github/workflows/composite/deploy-helm
|
|
||||||
with:
|
|
||||||
azure_credentials: ${{ secrets.AZURE_CREDENTIALS }}
|
|
||||||
cluster_name: ${{ secrets.CLUSTER_NAME }}
|
|
||||||
resource_group: ${{ secrets.RESOURCE_GROUP }}
|
|
||||||
registry_host: ${{ secrets.REGISTRY_HOST }}
|
|
||||||
chart: ${{ env.CHART }}
|
|
||||||
chart_root: ${{ env.CHART_ROOT }}
|
|
||||||
namespace: ${{ env.NAMESPACE }}
|
|
52
.github/workflows/webspa.yml
vendored
52
.github/workflows/webspa.yml
vendored
@ -1,52 +0,0 @@
|
|||||||
name: webspa
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
|
|
||||||
paths:
|
|
||||||
- src/BuildingBlocks/**
|
|
||||||
- src/Web/WebSPA/**
|
|
||||||
- .github/workflows/webspa.yml
|
|
||||||
|
|
||||||
pull_request:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
|
|
||||||
paths:
|
|
||||||
- src/BuildingBlocks/**
|
|
||||||
- src/Web/WebSPA/**
|
|
||||||
- .github/workflows/webspa.yml
|
|
||||||
env:
|
|
||||||
SERVICE: webspa
|
|
||||||
IMAGE: webspa
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
|
|
||||||
BuildContainersForPR_Linux:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: ${{ github.event_name == 'pull_request' }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- uses: ./.github/workflows/composite/build
|
|
||||||
with:
|
|
||||||
service: ${{ env.SERVICE }}
|
|
||||||
registry_endpoint: ${{ secrets.REGISTRY_ENDPOINT }}
|
|
||||||
|
|
||||||
BuildLinux:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: ${{ github.event_name != 'pull_request' }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- uses: ./.github/workflows/composite/build-push
|
|
||||||
with:
|
|
||||||
service: ${{ env.SERVICE }}
|
|
||||||
registry_host: ${{ secrets.REGISTRY_HOST }}
|
|
||||||
registry_endpoint: ${{ secrets.REGISTRY_ENDPOINT }}
|
|
||||||
image_name: ${{ env.IMAGE }}
|
|
||||||
registry_username: ${{ secrets.USERNAME }}
|
|
||||||
registry_password: ${{ secrets.PASSWORD }}
|
|
35
.github/workflows/webstatus-deploy.yml
vendored
35
.github/workflows/webstatus-deploy.yml
vendored
@ -1,35 +0,0 @@
|
|||||||
name: Deploy webstatus
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
repository_dispatch:
|
|
||||||
types:
|
|
||||||
- deploy
|
|
||||||
workflow_run:
|
|
||||||
workflows: ["webstatus"]
|
|
||||||
branches: [dev]
|
|
||||||
types: [completed]
|
|
||||||
|
|
||||||
env:
|
|
||||||
CHART: webstatus
|
|
||||||
NAMESPACE: eshop
|
|
||||||
CHART_ROOT: deploy/k8s/helm
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
deploy-to-k8s:
|
|
||||||
#if: ${{ github.event_name == 'workflow_dispatch' || github.event_name == 'repository_dispatch' || github.event.workflow_run.conclusion == 'success' }}
|
|
||||||
if: false
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v2
|
|
||||||
|
|
||||||
- uses: ./.github/workflows/composite/deploy-helm
|
|
||||||
with:
|
|
||||||
azure_credentials: ${{ secrets.AZURE_CREDENTIALS }}
|
|
||||||
cluster_name: ${{ secrets.CLUSTER_NAME }}
|
|
||||||
resource_group: ${{ secrets.RESOURCE_GROUP }}
|
|
||||||
registry_host: ${{ secrets.REGISTRY_HOST }}
|
|
||||||
chart: ${{ env.CHART }}
|
|
||||||
chart_root: ${{ env.CHART_ROOT }}
|
|
||||||
namespace: ${{ env.NAMESPACE }}
|
|
53
.github/workflows/webstatus.yml
vendored
53
.github/workflows/webstatus.yml
vendored
@ -1,53 +0,0 @@
|
|||||||
name: webstatus
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
|
|
||||||
paths:
|
|
||||||
- src/BuildingBlocks/**
|
|
||||||
- src/Web/WebStatus/**
|
|
||||||
- .github/workflows/webstatus.yml
|
|
||||||
|
|
||||||
pull_request:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
|
|
||||||
paths:
|
|
||||||
- src/BuildingBlocks/**
|
|
||||||
- src/Web/WebStatus/**
|
|
||||||
- .github/workflows/webstatus.yml
|
|
||||||
|
|
||||||
env:
|
|
||||||
SERVICE: webstatus
|
|
||||||
IMAGE: webstatus
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
|
|
||||||
BuildContainersForPR_Linux:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: ${{ github.event_name == 'pull_request' }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- uses: ./.github/workflows/composite/build
|
|
||||||
with:
|
|
||||||
service: ${{ env.SERVICE }}
|
|
||||||
registry_endpoint: ${{ secrets.REGISTRY_ENDPOINT }}
|
|
||||||
|
|
||||||
BuildLinux:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: ${{ github.event_name != 'pull_request' }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- uses: ./.github/workflows/composite/build-push
|
|
||||||
with:
|
|
||||||
service: ${{ env.SERVICE }}
|
|
||||||
registry_host: ${{ secrets.REGISTRY_HOST }}
|
|
||||||
registry_endpoint: ${{ secrets.REGISTRY_ENDPOINT }}
|
|
||||||
image_name: ${{ env.IMAGE }}
|
|
||||||
registry_username: ${{ secrets.USERNAME }}
|
|
||||||
registry_password: ${{ secrets.PASSWORD }}
|
|
6
.gitignore
vendored
6
.gitignore
vendored
@ -1,10 +1,6 @@
|
|||||||
## Ignore Visual Studio temporary files, build results, and
|
## Ignore Visual Studio temporary files, build results, and
|
||||||
## files generated by popular Visual Studio add-ons.
|
## files generated by popular Visual Studio add-ons.
|
||||||
|
|
||||||
## Local history files
|
|
||||||
.history/
|
|
||||||
.vshistory/
|
|
||||||
|
|
||||||
# User-specific files
|
# User-specific files
|
||||||
*.suo
|
*.suo
|
||||||
*.user
|
*.user
|
||||||
@ -281,5 +277,3 @@ pub/
|
|||||||
src/**/app.yaml
|
src/**/app.yaml
|
||||||
src/**/inf.yaml
|
src/**/inf.yaml
|
||||||
|
|
||||||
.angular/
|
|
||||||
/src/Services/Identity/Identity.API/keys/*.json
|
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
This repo is a reference and learning resource and everyone is invited to contribute, however not all PRs will be accepted into the main branch (**`dev`**).
|
This repo is a reference and learning resource and everyone is invited to contribute, however not all PRs will be accepted into the main branch (**`dev`**).
|
||||||
|
|
||||||
There's a general development strategy that's driven by @CESARDELATORRE/@nishanil, who chooses, or defines criteria for choosing, the issues to include in the codebase, given a bunch of constraints and other guidelines.
|
There's a general development strategy that's driven by @CESARDELATORRE, who chooses, or defines criteria for choosing, the issues to include in the codebase, given a bunch of constraints and other guidelines.
|
||||||
|
|
||||||
However you can always get in touch with him, if you want to implement some general-interest feature in your repo and have it referenced from the [documentation](https://docs.microsoft.com/dotnet/standard/microservices-architecture/) or the [Microservices eBook](https://aka.ms/microservicesebook/).
|
However you can always get in touch with him, if you want to implement some general-interest feature in your repo and have it referenced from the [documentation](https://docs.microsoft.com/dotnet/standard/microservices-architecture/) or the [Microservices eBook](https://aka.ms/microservicesebook/).
|
||||||
|
|
||||||
@ -47,14 +47,15 @@ All contributions must be submitted as a [Pull Request (PR)](https://help.github
|
|||||||
The main branches are **`dev`** and **`master`**:
|
The main branches are **`dev`** and **`master`**:
|
||||||
|
|
||||||
- **`dev`**: Contains the latest code **and it is the branch actively developed**.
|
- **`dev`**: Contains the latest code **and it is the branch actively developed**.
|
||||||
**All PRs must be against `dev` branch to be considered**. This branch is developed using `.NET 7`
|
**All PRs must be against `dev` branch to be considered**. This branch is developed using .NET Core 2.x
|
||||||
|
|
||||||
- **`main`**: Synced from time to time from **`dev`**. It contains "stable" code.This branch contains changes specific to `.NET Core 3.1` (**Keep in mind "stable" does not mean PRODUCTION-READY!**)
|
- **`master`**: Synced from time to time from **`dev`**. It contains "stable" code.
|
||||||
|
(**Keep in mind "stable" does not mean PRODUCTION-READY!**)
|
||||||
|
|
||||||
- Any other branch is considered temporary and could be deleted at any time. Do not submit any PR to them!
|
- Any other branch is considered temporary and could be deleted at any time. Do not submit any PR to them!
|
||||||
|
|
||||||
## DISCLAIMER - This is not a PRODUCTION-READY TEMPLATE for microservices
|
## DISCLAIMER - This is not a PRODUCTION-READY TEMPLATE for microservices
|
||||||
eShopOnContainers is a reference application to **showcase architectural patterns** for developing microservices applications on .NET 5. **IT IS NOT A PRODUCTION-READY TEMPLATE** to start real-world application. In fact, the application is in a **permanent beta state**, as it’s also used to test new potentially interesting technologies as they show up.
|
eShopOnContainers is a reference application to **showcase architectural patterns** for developing microservices applications on .NET Core. **IT IS NOT A PRODUCTION-READY TEMPLATE** to start real-world application. In fact, the application is in a **permanent beta state**, as it’s also used to test new potentially interesting technologies as they show up.
|
||||||
|
|
||||||
Since this is a learning resource, some design decisions have favored simplicity to convey a pattern, over production-grade robustness.
|
Since this is a learning resource, some design decisions have favored simplicity to convey a pattern, over production-grade robustness.
|
||||||
|
|
||||||
|
67
README.md
67
README.md
@ -6,75 +6,60 @@
|
|||||||
|
|
||||||
Sample .NET Core reference application, powered by Microsoft, based on a simplified microservices architecture and Docker containers.
|
Sample .NET Core reference application, powered by Microsoft, based on a simplified microservices architecture and Docker containers.
|
||||||
|
|
||||||
## SPA Application (Angular)
|

|
||||||
|
|
||||||

|
## Azure DevOps - Build Status
|
||||||
|
|
||||||
## Build Status (GitHub Actions)
|
|
||||||
|
|
||||||
| Image | Status | Image | Status |
|
| Image | Status | Image | Status |
|
||||||
| ------------- | ------------- | ------------- | ------------- |
|
| ------------- | ------------- | ------------- | ------------- |
|
||||||
| Web Status | [](https://github.com/dotnet-architecture/eShopOnContainers/actions?query=workflow%3Awebstatus) | Shopping Aggregator (Web) | [](https://github.com/dotnet-architecture/eShopOnContainers/actions?query=workflow%3Awebshoppingagg) |
|
| Api Gateway (base) | [](https://msftdevtools.visualstudio.com/eShopOnContainers/_build/latest?definitionId=201&branchName=dev) | Shopping Aggregator (Web) | [](https://msftdevtools.visualstudio.com/eShopOnContainers/_build/latest?definitionId=206&branchName=dev) |
|
||||||
| Basket API | [](https://github.com/dotnet-architecture/eShopOnContainers/actions?query=workflow%3Abasket-api) | Shopping Aggregator (Mobile) | [](https://github.com/dotnet-architecture/eShopOnContainers/actions?query=workflow%3Amobileshoppingagg) |
|
| Basket API | [](https://msftdevtools.visualstudio.com/eShopOnContainers/_build/latest?definitionId=199&branchName=dev) | Shopping Aggregator (Mobile) | [](https://msftdevtools.visualstudio.com/eShopOnContainers/_build/latest?definitionId=204&branchName=dev) |
|
||||||
| Catalog API | [](https://github.com/dotnet-architecture/eShopOnContainers/actions?query=workflow%3Acatalog-api) | Web Client (MVC) | [](https://github.com/dotnet-architecture/eShopOnContainers/actions?query=workflow%3Awebmvc) |
|
| Catalog API | [](https://msftdevtools.visualstudio.com/eShopOnContainers/_build/latest?definitionId=197&branchName=dev) | Web Client (MVC) | [](https://msftdevtools.visualstudio.com/eShopOnContainers/_build/latest?definitionId=209&branchName=dev) |
|
||||||
|Identity API | [](https://github.com/dotnet-architecture/eShopOnContainers/actions?query=workflow%3Aidentity-api) | Web Client (SPA) | [](https://github.com/dotnet-architecture/eShopOnContainers/actions?query=workflow%3Awebspa) |
|
|Identity API | [](https://msftdevtools.visualstudio.com/eShopOnContainers/_build/latest?definitionId=200&branchName=dev) | Web Client (SPA) | [](https://msftdevtools.visualstudio.com/eShopOnContainers/_build/latest?definitionId=210&branchName=dev) |
|
||||||
| Ordering API | [](https://github.com/dotnet-architecture/eShopOnContainers/actions?query=workflow%3Aordering-api) | Webhooks Client | [](https://github.com/dotnet-architecture/eShopOnContainers/actions?query=workflow%3Awebhooks-client) |
|
| Location API | [](https://msftdevtools.visualstudio.com/eShopOnContainers/_build/latest?definitionId=202&branchName=dev) | Web Status (Health) | [](https://msftdevtools.visualstudio.com/eShopOnContainers/_build/latest?definitionId=211&branchName=dev) |
|
||||||
| Payment API | [](https://github.com/dotnet-architecture/eShopOnContainers/actions?query=workflow%3Apayment-api) | Ordering SignalR | [](https://github.com/dotnet-architecture/eShopOnContainers/actions?query=workflow%3Aordering-signalrhub) | |
|
| Marketing API | [](https://msftdevtools.visualstudio.com/eShopOnContainers/_build/latest?definitionId=203&branchName=dev) | Webhooks API | [](https://msftdevtools.visualstudio.com/eShopOnContainers/_build/latest?definitionId=207&branchName=dev) |
|
||||||
|
| Ordering API | [](https://msftdevtools.visualstudio.com/eShopOnContainers/_build/latest?definitionId=198&branchName=dev) | Webhooks Client | [](https://msftdevtools.visualstudio.com/eShopOnContainers/_build/latest?definitionId=208&branchName=dev) |
|
||||||
|
| Payment API | [](https://msftdevtools.visualstudio.com/eShopOnContainers/_build/latest?definitionId=205&branchName=dev) | | |
|
||||||
|
|
||||||
_**Dev** branch contains the latest **beta** code and their images are tagged with `:linux-dev` in our [Docker Hub](https://hub.docker.com/u/eshop)_
|
_**Dev** branch contains the latest **beta** code and their images are tagged with `:linux-dev` in our [Docker Hub](https://hub.docker.com/u/eshop)_
|
||||||
|
|
||||||
|
## Are you new to **microservices** and **cloud-native development**?
|
||||||
|
Take a look at the free course [Create and deploy a cloud-native ASP.NET Core microservice](https://docs.microsoft.com/en-us/learn/modules/microservices-aspnet-core/) on MS Learn. This module explains microservices concepts, cloud-native technologies, and reduce the friction in getting started with `eShopOnContainers`.
|
||||||
|
|
||||||
## Getting Started
|
## Getting Started
|
||||||
|
|
||||||
Make sure you have [installed](https://docs.docker.com/docker-for-windows/install/) and [configured](https://github.com/dotnet-architecture/eShopOnContainers/wiki/Windows-setup#configure-docker) docker in your environment. After that, you can run the below commands from the **/src/** directory and get started with the `eShopOnContainers` immediately.
|
*eShopOnContainers* is provided in two flavors: Basic and Advanced.
|
||||||
|
|
||||||
```powershell
|
|
||||||
docker-compose build
|
|
||||||
docker-compose up
|
|
||||||
```
|
|
||||||
|
|
||||||
You should be able to browse different components of the application by using the below URLs :
|
|
||||||
|
|
||||||
```
|
|
||||||
Web Status : http://host.docker.internal:5107/
|
|
||||||
Web MVC : http://host.docker.internal:5100/
|
|
||||||
Web SPA : http://host.docker.internal:5104/
|
|
||||||
```
|
|
||||||
|
|
||||||
>Note: If you are running this application in macOS then use `docker.for.mac.localhost` as DNS name in `.env` file and the above URLs instead of `host.docker.internal`.
|
|
||||||
|
|
||||||
Below are the other avenues to setup *eShopOnContainers*.
|
|
||||||
|
|
||||||
### Basic scenario
|
### Basic scenario
|
||||||
|
|
||||||
The basic scenario can be run locally using docker-compose, and also deployed to a local Kubernetes cluster. Refer to these Wiki pages to Get Started:
|
The basic scenario can be run locally using docker-compose, and also deployed to a local Kubernetes cluster. Refer to these Wiki pages to Get Started:
|
||||||
|
|
||||||
|
- [CLI or Visual Studio Code](https://github.com/dotnet-architecture/eShopOnContainers/wiki/Windows-setup)
|
||||||
- [Visual Studio (F5 experience)](https://github.com/dotnet-architecture/eShopOnContainers/wiki/Windows-setup#optional---use-visual-studio)
|
- [Visual Studio (F5 experience)](https://github.com/dotnet-architecture/eShopOnContainers/wiki/Windows-setup#optional---use-visual-studio)
|
||||||
- [Docker compose on windows](https://github.com/dotnet-architecture/eShopOnContainers/wiki/Windows-setup)
|
- [Docker compose](https://github.com/dotnet-architecture/eShopOnContainers/wiki/Docker-compose-deployment-files)
|
||||||
- [Docker compose on macOS](https://github.com/dotnet-architecture/eShopOnContainers/wiki/Mac-setup)
|
|
||||||
- [Local Kubernetes](https://github.com/dotnet-architecture/eShopOnContainers/wiki/Deploy-to-Local-Kubernetes)
|
- [Local Kubernetes](https://github.com/dotnet-architecture/eShopOnContainers/wiki/Deploy-to-Local-Kubernetes)
|
||||||
|
|
||||||
### Advanced scenario
|
### Advanced scenario
|
||||||
|
|
||||||
The Advanced scenario can be run only in a Kubernetes cluster. Currently, this scenario is the same as a basic scenario with the following differences:
|
The Advanced scenario can be run only in a Kubernetes cluster. Currently this scenario is the same as basic scenario with the following differences:
|
||||||
|
|
||||||
- [Deploy to AKS with a Service Mesh for resiliency](https://github.com/dotnet-architecture/eShopOnContainers/wiki/Deploy-to-Azure-Kubernetes-Service-(AKS))
|
- [Deploy to AKS with a Service Mesh for resiliency](https://github.com/dotnet-architecture/eShopOnContainers/wiki/Deploy-to-Azure-Kubernetes-Service-(AKS))
|
||||||
|
|
||||||
In the future, more features will be implemented in the advanced scenario.
|
In the future more features will be implemented in the advanced scenario.
|
||||||
|
|
||||||
|
|
||||||
## IMPORTANT NOTES!
|
## IMPORTANT NOTES!
|
||||||
|
|
||||||
**You can use either the latest version of Visual Studio or simply Docker CLI and .NET CLI for Windows, Mac, and Linux**.
|
**You can use either the latest version of Visual Studio or simply Docker CLI and .NET CLI for Windows, Mac and Linux**.
|
||||||
|
|
||||||
**Note for Pull Requests (PRs)**: We accept pull requests from the community. When doing it, please do it onto the **DEV branch** which is the consolidated work-in-progress branch. Do not request it onto **main** branch.
|
**Note for Pull Requests (PRs)**: We accept pull request from the community. When doing it, please do it onto the **DEV branch** which is the consolidated work-in-progress branch. Do not request it onto **master** branch.
|
||||||
|
|
||||||
**NEWS / ANNOUNCEMENTS**
|
**NEWS / ANNOUNCEMENTS**
|
||||||
Do you want to be up-to-date on .NET Architecture guidance and reference apps like eShopOnContainers? --> Subscribe by "WATCHING" this new GitHub repo: https://github.com/dotnet-architecture/News
|
Do you want to be up-to-date on .NET Architecture guidance and reference apps like eShopOnContainers? --> Subscribe by "WATCHING" this new GitHub repo: https://github.com/dotnet-architecture/News
|
||||||
|
|
||||||
## Updated for .NET 7
|
## Updated for .NET Core 3.1 (LTS)
|
||||||
|
|
||||||
eShopOnContainers is updated to .NET 7 "wave" of technologies. Not just compilation but also new recommended code in EF Core, ASP.NET Core, and other new related versions with several significant changes.
|
eShopOnContainers is updated to .NET Core 3.1 "wave" of technologies. Not just compilation but also new recommended code in EF Core, ASP.NET Core, and other new related versions with several significant changes.
|
||||||
|
|
||||||
**See more details in the [Release notes](https://github.com/dotnet-architecture/eShopOnContainers/wiki/Release-notes) wiki page**.
|
**See more details in the [Release notes](https://github.com/dotnet-architecture/eShopOnContainers/wiki/Release-notes) wiki page**.
|
||||||
|
|
||||||
@ -86,15 +71,15 @@ eShopOnContainers is updated to .NET 7 "wave" of technologies. Not just compilat
|
|||||||
|
|
||||||
### Architecture overview
|
### Architecture overview
|
||||||
|
|
||||||
This reference application is cross-platform at the server and client-side, thanks to .NET 7 services capable of running on Linux or Windows containers depending on your Docker host, and to Xamarin for mobile apps running on Android, iOS, or Windows/UWP plus any browser for the client web apps.
|
This reference application is cross-platform at the server and client side, thanks to .NET Core services capable of running on Linux or Windows containers depending on your Docker host, and to Xamarin for mobile apps running on Android, iOS or Windows/UWP plus any browser for the client web apps.
|
||||||
The architecture proposes a microservice oriented architecture implementation with multiple autonomous microservices (each one owning its own data/db) and implementing different approaches within each microservice (simple CRUD vs. DDD/CQRS patterns) using HTTP as the communication protocol between the client apps and the microservices and supports asynchronous communication for data updates propagation across multiple services based on Integration Events and an Event Bus (a light message broker, to choose between RabbitMQ or Azure Service Bus, underneath) plus other features defined at the [roadmap](https://github.com/dotnet-architecture/eShopOnContainers/wiki/Roadmap).
|
The architecture proposes a microservice oriented architecture implementation with multiple autonomous microservices (each one owning its own data/db) and implementing different approaches within each microservice (simple CRUD vs. DDD/CQRS patterns) using Http as the communication protocol between the client apps and the microservices and supports asynchronous communication for data updates propagation across multiple services based on Integration Events and an Event Bus (a light message broker, to choose between RabbitMQ or Azure Service Bus, underneath) plus other features defined at the [roadmap](https://github.com/dotnet-architecture/eShopOnContainers/wiki/Roadmap).
|
||||||
|
|
||||||

|

|
||||||

|

|
||||||
|
|
||||||
## Related documentation and guidance
|
## Related documentation and guidance
|
||||||
|
|
||||||
You can find the related reference **Guide/eBook** focusing on **architecting and developing containerized and microservice-based .NET Applications** (download link available below) which explains in detail how to develop this kind of architectural style (microservices, Docker containers, Domain-Driven Design for certain microservices) plus other simpler architectural styles, like monolithic apps that can also live as Docker containers.
|
You can find the related reference **Guide/eBook** focusing on **architecting and developing containerized and microservice based .NET Applications** (download link available below) which explains in detail how to develop this kind of architectural style (microservices, Docker containers, Domain-Driven Design for certain microservices) plus other simpler architectural styles, like monolithic apps that can also live as Docker containers.
|
||||||
|
|
||||||
There are also additional eBooks focusing on Containers/Docker lifecycle (DevOps, CI/CD, etc.) with Microsoft Tools, already published plus an additional eBook focusing on Enterprise Apps Patterns with Xamarin.Forms.
|
There are also additional eBooks focusing on Containers/Docker lifecycle (DevOps, CI/CD, etc.) with Microsoft Tools, already published plus an additional eBook focusing on Enterprise Apps Patterns with Xamarin.Forms.
|
||||||
You can download them and start reviewing these Guides/eBooks here:
|
You can download them and start reviewing these Guides/eBooks here:
|
||||||
@ -106,8 +91,6 @@ You can download them and start reviewing these Guides/eBooks here:
|
|||||||
|
|
||||||
For more free e-Books check out [.NET Architecture center](https://dot.net/architecture). If you have an e-book feedback, let us know by creating a new issue here: <https://github.com/dotnet-architecture/ebooks/issues>
|
For more free e-Books check out [.NET Architecture center](https://dot.net/architecture). If you have an e-book feedback, let us know by creating a new issue here: <https://github.com/dotnet-architecture/ebooks/issues>
|
||||||
|
|
||||||
## Are you new to **microservices** and **cloud-native development**?
|
|
||||||
Take a look at the free course [Create and deploy a cloud-native ASP.NET Core microservice](https://docs.microsoft.com/en-us/learn/modules/microservices-aspnet-core/) on MS Learn. This module explains microservices concepts, cloud-native technologies, and reduces the friction in getting started with `eShopOnContainers`.
|
|
||||||
|
|
||||||
## Read further
|
## Read further
|
||||||
|
|
||||||
|
@ -2,13 +2,9 @@
|
|||||||
|
|
||||||
Following are the most important branches:
|
Following are the most important branches:
|
||||||
|
|
||||||
- `dev`: Contains the latest code **and it is the branch actively developed**. Note that **all PRs must be against the `dev` branch to be considered**. This branch is developed using `.NET 7`
|
- `dev`: Contains the latest code **and it is the branch actively developed**. Note that **all PRs must be against `dev` branch to be considered**. This branch is developed using .NET Core 2.0
|
||||||
- `release/net-6`: Contains the code changes specific to the `.NET 6`
|
- `master`: Synced time to time from dev. It contains "stable" code, although not the latest one. We plan to do periodic merges from `dev` to `master`, but we are not doing it right now.
|
||||||
- `release/net-5`: Contains the code changes specific to the `.NET 5`
|
|
||||||
- `release/net-3.1.1`: Contains the code changes specific to the `.NET 3.1`
|
|
||||||
|
|
||||||
> [!DISCLAIMER]: The `main` branch contains the old code base and will get obsolete in the future. So it's recommended to refer to different [tags](https://github.com/dotnet-architecture/eShopOnContainers/tags) to avoid any confusion.
|
Any other branch is considered temporary and could be deleted at any time. Do not do any PR to them!
|
||||||
|
|
||||||
Any other branch is considered temporary and could be deleted at any time. Do not submit any PR against them!
|
|
||||||
|
|
||||||
Thanks!
|
Thanks!
|
||||||
|
@ -14,10 +14,12 @@ $services = @(
|
|||||||
@{ Name="eshopidentity"; Image="eshop/identity.api"; File="src/Services/Identity/Identity.API/Dockerfile" },
|
@{ Name="eshopidentity"; Image="eshop/identity.api"; File="src/Services/Identity/Identity.API/Dockerfile" },
|
||||||
@{ Name="eshopordering"; Image="eshop/ordering.api"; File="src/Services/Ordering/Ordering.API/Dockerfile" },
|
@{ Name="eshopordering"; Image="eshop/ordering.api"; File="src/Services/Ordering/Ordering.API/Dockerfile" },
|
||||||
@{ Name="eshoporderingbg"; Image="eshop/ordering.backgroundtasks"; File="src/Services/Ordering/Ordering.BackgroundTasks/Dockerfile" },
|
@{ Name="eshoporderingbg"; Image="eshop/ordering.backgroundtasks"; File="src/Services/Ordering/Ordering.BackgroundTasks/Dockerfile" },
|
||||||
|
@{ Name="eshopmarketing"; Image="eshop/marketing.api"; File="src/Services/Marketing/Marketing.API/Dockerfile" },
|
||||||
@{ Name="eshopwebspa"; Image="eshop/webspa"; File="src/Web/WebSPA/Dockerfile" },
|
@{ Name="eshopwebspa"; Image="eshop/webspa"; File="src/Web/WebSPA/Dockerfile" },
|
||||||
@{ Name="eshopwebmvc"; Image="eshop/webmvc"; File="src/Web/WebMVC/Dockerfile" },
|
@{ Name="eshopwebmvc"; Image="eshop/webmvc"; File="src/Web/WebMVC/Dockerfile" },
|
||||||
@{ Name="eshopwebstatus"; Image="eshop/webstatus"; File="src/Web/WebStatus/Dockerfile" },
|
@{ Name="eshopwebstatus"; Image="eshop/webstatus"; File="src/Web/WebStatus/Dockerfile" },
|
||||||
@{ Name="eshoppayment"; Image="eshop/payment.api"; File="src/Services/Payment/Payment.API/Dockerfile" },
|
@{ Name="eshoppayment"; Image="eshop/payment.api"; File="src/Services/Payment/Payment.API/Dockerfile" },
|
||||||
|
@{ Name="eshoplocations"; Image="eshop/locations.api"; File="src/Services/Location/Locations.API/Dockerfile" },
|
||||||
@{ Name="eshopocelotapigw"; Image="eshop/ocelotapigw"; File="src/ApiGateways/ApiGw-Base/Dockerfile" },
|
@{ Name="eshopocelotapigw"; Image="eshop/ocelotapigw"; File="src/ApiGateways/ApiGw-Base/Dockerfile" },
|
||||||
@{ Name="eshopmobileshoppingagg"; Image="eshop/mobileshoppingagg"; File="src/ApiGateways/Mobile.Bff.Shopping/aggregator/Dockerfile" },
|
@{ Name="eshopmobileshoppingagg"; Image="eshop/mobileshoppingagg"; File="src/ApiGateways/Mobile.Bff.Shopping/aggregator/Dockerfile" },
|
||||||
@{ Name="eshopwebshoppingagg"; Image="eshop/webshoppingagg"; File="src/ApiGateways/Web.Bff.Shopping/aggregator/Dockerfile" },
|
@{ Name="eshopwebshoppingagg"; Image="eshop/webshoppingagg"; File="src/ApiGateways/Web.Bff.Shopping/aggregator/Dockerfile" },
|
||||||
@ -31,3 +33,5 @@ $services |% {
|
|||||||
Write-Host "Setting ACR build $bname ($bimg)"
|
Write-Host "Setting ACR build $bname ($bimg)"
|
||||||
az acr build-task create --registry $acrName --name $bname --image ${bimg}:$gitBranch --context $gitContext --branch $gitBranch --git-access-token $patToken --file $bfile
|
az acr build-task create --registry $acrName --name $bname --image ${bimg}:$gitBranch --context $gitContext --branch $gitBranch --git-access-token $patToken --file $bfile
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Basket.API
|
||||||
|
32
build/azure-devops/apigws/azure-pipelines.yml
Normal file
32
build/azure-devops/apigws/azure-pipelines.yml
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
trigger:
|
||||||
|
branches:
|
||||||
|
include:
|
||||||
|
- master
|
||||||
|
- dev
|
||||||
|
paths:
|
||||||
|
include:
|
||||||
|
- src/ApiGateways/*
|
||||||
|
- build/azure-devops/buildimages.yml
|
||||||
|
- build/azure-devops/multiarch.yml
|
||||||
|
- build/azure-devops/apigws/*
|
||||||
|
- deploy/k8s/helm/apigwmm/*
|
||||||
|
- deploy/k8s/helm/apigwms/*
|
||||||
|
- deploy/k8s/helm/apigwwm/*
|
||||||
|
- deploy/k8s/helm/apigwws/*
|
||||||
|
exclude:
|
||||||
|
- src/ApiGateways/Mobile.Bff.Shopping/aggregator/*
|
||||||
|
- src/ApiGateways/Web.Bff.Shopping/aggregator/*
|
||||||
|
jobs:
|
||||||
|
- job: PublishCharts
|
||||||
|
condition: ne('$(Build.Reason)', 'PullRequest')
|
||||||
|
pool:
|
||||||
|
vmImage: 'ubuntu-16.04'
|
||||||
|
steps:
|
||||||
|
- task: CopyFiles@2
|
||||||
|
inputs:
|
||||||
|
sourceFolder: $(Build.SourcesDirectory)/deploy/k8s/helm
|
||||||
|
targetFolder: $(Build.ArtifactStagingDirectory)/deploy/k8s/helm
|
||||||
|
- task: PublishBuildArtifacts@1
|
||||||
|
inputs:
|
||||||
|
pathtoPublish: $(Build.ArtifactStagingDirectory)/deploy/k8s/helm
|
||||||
|
artifactName: helm
|
27
build/azure-devops/basket-api/azure-pipelines.yml
Normal file
27
build/azure-devops/basket-api/azure-pipelines.yml
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
variables:
|
||||||
|
registryEndpoint: eshop-registry
|
||||||
|
trigger:
|
||||||
|
branches:
|
||||||
|
include:
|
||||||
|
- master
|
||||||
|
- dev
|
||||||
|
paths:
|
||||||
|
include:
|
||||||
|
- src/BuildingBlocks/*
|
||||||
|
- src/Services/Basket/*
|
||||||
|
- build/azure-devops/buildimages.yml
|
||||||
|
- build/azure-devops/multiarch.yml
|
||||||
|
- build/azure-devops/basket-api/*
|
||||||
|
- deploy/k8s/helm/basket-api/*
|
||||||
|
jobs:
|
||||||
|
- template: ../buildimages.yaml
|
||||||
|
parameters:
|
||||||
|
services: basket-api
|
||||||
|
registryEndpoint: $(registryEndpoint)
|
||||||
|
helmfrom: $(Build.SourcesDirectory)/deploy/k8s/helm
|
||||||
|
helmto: $(Build.ArtifactStagingDirectory)/deploy/k8s/helm
|
||||||
|
- template: ../multiarch.yaml
|
||||||
|
parameters:
|
||||||
|
image: basket.api
|
||||||
|
branch: $(Build.SourceBranchName)
|
||||||
|
registryEndpoint: $(registryEndpoint)
|
94
build/azure-devops/buildimages.yaml
Normal file
94
build/azure-devops/buildimages.yaml
Normal file
@ -0,0 +1,94 @@
|
|||||||
|
parameters:
|
||||||
|
services: ''
|
||||||
|
registryEndpoint: ''
|
||||||
|
helmfrom: ''
|
||||||
|
helmto: ''
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
- job: BuildContainersForPR_Linux
|
||||||
|
condition: eq('${{ variables['Build.Reason'] }}', 'PullRequest')
|
||||||
|
pool:
|
||||||
|
vmImage: 'ubuntu-16.04'
|
||||||
|
steps:
|
||||||
|
- bash: docker-compose -f src/docker-compose.yml build ${{ parameters.services }}
|
||||||
|
displayName: Compose build ${{ parameters.services }}
|
||||||
|
env:
|
||||||
|
TAG: ${{ variables['Build.SourceBranchName'] }}
|
||||||
|
- job: BuildContainersForPR_Windows
|
||||||
|
condition: False
|
||||||
|
# condition: eq('${{ variables['Build.Reason'] }}', 'PullRequest')
|
||||||
|
pool:
|
||||||
|
vmImage: 'windows-2019'
|
||||||
|
steps:
|
||||||
|
- bash: docker-compose f src/docker-compose.yml build ${{ parameters.services }}
|
||||||
|
displayName: Compose build ${{ parameters.services }}
|
||||||
|
env:
|
||||||
|
TAG: ${{ variables['Build.SourceBranchName'] }}
|
||||||
|
PLATFORM: win
|
||||||
|
NODE_IMAGE: stefanscherer/node-windows:10
|
||||||
|
- job: BuildLinux
|
||||||
|
condition: ne('${{ variables['Build.Reason'] }}', 'PullRequest')
|
||||||
|
pool:
|
||||||
|
vmImage: 'ubuntu-16.04'
|
||||||
|
steps:
|
||||||
|
- task: DockerCompose@0
|
||||||
|
displayName: Compose build ${{ parameters.services }}
|
||||||
|
inputs:
|
||||||
|
dockerComposeCommand: 'build ${{ parameters.services }}'
|
||||||
|
containerregistrytype: Container Registry
|
||||||
|
dockerRegistryEndpoint: ${{ parameters.registryEndpoint }}
|
||||||
|
dockerComposeFile: src/docker-compose.yml
|
||||||
|
qualifyImageNames: true
|
||||||
|
projectName: ""
|
||||||
|
dockerComposeFileArgs: |
|
||||||
|
TAG=${{ variables['Build.SourceBranchName'] }}
|
||||||
|
- task: DockerCompose@0
|
||||||
|
displayName: Compose push ${{ parameters.images }}
|
||||||
|
inputs:
|
||||||
|
dockerComposeCommand: 'push ${{ parameters.services }}'
|
||||||
|
containerregistrytype: Container Registry
|
||||||
|
dockerRegistryEndpoint: ${{ parameters.registryEndpoint }}
|
||||||
|
dockerComposeFile: src/docker-compose.yml
|
||||||
|
qualifyImageNames: true
|
||||||
|
projectName: ""
|
||||||
|
dockerComposeFileArgs: |
|
||||||
|
TAG=${{ variables['Build.SourceBranchName'] }}
|
||||||
|
- task: CopyFiles@2
|
||||||
|
inputs:
|
||||||
|
sourceFolder: ${{ parameters.helmfrom }}
|
||||||
|
targetFolder: ${{ parameters.helmto }}
|
||||||
|
- task: PublishBuildArtifacts@1
|
||||||
|
inputs:
|
||||||
|
pathtoPublish: ${{ parameters.helmto }}
|
||||||
|
artifactName: helm
|
||||||
|
- job: BuildWindows
|
||||||
|
condition: False
|
||||||
|
# condition: ne('${{ variables['Build.Reason'] }}', 'PullRequest')
|
||||||
|
pool:
|
||||||
|
vmImage: 'windows-2019'
|
||||||
|
steps:
|
||||||
|
- task: DockerCompose@0
|
||||||
|
displayName: Compose build ${{ parameters.services }}
|
||||||
|
inputs:
|
||||||
|
dockerComposeCommand: 'build ${{ parameters.services }}'
|
||||||
|
containerregistrytype: Container Registry
|
||||||
|
dockerRegistryEndpoint: ${{ parameters.registryEndpoint }}
|
||||||
|
dockerComposeFile: src/docker-compose.yml
|
||||||
|
qualifyImageNames: true
|
||||||
|
projectName: ""
|
||||||
|
dockerComposeFileArgs: |
|
||||||
|
TAG=${{ variables['Build.SourceBranchName'] }}
|
||||||
|
PLATFORM=win
|
||||||
|
NODE_IMAGE=stefanscherer/node-windows:10
|
||||||
|
- task: DockerCompose@0
|
||||||
|
displayName: Compose push ${{ parameters.services }}
|
||||||
|
inputs:
|
||||||
|
dockerComposeCommand: 'push ${{ parameters.services }}'
|
||||||
|
containerregistrytype: Container Registry
|
||||||
|
dockerRegistryEndpoint: ${{ parameters.registryEndpoint }}
|
||||||
|
dockerComposeFile: src/docker-compose.yml
|
||||||
|
qualifyImageNames: true
|
||||||
|
projectName: ""
|
||||||
|
dockerComposeFileArgs: |
|
||||||
|
TAG=${{ variables['Build.SourceBranchName'] }}
|
||||||
|
PLATFORM=win
|
27
build/azure-devops/catalog-api/azure-pipelines.yml
Normal file
27
build/azure-devops/catalog-api/azure-pipelines.yml
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
variables:
|
||||||
|
registryEndpoint: eshop-registry
|
||||||
|
trigger:
|
||||||
|
branches:
|
||||||
|
include:
|
||||||
|
- master
|
||||||
|
- dev
|
||||||
|
paths:
|
||||||
|
include:
|
||||||
|
- src/BuildingBlocks/*
|
||||||
|
- src/Services/Catalog/*
|
||||||
|
- build/azure-devops/buildimages.yml
|
||||||
|
- build/azure-devops/multiarch.yml
|
||||||
|
- build/azure-devops/catalog-api/*
|
||||||
|
- deploy/k8s/helm/catalog-api/*
|
||||||
|
jobs:
|
||||||
|
- template: ../buildimages.yaml
|
||||||
|
parameters:
|
||||||
|
services: catalog-api
|
||||||
|
registryEndpoint: $(registryEndpoint)
|
||||||
|
helmfrom: $(Build.SourcesDirectory)/deploy/k8s/helm
|
||||||
|
helmto: $(Build.ArtifactStagingDirectory)/deploy/k8s/helm
|
||||||
|
- template: ../multiarch.yaml
|
||||||
|
parameters:
|
||||||
|
image: catalog.api
|
||||||
|
branch: $(Build.SourceBranchName)
|
||||||
|
registryEndpoint: $(registryEndpoint)
|
27
build/azure-devops/identity-api/azure-pipelines.yml
Normal file
27
build/azure-devops/identity-api/azure-pipelines.yml
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
variables:
|
||||||
|
registryEndpoint: eshop-registry
|
||||||
|
trigger:
|
||||||
|
branches:
|
||||||
|
include:
|
||||||
|
- master
|
||||||
|
- dev
|
||||||
|
paths:
|
||||||
|
include:
|
||||||
|
- src/BuildingBlocks/*
|
||||||
|
- src/Services/Identity/*
|
||||||
|
- build/azure-devops/buildimages.yml
|
||||||
|
- build/azure-devops/multiarch.yml
|
||||||
|
- build/azure-devops/identity-api/*
|
||||||
|
- deploy/k8s/helm/identity-api/*
|
||||||
|
jobs:
|
||||||
|
- template: ../buildimages.yaml
|
||||||
|
parameters:
|
||||||
|
services: identity-api
|
||||||
|
registryEndpoint: $(registryEndpoint)
|
||||||
|
helmfrom: $(Build.SourcesDirectory)/deploy/k8s/helm
|
||||||
|
helmto: $(Build.ArtifactStagingDirectory)/deploy/k8s/helm
|
||||||
|
- template: ../multiarch.yaml
|
||||||
|
parameters:
|
||||||
|
image: identity.api
|
||||||
|
branch: $(Build.SourceBranchName)
|
||||||
|
registryEndpoint: $(registryEndpoint)
|
28
build/azure-devops/infrastructure/azure-pipelines.yml
Normal file
28
build/azure-devops/infrastructure/azure-pipelines.yml
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
pool:
|
||||||
|
vmImage: 'ubuntu-16.04'
|
||||||
|
variables:
|
||||||
|
registryEndpoint: eshop-registry
|
||||||
|
trigger:
|
||||||
|
branches:
|
||||||
|
include:
|
||||||
|
- master
|
||||||
|
- dev
|
||||||
|
paths:
|
||||||
|
include:
|
||||||
|
- build/azure-devops/buildimages.yml
|
||||||
|
- build/azure-devops/multiarch.yml
|
||||||
|
- build/azure-devops/infrastructure/*
|
||||||
|
- deploy/k8s/helm/basket-data/*
|
||||||
|
- deploy/k8s/helm/keystore-data/*
|
||||||
|
- deploy/k8s/helm/nosql-data/*
|
||||||
|
- deploy/k8s/helm/rabbitmq/*
|
||||||
|
- deploy/k8s/helm/sql-data/*
|
||||||
|
steps:
|
||||||
|
- task: CopyFiles@2
|
||||||
|
inputs:
|
||||||
|
sourceFolder: $(Build.SourcesDirectory)/deploy/k8s/helm
|
||||||
|
targetFolder: $(Build.ArtifactStagingDirectory)/deploy/k8s/helm
|
||||||
|
- task: PublishBuildArtifacts@1
|
||||||
|
inputs:
|
||||||
|
pathtoPublish: $(Build.ArtifactStagingDirectory)/deploy/k8s/helm
|
||||||
|
artifactName: helm
|
27
build/azure-devops/location-api/azure-pipelines.yml
Normal file
27
build/azure-devops/location-api/azure-pipelines.yml
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
variables:
|
||||||
|
registryEndpoint: eshop-registry
|
||||||
|
trigger:
|
||||||
|
branches:
|
||||||
|
include:
|
||||||
|
- master
|
||||||
|
- dev
|
||||||
|
paths:
|
||||||
|
include:
|
||||||
|
- src/BuildingBlocks/*
|
||||||
|
- src/Services/Location/*
|
||||||
|
- build/azure-devops/buildimages.yml
|
||||||
|
- build/azure-devops/multiarch.yml
|
||||||
|
- build/azure-devops/location-api/*
|
||||||
|
- deploy/k8s/helm/locations-api/*
|
||||||
|
jobs:
|
||||||
|
- template: ../buildimages.yaml
|
||||||
|
parameters:
|
||||||
|
services: locations-api
|
||||||
|
registryEndpoint: $(registryEndpoint)
|
||||||
|
helmfrom: $(Build.SourcesDirectory)/deploy/k8s/helm
|
||||||
|
helmto: $(Build.ArtifactStagingDirectory)/deploy/k8s/helm
|
||||||
|
- template: ../multiarch.yaml
|
||||||
|
parameters:
|
||||||
|
image: locations.api
|
||||||
|
branch: $(Build.SourceBranchName)
|
||||||
|
registryEndpoint: $(registryEndpoint)
|
27
build/azure-devops/marketing-api/azure-pipelines.yml
Normal file
27
build/azure-devops/marketing-api/azure-pipelines.yml
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
variables:
|
||||||
|
registryEndpoint: eshop-registry
|
||||||
|
trigger:
|
||||||
|
branches:
|
||||||
|
include:
|
||||||
|
- master
|
||||||
|
- dev
|
||||||
|
paths:
|
||||||
|
include:
|
||||||
|
- src/BuildingBlocks/*
|
||||||
|
- src/Services/Marketing/*
|
||||||
|
- build/azure-devops/buildimages.yml
|
||||||
|
- build/azure-devops/multiarch.yml
|
||||||
|
- build/azure-devops/marketing-api/*
|
||||||
|
- deploy/k8s/helm/marketing-api/*
|
||||||
|
jobs:
|
||||||
|
- template: ../buildimages.yaml
|
||||||
|
parameters:
|
||||||
|
services: marketing-api
|
||||||
|
registryEndpoint: $(registryEndpoint)
|
||||||
|
helmfrom: $(Build.SourcesDirectory)/deploy/k8s/helm
|
||||||
|
helmto: $(Build.ArtifactStagingDirectory)/deploy/k8s/helm
|
||||||
|
- template: ../multiarch.yaml
|
||||||
|
parameters:
|
||||||
|
image: marketing.api
|
||||||
|
branch: $(Build.SourceBranchName)
|
||||||
|
registryEndpoint: $(registryEndpoint)
|
27
build/azure-devops/mobile-shopping-agg/azure-pipelines.yml
Normal file
27
build/azure-devops/mobile-shopping-agg/azure-pipelines.yml
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
variables:
|
||||||
|
registryEndpoint: eshop-registry
|
||||||
|
trigger:
|
||||||
|
branches:
|
||||||
|
include:
|
||||||
|
- master
|
||||||
|
- dev
|
||||||
|
paths:
|
||||||
|
include:
|
||||||
|
- src/ApiGateways/Mobile.Bff.Shopping/aggregator/*
|
||||||
|
- build/azure-devops/buildimages.yml
|
||||||
|
- build/azure-devops/multiarch.yml
|
||||||
|
- build/azure-devops/mobile-shopping-agg/*
|
||||||
|
- deploy/k8s/helm/mobileshoppingagg/*
|
||||||
|
jobs:
|
||||||
|
- template: ../buildimages.yaml
|
||||||
|
parameters:
|
||||||
|
services: mobileshoppingagg
|
||||||
|
registryEndpoint: $(registryEndpoint)
|
||||||
|
helmfrom: $(Build.SourcesDirectory)/deploy/k8s/helm
|
||||||
|
helmto: $(Build.ArtifactStagingDirectory)/deploy/k8s/helm
|
||||||
|
- template: ../multiarch.yaml
|
||||||
|
parameters:
|
||||||
|
image: mobileshoppingagg
|
||||||
|
branch: $(Build.SourceBranchName)
|
||||||
|
registryEndpoint: $(registryEndpoint)
|
||||||
|
|
33
build/azure-devops/multiarch.yaml
Normal file
33
build/azure-devops/multiarch.yaml
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
parameters:
|
||||||
|
image: ''
|
||||||
|
branch: ''
|
||||||
|
registry: 'eshop'
|
||||||
|
registryEndpoint: ''
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
- job: manifest
|
||||||
|
condition: and(succeeded(),ne('${{ variables['Build.Reason'] }}', 'PullRequest'))
|
||||||
|
dependsOn:
|
||||||
|
# - BuildWindows
|
||||||
|
- BuildLinux
|
||||||
|
pool:
|
||||||
|
vmImage: 'Ubuntu 16.04'
|
||||||
|
steps:
|
||||||
|
- task: Docker@1
|
||||||
|
displayName: Docker Login
|
||||||
|
inputs:
|
||||||
|
command: login
|
||||||
|
containerregistrytype: 'Container Registry'
|
||||||
|
dockerRegistryEndpoint: ${{ parameters.registryEndpoint }}
|
||||||
|
# Disabled windows deploy
|
||||||
|
# docker --config ~/.docker manifest create ${{ parameters.registry }}/${{ parameters.image }}:${{ parameters.branch }} ${{ parameters.registry }}/${{ parameters.image }}:linux-${{ parameters.branch }} ${{ parameters.registry }}/${{ parameters.image }}:win-${{ parameters.branch }}
|
||||||
|
# docker --config ~/.docker manifest create ${{ parameters.registry }}/${{ parameters.image }}:latest ${{ parameters.registry }}/${{ parameters.image }}:linux-latest ${{ parameters.registry }}/${{ parameters.image }}:win-latest
|
||||||
|
- bash: |
|
||||||
|
mkdir -p ~/.docker
|
||||||
|
sed '$ s/.$//' $DOCKER_CONFIG/config.json > ~/.docker/config.json
|
||||||
|
echo ',"experimental": "enabled" }' >> ~/.docker/config.json
|
||||||
|
docker --config ~/.docker manifest create ${{ parameters.registry }}/${{ parameters.image }}:${{ parameters.branch }} ${{ parameters.registry }}/${{ parameters.image }}:linux-${{ parameters.branch }}
|
||||||
|
docker --config ~/.docker manifest create ${{ parameters.registry }}/${{ parameters.image }}:latest ${{ parameters.registry }}/${{ parameters.image }}:linux-latest
|
||||||
|
docker --config ~/.docker manifest push ${{ parameters.registry }}/${{ parameters.image }}:${{ parameters.branch }}
|
||||||
|
docker --config ~/.docker manifest push ${{ parameters.registry }}/${{ parameters.image }}:latest
|
||||||
|
displayName: Create multiarch manifest
|
29
build/azure-devops/ordering-api/azure-pipelines.yml
Normal file
29
build/azure-devops/ordering-api/azure-pipelines.yml
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
variables:
|
||||||
|
registryEndpoint: eshop-registry
|
||||||
|
trigger:
|
||||||
|
branches:
|
||||||
|
include:
|
||||||
|
- master
|
||||||
|
- dev
|
||||||
|
paths:
|
||||||
|
include:
|
||||||
|
- src/BuildingBlocks/*
|
||||||
|
- src/Services/Ordering/*
|
||||||
|
- build/azure-devops/buildimages.yml
|
||||||
|
- build/azure-devops/multiarch.yml
|
||||||
|
- build/azure-devops/ordering-api/*
|
||||||
|
- deploy/k8s/helm/ordering-api/*
|
||||||
|
- deploy/k8s/helm/ordering-backgroundtasks/*
|
||||||
|
- deploy/k8s/helm/ordering-signalrhub/*
|
||||||
|
jobs:
|
||||||
|
- template: ../buildimages.yaml
|
||||||
|
parameters:
|
||||||
|
services: ordering-api
|
||||||
|
registryEndpoint: $(registryEndpoint)
|
||||||
|
helmfrom: $(Build.SourcesDirectory)/deploy/k8s/helm
|
||||||
|
helmto: $(Build.ArtifactStagingDirectory)/deploy/k8s/helm
|
||||||
|
- template: ../multiarch.yaml
|
||||||
|
parameters:
|
||||||
|
image: ordering.api
|
||||||
|
branch: $(Build.SourceBranchName)
|
||||||
|
registryEndpoint: $(registryEndpoint)
|
27
build/azure-devops/payment-api/azure-pipelines.yml
Normal file
27
build/azure-devops/payment-api/azure-pipelines.yml
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
variables:
|
||||||
|
registryEndpoint: eshop-registry
|
||||||
|
trigger:
|
||||||
|
branches:
|
||||||
|
include:
|
||||||
|
- master
|
||||||
|
- dev
|
||||||
|
paths:
|
||||||
|
include:
|
||||||
|
- src/BuildingBlocks/*
|
||||||
|
- src/Services/Payment/*
|
||||||
|
- build/azure-devops/buildimages.yml
|
||||||
|
- build/azure-devops/multiarch.yml
|
||||||
|
- build/azure-devops/payment-api/*
|
||||||
|
- deploy/k8s/helm/payment-api/*
|
||||||
|
jobs:
|
||||||
|
- template: ../buildimages.yaml
|
||||||
|
parameters:
|
||||||
|
services: payment-api
|
||||||
|
registryEndpoint: $(registryEndpoint)
|
||||||
|
helmfrom: $(Build.SourcesDirectory)/deploy/k8s/helm
|
||||||
|
helmto: $(Build.ArtifactStagingDirectory)/deploy/k8s/helm
|
||||||
|
- template: ../multiarch.yaml
|
||||||
|
parameters:
|
||||||
|
image: payment.api
|
||||||
|
branch: $(Build.SourceBranchName)
|
||||||
|
registryEndpoint: $(registryEndpoint)
|
5
build/azure-devops/readme.md
Normal file
5
build/azure-devops/readme.md
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
# Azure DevOps build definitions
|
||||||
|
|
||||||
|
This folder contains the Azure DevOps build definitions in YAML format. Each folder contains one `azure-pipelines.yml` that contains the build definition for one microservice (usually a Docker image, but some microservices generates more than one Docker image).
|
||||||
|
|
||||||
|
For more information about YAML builds read the [Azure DevOps documentation](https://docs.microsoft.com/azure/devops/pipelines/get-started-yaml?view=azure-devops).
|
26
build/azure-devops/web-shopping-agg/azure-pipelines.yml
Normal file
26
build/azure-devops/web-shopping-agg/azure-pipelines.yml
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
variables:
|
||||||
|
registryEndpoint: eshop-registry
|
||||||
|
trigger:
|
||||||
|
branches:
|
||||||
|
include:
|
||||||
|
- master
|
||||||
|
- dev
|
||||||
|
paths:
|
||||||
|
include:
|
||||||
|
- src/ApiGateways/Web.Bff.Shopping/aggregator/*
|
||||||
|
- build/azure-devops/buildimages.yml
|
||||||
|
- build/azure-devops/multiarch.yml
|
||||||
|
- build/azure-devops/web-shopping-agg/*
|
||||||
|
- deploy/k8s/helm/webshoppingagg/*
|
||||||
|
jobs:
|
||||||
|
- template: ../buildimages.yaml
|
||||||
|
parameters:
|
||||||
|
services: webshoppingagg
|
||||||
|
registryEndpoint: $(registryEndpoint)
|
||||||
|
helmfrom: $(Build.SourcesDirectory)/deploy/k8s/helm
|
||||||
|
helmto: $(Build.ArtifactStagingDirectory)/deploy/k8s/helm
|
||||||
|
- template: ../multiarch.yaml
|
||||||
|
parameters:
|
||||||
|
image: webshoppingagg
|
||||||
|
branch: $(Build.SourceBranchName)
|
||||||
|
registryEndpoint: $(registryEndpoint)
|
27
build/azure-devops/webhooks-api/azure-pipelines.yml
Normal file
27
build/azure-devops/webhooks-api/azure-pipelines.yml
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
variables:
|
||||||
|
registryEndpoint: eshop-registry
|
||||||
|
trigger:
|
||||||
|
branches:
|
||||||
|
include:
|
||||||
|
- master
|
||||||
|
- dev
|
||||||
|
paths:
|
||||||
|
include:
|
||||||
|
- src/BuildingBlocks/*
|
||||||
|
- src/Services/Webhooks/*
|
||||||
|
- build/azure-devops/buildimages.yml
|
||||||
|
- build/azure-devops/multiarch.yml
|
||||||
|
- build/azure-devops/webhooks-api/*
|
||||||
|
- deploy/k8s/helm/webhooks-api/*
|
||||||
|
jobs:
|
||||||
|
- template: ../buildimages.yaml
|
||||||
|
parameters:
|
||||||
|
services: webhooks-api
|
||||||
|
registryEndpoint: $(registryEndpoint)
|
||||||
|
helmfrom: $(Build.SourcesDirectory)/deploy/k8s/helm
|
||||||
|
helmto: $(Build.ArtifactStagingDirectory)/deploy/k8s/helm
|
||||||
|
- template: ../multiarch.yaml
|
||||||
|
parameters:
|
||||||
|
image: webhooks.api
|
||||||
|
branch: $(Build.SourceBranchName)
|
||||||
|
registryEndpoint: $(registryEndpoint)
|
27
build/azure-devops/webhooks-client/azure-pipelines.yml
Normal file
27
build/azure-devops/webhooks-client/azure-pipelines.yml
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
variables:
|
||||||
|
registryEndpoint: eshop-registry
|
||||||
|
trigger:
|
||||||
|
branches:
|
||||||
|
include:
|
||||||
|
- master
|
||||||
|
- dev
|
||||||
|
paths:
|
||||||
|
include:
|
||||||
|
- src/BuildingBlocks/*
|
||||||
|
- src/Web/WebhookClient/*
|
||||||
|
- build/azure-devops/buildimages.yml
|
||||||
|
- build/azure-devops/multiarch.yml
|
||||||
|
- build/azure-devops/webhooks-client/*
|
||||||
|
- deploy/k8s/helm/webhooks-web/*
|
||||||
|
jobs:
|
||||||
|
- template: ../buildimages.yaml
|
||||||
|
parameters:
|
||||||
|
services: webhooks-client
|
||||||
|
registryEndpoint: $(registryEndpoint)
|
||||||
|
helmfrom: $(Build.SourcesDirectory)/deploy/k8s/helm
|
||||||
|
helmto: $(Build.ArtifactStagingDirectory)/deploy/k8s/helm
|
||||||
|
- template: ../multiarch.yaml
|
||||||
|
parameters:
|
||||||
|
image: webhooks.client
|
||||||
|
branch: $(Build.SourceBranchName)
|
||||||
|
registryEndpoint: $(registryEndpoint)
|
27
build/azure-devops/webmvc/azure-pipelines.yml
Normal file
27
build/azure-devops/webmvc/azure-pipelines.yml
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
variables:
|
||||||
|
registryEndpoint: eshop-registry
|
||||||
|
trigger:
|
||||||
|
branches:
|
||||||
|
include:
|
||||||
|
- master
|
||||||
|
- dev
|
||||||
|
paths:
|
||||||
|
include:
|
||||||
|
- src/BuildingBlocks/*
|
||||||
|
- src/Web/WebMVC/*
|
||||||
|
- build/azure-devops/buildimages.yml
|
||||||
|
- build/azure-devops/multiarch.yml
|
||||||
|
- build/azure-devops/webmvc/*
|
||||||
|
- deploy/k8s/helm/webmvc/*
|
||||||
|
jobs:
|
||||||
|
- template: ../buildimages.yaml
|
||||||
|
parameters:
|
||||||
|
services: webmvc
|
||||||
|
registryEndpoint: $(registryEndpoint)
|
||||||
|
helmfrom: $(Build.SourcesDirectory)/deploy/k8s/helm
|
||||||
|
helmto: $(Build.ArtifactStagingDirectory)/deploy/k8s/helm
|
||||||
|
- template: ../multiarch.yaml
|
||||||
|
parameters:
|
||||||
|
image: webmvc
|
||||||
|
branch: $(Build.SourceBranchName)
|
||||||
|
registryEndpoint: $(registryEndpoint)
|
27
build/azure-devops/webspa/azure-pipelines.yml
Normal file
27
build/azure-devops/webspa/azure-pipelines.yml
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
variables:
|
||||||
|
registryEndpoint: eshop-registry
|
||||||
|
trigger:
|
||||||
|
branches:
|
||||||
|
include:
|
||||||
|
- master
|
||||||
|
- dev
|
||||||
|
paths:
|
||||||
|
include:
|
||||||
|
- src/BuildingBlocks/*
|
||||||
|
- src/Web/WebSPA/*
|
||||||
|
- build/azure-devops/buildimages.yml
|
||||||
|
- build/azure-devops/multiarch.yml
|
||||||
|
- build/azure-devops/webspa/*
|
||||||
|
- deploy/k8s/helm/webspa/*
|
||||||
|
jobs:
|
||||||
|
- template: ../buildimages.yaml
|
||||||
|
parameters:
|
||||||
|
services: webspa
|
||||||
|
registryEndpoint: $(registryEndpoint)
|
||||||
|
helmfrom: $(Build.SourcesDirectory)/deploy/k8s/helm
|
||||||
|
helmto: $(Build.ArtifactStagingDirectory)/deploy/k8s/helm
|
||||||
|
- template: ../multiarch.yaml
|
||||||
|
parameters:
|
||||||
|
image: webspa
|
||||||
|
branch: $(Build.SourceBranchName)
|
||||||
|
registryEndpoint: $(registryEndpoint)
|
27
build/azure-devops/webstatus/azure-pipelines.yml
Normal file
27
build/azure-devops/webstatus/azure-pipelines.yml
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
variables:
|
||||||
|
registryEndpoint: eshop-registry
|
||||||
|
trigger:
|
||||||
|
branches:
|
||||||
|
include:
|
||||||
|
- master
|
||||||
|
- dev
|
||||||
|
paths:
|
||||||
|
include:
|
||||||
|
- src/BuildingBlocks/*
|
||||||
|
- src/Web/WebStatus/*
|
||||||
|
- build/azure-devops/buildimages.yml
|
||||||
|
- build/azure-devops/multiarch.yml
|
||||||
|
- build/azure-devops/webstatus/*
|
||||||
|
- deploy/k8s/helm/webstatus/*
|
||||||
|
jobs:
|
||||||
|
- template: ../buildimages.yaml
|
||||||
|
parameters:
|
||||||
|
services: webstatus
|
||||||
|
registryEndpoint: $(registryEndpoint)
|
||||||
|
helmfrom: $(Build.SourcesDirectory)/deploy/k8s/helm
|
||||||
|
helmto: $(Build.ArtifactStagingDirectory)/deploy/k8s/helm
|
||||||
|
- template: ../multiarch.yaml
|
||||||
|
parameters:
|
||||||
|
image: webstatus
|
||||||
|
branch: $(Build.SourceBranchName)
|
||||||
|
registryEndpoint: $(registryEndpoint)
|
@ -12,7 +12,7 @@ Write-Host "Tags used are linux-master, win-master, linux-dev, win-dev, linux-la
|
|||||||
Write-Host "Multiarch images tags will be master, dev, latest" -ForegroundColor Yellow
|
Write-Host "Multiarch images tags will be master, dev, latest" -ForegroundColor Yellow
|
||||||
|
|
||||||
|
|
||||||
$services = "identity.api", "basket.api", "catalog.api", "ordering.api", "ordering.backgroundtasks", "payment.api", "webhooks.api", "ocelotapigw", "mobileshoppingagg", "webshoppingagg", "ordering.signalrhub", "webstatus", "webspa", "webmvc", "webhooks.client"
|
$services = "identity.api", "basket.api", "catalog.api", "ordering.api", "ordering.backgroundtasks", "marketing.api", "payment.api", "locations.api", "webhooks.api", "ocelotapigw", "mobileshoppingagg", "webshoppingagg", "ordering.signalrhub", "webstatus", "webspa", "webmvc", "webhooks.client"
|
||||||
|
|
||||||
foreach ($svc in $services) {
|
foreach ($svc in $services) {
|
||||||
Write-Host "Creating manifest for $svc and tags :latest, :master, and :dev"
|
Write-Host "Creating manifest for $svc and tags :latest, :master, and :dev"
|
||||||
|
@ -51,8 +51,8 @@ if [ ! -f "$1.json" ]; then
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ ! -f "$1.parameters.json" ]; then
|
if [ ! -f "$2.parameters.json" ]; then
|
||||||
echo "$1.parameters.json doesn't exist"
|
echo "$2.parameters.json doesn't exist"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
@ -14,11 +14,10 @@
|
|||||||
"BasketSubscriptionName": "Basket",
|
"BasketSubscriptionName": "Basket",
|
||||||
"CatalogSubscriptionName": "Catalog",
|
"CatalogSubscriptionName": "Catalog",
|
||||||
"OrderingSubscriptionName": "Ordering",
|
"OrderingSubscriptionName": "Ordering",
|
||||||
|
"LocationsSubscriptionName": "Locations",
|
||||||
|
"MarketingSubscriptionName": "Marketing",
|
||||||
"GracePeriodSubscriptionName": "GracePeriod",
|
"GracePeriodSubscriptionName": "GracePeriod",
|
||||||
"PaymentSubscriptionName": "Payment",
|
"PaymentSubscriptionName": "Payment",
|
||||||
"BackgroundTaskSubscriptionName": "backgroundtasks",
|
|
||||||
"OrderingSignalrHubSubscriptionName": "Ordering.signalrhub",
|
|
||||||
"WebhooksSubscriptionName": "Webhooks",
|
|
||||||
"location": "[resourceGroup().location]",
|
"location": "[resourceGroup().location]",
|
||||||
"sbVersion": "2015-08-01",
|
"sbVersion": "2015-08-01",
|
||||||
"defaultSASKeyName": "Root",
|
"defaultSASKeyName": "Root",
|
||||||
@ -136,6 +135,46 @@
|
|||||||
"entityAvailabilityStatus": "Available"
|
"entityAvailabilityStatus": "Available"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"apiVersion": "[variables('sbVersion')]",
|
||||||
|
"name": "[variables('LocationsSubscriptionName')]",
|
||||||
|
"type": "Subscriptions",
|
||||||
|
"dependsOn": [
|
||||||
|
"[variables('serviceBusTopicName')]"
|
||||||
|
],
|
||||||
|
"properties": {
|
||||||
|
"lockDuration": "00:00:30",
|
||||||
|
"requiresSession": false,
|
||||||
|
"defaultMessageTimeToLive": "14.00:00:00",
|
||||||
|
"deadLetteringOnMessageExpiration": true,
|
||||||
|
"deadLetteringOnFilterEvaluationExceptions": true,
|
||||||
|
"maxDeliveryCount": 10,
|
||||||
|
"enableBatchedOperations": false,
|
||||||
|
"status": "Active",
|
||||||
|
"autoDeleteOnIdle": "10675199.02:48:05.4775807",
|
||||||
|
"entityAvailabilityStatus": "Available"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"apiVersion": "[variables('sbVersion')]",
|
||||||
|
"name": "[variables('MarketingSubscriptionName')]",
|
||||||
|
"type": "Subscriptions",
|
||||||
|
"dependsOn": [
|
||||||
|
"[variables('serviceBusTopicName')]"
|
||||||
|
],
|
||||||
|
"properties": {
|
||||||
|
"lockDuration": "00:00:30",
|
||||||
|
"requiresSession": false,
|
||||||
|
"defaultMessageTimeToLive": "14.00:00:00",
|
||||||
|
"deadLetteringOnMessageExpiration": true,
|
||||||
|
"deadLetteringOnFilterEvaluationExceptions": true,
|
||||||
|
"maxDeliveryCount": 10,
|
||||||
|
"enableBatchedOperations": false,
|
||||||
|
"status": "Active",
|
||||||
|
"autoDeleteOnIdle": "10675199.02:48:05.4775807",
|
||||||
|
"entityAvailabilityStatus": "Available"
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"apiVersion": "[variables('sbVersion')]",
|
"apiVersion": "[variables('sbVersion')]",
|
||||||
"name": "[variables('GracePeriodSubscriptionName')]",
|
"name": "[variables('GracePeriodSubscriptionName')]",
|
||||||
@ -175,66 +214,6 @@
|
|||||||
"autoDeleteOnIdle": "10675199.02:48:05.4775807",
|
"autoDeleteOnIdle": "10675199.02:48:05.4775807",
|
||||||
"entityAvailabilityStatus": "Available"
|
"entityAvailabilityStatus": "Available"
|
||||||
}
|
}
|
||||||
},
|
|
||||||
{
|
|
||||||
"apiVersion": "[variables('sbVersion')]",
|
|
||||||
"name": "[variables('BackgroundTaskSubscriptionName')]",
|
|
||||||
"type": "Subscriptions",
|
|
||||||
"dependsOn": [
|
|
||||||
"[variables('serviceBusTopicName')]"
|
|
||||||
],
|
|
||||||
"properties": {
|
|
||||||
"lockDuration": "00:00:30",
|
|
||||||
"requiresSession": false,
|
|
||||||
"defaultMessageTimeToLive": "14.00:00:00",
|
|
||||||
"deadLetteringOnMessageExpiration": true,
|
|
||||||
"deadLetteringOnFilterEvaluationExceptions": true,
|
|
||||||
"maxDeliveryCount": 10,
|
|
||||||
"enableBatchedOperations": false,
|
|
||||||
"status": "Active",
|
|
||||||
"autoDeleteOnIdle": "10675199.02:48:05.4775807",
|
|
||||||
"entityAvailabilityStatus": "Available"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"apiVersion": "[variables('sbVersion')]",
|
|
||||||
"name": "[variables('OrderingSignalrHubSubscriptionName')]",
|
|
||||||
"type": "Subscriptions",
|
|
||||||
"dependsOn": [
|
|
||||||
"[variables('serviceBusTopicName')]"
|
|
||||||
],
|
|
||||||
"properties": {
|
|
||||||
"lockDuration": "00:00:30",
|
|
||||||
"requiresSession": false,
|
|
||||||
"defaultMessageTimeToLive": "14.00:00:00",
|
|
||||||
"deadLetteringOnMessageExpiration": true,
|
|
||||||
"deadLetteringOnFilterEvaluationExceptions": true,
|
|
||||||
"maxDeliveryCount": 10,
|
|
||||||
"enableBatchedOperations": false,
|
|
||||||
"status": "Active",
|
|
||||||
"autoDeleteOnIdle": "10675199.02:48:05.4775807",
|
|
||||||
"entityAvailabilityStatus": "Available"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"apiVersion": "[variables('sbVersion')]",
|
|
||||||
"name": "[variables('WebhooksSubscriptionName')]",
|
|
||||||
"type": "Subscriptions",
|
|
||||||
"dependsOn": [
|
|
||||||
"[variables('serviceBusTopicName')]"
|
|
||||||
],
|
|
||||||
"properties": {
|
|
||||||
"lockDuration": "00:00:30",
|
|
||||||
"requiresSession": false,
|
|
||||||
"defaultMessageTimeToLive": "14.00:00:00",
|
|
||||||
"deadLetteringOnMessageExpiration": true,
|
|
||||||
"deadLetteringOnFilterEvaluationExceptions": true,
|
|
||||||
"maxDeliveryCount": 10,
|
|
||||||
"enableBatchedOperations": false,
|
|
||||||
"status": "Active",
|
|
||||||
"autoDeleteOnIdle": "10675199.02:48:05.4775807",
|
|
||||||
"entityAvailabilityStatus": "Available"
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
@ -73,7 +73,22 @@
|
|||||||
"dependsOn": [
|
"dependsOn": [
|
||||||
"[concat('Microsoft.Sql/servers/', variables('sql_server_name'))]"
|
"[concat('Microsoft.Sql/servers/', variables('sql_server_name'))]"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"type": "databases",
|
||||||
|
"name": "[parameters('sql_server').dbs.marketing]",
|
||||||
|
"apiVersion": "2014-04-01-preview",
|
||||||
|
"location": "[resourceGroup().location]",
|
||||||
|
"properties": {
|
||||||
|
"edition": "Standard",
|
||||||
|
"collation": "SQL_Latin1_General_CP1_CI_AS",
|
||||||
|
"maxSizeBytes": "1073741824",
|
||||||
|
"requestedServiceObjectiveName": "S1"
|
||||||
|
},
|
||||||
|
"dependsOn": [
|
||||||
|
"[concat('Microsoft.Sql/servers/', variables('sql_server_name'))]"
|
||||||
|
]
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"type": "firewallrules",
|
"type": "firewallrules",
|
||||||
"name": "AllowAllWindowsAzureIps",
|
"name": "AllowAllWindowsAzureIps",
|
||||||
|
@ -8,7 +8,8 @@
|
|||||||
"dbs": {
|
"dbs": {
|
||||||
"ordering": "orderingdb",
|
"ordering": "orderingdb",
|
||||||
"identity": "identitydb",
|
"identity": "identitydb",
|
||||||
"catalog": "catalogdb"
|
"catalog": "catalogdb",
|
||||||
|
"marketing": "marketingdb"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
94
deploy/azure/az/storage/marketing/deploystorage.json
Normal file
94
deploy/azure/az/storage/marketing/deploystorage.json
Normal file
@ -0,0 +1,94 @@
|
|||||||
|
{
|
||||||
|
"$schema": "https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#",
|
||||||
|
"contentVersion": "1.0.0.0",
|
||||||
|
"parameters": {
|
||||||
|
"marketingstorage": {
|
||||||
|
"type": "string"
|
||||||
|
},
|
||||||
|
"profileName" : {
|
||||||
|
"type": "string"
|
||||||
|
},
|
||||||
|
"endpointName" : {
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"variables": {
|
||||||
|
"marketingstorage": "[concat(parameters('marketingstorage'), uniqueString(resourceGroup().id))]",
|
||||||
|
"endpointName": "[concat(parameters('endpointName'), uniqueString(resourceGroup().id))]",
|
||||||
|
"profileName": "[parameters('profileName')]"
|
||||||
|
},
|
||||||
|
"resources": [
|
||||||
|
{
|
||||||
|
"type": "Microsoft.Storage/storageAccounts",
|
||||||
|
"name": "[variables('marketingstorage')]",
|
||||||
|
"apiVersion": "2016-01-01",
|
||||||
|
"location": "[resourceGroup().location]",
|
||||||
|
"tags": {
|
||||||
|
"displayName": "[variables('marketingstorage')]"
|
||||||
|
},
|
||||||
|
"sku": {
|
||||||
|
"name": "Standard_LRS"
|
||||||
|
},
|
||||||
|
"kind": "Storage"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "[variables('profileName')]",
|
||||||
|
"type": "Microsoft.Cdn/profiles",
|
||||||
|
"location": "[resourceGroup().location]",
|
||||||
|
"apiVersion": "2016-04-02",
|
||||||
|
"tags": {
|
||||||
|
"displayName": "[variables('profileName')]"
|
||||||
|
},
|
||||||
|
"sku": {
|
||||||
|
"name": "Standard_Verizon"
|
||||||
|
},
|
||||||
|
"resources": [
|
||||||
|
{
|
||||||
|
"apiVersion": "2016-04-02",
|
||||||
|
"name": "[variables('endpointName')]",
|
||||||
|
"type": "endpoints",
|
||||||
|
"dependsOn": [
|
||||||
|
"[variables('profileName')]",
|
||||||
|
"[variables('marketingstorage')]"
|
||||||
|
],
|
||||||
|
"location": "[resourceGroup().location]",
|
||||||
|
"tags": {
|
||||||
|
"displayName": "[variables('endpointName')]"
|
||||||
|
},
|
||||||
|
"properties": {
|
||||||
|
"originHostHeader": "[replace(replace(reference(resourceId('Microsoft.Storage/storageAccounts', variables('marketingstorage')),'2015-06-15' ).primaryEndpoints.blob,'https://',''),'/','')]",
|
||||||
|
"isHttpAllowed": true,
|
||||||
|
"isHttpsAllowed": true,
|
||||||
|
"queryStringCachingBehavior": "IgnoreQueryString",
|
||||||
|
"contentTypesToCompress": [
|
||||||
|
"text/plain",
|
||||||
|
"text/html",
|
||||||
|
"text/css",
|
||||||
|
"application/x-javascript",
|
||||||
|
"text/javascript"
|
||||||
|
],
|
||||||
|
"isCompressionEnabled": "True",
|
||||||
|
"origins": [
|
||||||
|
{
|
||||||
|
"name": "origin1",
|
||||||
|
"properties": {
|
||||||
|
"hostName": "[replace(replace(reference(resourceId('Microsoft.Storage/storageAccounts', variables('marketingstorage')),'2015-06-15' ).primaryEndpoints.blob,'https://',''),'/','')]"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"outputs": {
|
||||||
|
"hostName": {
|
||||||
|
"type": "string",
|
||||||
|
"value": "[reference(resourceId('Microsoft.cdn/profiles/endpoints', variables('profileName'), variables('endpointName'))).hostName]"
|
||||||
|
},
|
||||||
|
"originHostHeader": {
|
||||||
|
"type": "string",
|
||||||
|
"value": "[reference(resourceId('Microsoft.cdn/profiles/endpoints', variables('profileName'), variables('endpointName'))).originHostHeader]"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,15 @@
|
|||||||
|
{
|
||||||
|
"$schema": "https://schema.management.azure.com/schemas/2015-01-01/deploymentParameters.json#",
|
||||||
|
"contentVersion": "1.0.0.0",
|
||||||
|
"parameters": {
|
||||||
|
"marketingstorage": {
|
||||||
|
"value": "marketing"
|
||||||
|
},
|
||||||
|
"profileName":{
|
||||||
|
"value": "eshopmarketing"
|
||||||
|
},
|
||||||
|
"endpointName":{
|
||||||
|
"value": "marketing-endpoint"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
37
deploy/azure/az/storage/marketing/readme.md
Normal file
37
deploy/azure/az/storage/marketing/readme.md
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
# Deploying Marketing Storage
|
||||||
|
|
||||||
|
The ARM template `deploystorage.json` and its parameter file (`deploystorage.parameters.json`) are used to deploy following resources:
|
||||||
|
|
||||||
|
1. One Storage Account
|
||||||
|
2. One CDN profile
|
||||||
|
3. One Endpoint
|
||||||
|
|
||||||
|
## Editing deploystorage.parameters.json file
|
||||||
|
|
||||||
|
You can edit the `deploystorage.parameters.json` file to set your values, but is not needed. The only parameters that can
|
||||||
|
be set are:
|
||||||
|
|
||||||
|
1. `marketingstorage` is a string that is used to create the storage account name. ARM script creates unique values by appending a unique string to this parameter value, so you can leave the default value.
|
||||||
|
|
||||||
|
2. `profileName` is a string that is used to create the CDN profile name.
|
||||||
|
|
||||||
|
3. `endpointName` is a string that is used to create the storage endpoint name. ARM script creates unique values by appending a unique string to this parameter value, so you can leave the default value.
|
||||||
|
|
||||||
|
## Deploy the template
|
||||||
|
|
||||||
|
Once parameter file is edited you can deploy it using [create-resources script](../../readme.md).
|
||||||
|
|
||||||
|
i. e. if you are in windows, to deploy a Storage account in a new resourcegroup located in westus, go to `deploy\az` folder and type:
|
||||||
|
|
||||||
|
```
|
||||||
|
create-resources.cmd storage\marketing\deploystorage newResourceGroup -c westus
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -22,6 +22,8 @@ Using `docker-machine` is the recommended way to create a VM with docker install
|
|||||||
3. [Deploying Redis Cache](az/redis/readme.md)
|
3. [Deploying Redis Cache](az/redis/readme.md)
|
||||||
4. [Deploying Cosmosdb](az/cosmos/readme.md)
|
4. [Deploying Cosmosdb](az/cosmos/readme.md)
|
||||||
5. [Deploying Catalog Storage](az/storage/catalog/readme.md)
|
5. [Deploying Catalog Storage](az/storage/catalog/readme.md)
|
||||||
|
6. [Deploying Marketing Storage](az/storage/marketing/readme.md)
|
||||||
|
7. [Deploying Marketing Azure functions](az/azurefunctions/readme.md)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
8
deploy/k8s/archived/README.md
Normal file
8
deploy/k8s/archived/README.md
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
# Kubernetes deployment
|
||||||
|
|
||||||
|
This folder contains the files required to deploy eShopOnContainers to a Kubernetes cluster.
|
||||||
|
|
||||||
|
For more information see the following articles in the [wiki](https://github.com/dotnet-architecture/eShopOnContainers/wiki):
|
||||||
|
|
||||||
|
- [Deploy to Local Kubernetes](https://github.com/dotnet-architecture/eShopOnContainers/wiki/Deploy-to-Local-Kubernetes)
|
||||||
|
- [Deploy to Azure Kubernetes Service (AKS)](https://github.com/dotnet-architecture/eShopOnContainers/wiki/Deploy-to-Azure-Kubernetes-Service-(AKS))
|
50
deploy/k8s/archived/create-aks.ps1
Normal file
50
deploy/k8s/archived/create-aks.ps1
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
Param(
|
||||||
|
[parameter(Mandatory=$true)][string]$resourceGroupName,
|
||||||
|
[parameter(Mandatory=$true)][string]$location,
|
||||||
|
[parameter(Mandatory=$true)][string]$serviceName,
|
||||||
|
[parameter(Mandatory=$true)][string]$dnsNamePrefix,
|
||||||
|
[parameter(Mandatory=$false)][string]$registryName,
|
||||||
|
[parameter(Mandatory=$true)][bool]$createAcr=$true,
|
||||||
|
[parameter(Mandatory=$false)][int]$nodeCount=3,
|
||||||
|
[parameter(Mandatory=$false)][string]$nodeVMSize="Standard_D2_v2",
|
||||||
|
[parameter(Mandatory=$false)][bool]$enableHttpApplicationAddon=$true,
|
||||||
|
[parameter(Mandatory=$false)][bool]$enableAzureMonitoring=$false,
|
||||||
|
[parameter(Mandatory=$false)][ValidateSet("VirtualMachineScaleSets","AvailabilitySet",IgnoreCase=$true)]$vmSetType="VirtualMachineScaleSets"
|
||||||
|
)
|
||||||
|
|
||||||
|
# Create resource group
|
||||||
|
Write-Host "Creating Azure Resource Group..." -ForegroundColor Yellow
|
||||||
|
az group create --name=$resourceGroupName --location=$location
|
||||||
|
|
||||||
|
if ($createAcr -eq $true) {
|
||||||
|
# Create Azure Container Registry
|
||||||
|
if ([string]::IsNullOrEmpty($registryName)) {
|
||||||
|
$registryName=$serviceName
|
||||||
|
}
|
||||||
|
Write-Host "Creating Azure Container Registry named $registryName" -ForegroundColor Yellow
|
||||||
|
az acr create -n $registryName -g $resourceGroupName -l $location --admin-enabled true --sku Basic
|
||||||
|
}
|
||||||
|
|
||||||
|
# Create kubernetes cluster in AKS
|
||||||
|
Write-Host "Creating AKS $resourceGroupName/$serviceName" -ForegroundColor Yellow
|
||||||
|
az aks create --resource-group=$resourceGroupName --name=$serviceName --dns-name-prefix=$dnsNamePrefix --generate-ssh-keys --node-count=$nodeCount --node-vm-size=$nodeVMSize --vm-set-type $vmSetType
|
||||||
|
|
||||||
|
if ($enableHttpApplicationAddon) {
|
||||||
|
Write-Host "Enabling Http Applciation Routing in AKS $serviceName" -ForegroundColor Yellow
|
||||||
|
az aks enable-addons --resource-group $resourceGroupName --name $serviceName --addons http_application_routing
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($enableAzureMonitoring) {
|
||||||
|
Write-Host "Enabling Azure Monitoring in AKS $serviceName" -ForegroundColor Yellow
|
||||||
|
az aks enable-addons --resource-group $resourceGroupName --name $serviceName --addons monitoring
|
||||||
|
}
|
||||||
|
|
||||||
|
# Retrieve kubernetes cluster configuration and save it under ~/.kube/config
|
||||||
|
Write-Host "Getting Kubernetes config..." -ForegroundColor Yellow
|
||||||
|
az aks get-credentials --resource-group=$resourceGroupName --name=$serviceName
|
||||||
|
|
||||||
|
if ($createAcr -eq $true) {
|
||||||
|
# Show ACR credentials
|
||||||
|
Write-Host "ACR $registryName credentials:" -ForegroundColor Yellow
|
||||||
|
az acr credential show -n $registryName
|
||||||
|
}
|
18
deploy/k8s/archived/dashboard-adminuser.yaml
Normal file
18
deploy/k8s/archived/dashboard-adminuser.yaml
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
apiVersion: v1
|
||||||
|
kind: ServiceAccount
|
||||||
|
metadata:
|
||||||
|
name: admin-user
|
||||||
|
namespace: kubernetes-dashboard
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: ClusterRoleBinding
|
||||||
|
metadata:
|
||||||
|
name: admin-user
|
||||||
|
roleRef:
|
||||||
|
apiGroup: rbac.authorization.k8s.io
|
||||||
|
kind: ClusterRole
|
||||||
|
name: cluster-admin
|
||||||
|
subjects:
|
||||||
|
- kind: ServiceAccount
|
||||||
|
name: admin-user
|
||||||
|
namespace: kubernetes-dashboard
|
20
deploy/k8s/archived/enable-tls.ps1
Normal file
20
deploy/k8s/archived/enable-tls.ps1
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
Param (
|
||||||
|
[parameter(Mandatory=$false)][string]$aksName="",
|
||||||
|
[parameter(Mandatory=$false)][string]$aksRg=""
|
||||||
|
)
|
||||||
|
|
||||||
|
if ($aksName -and $aksRg) {
|
||||||
|
|
||||||
|
$aks=$(az aks show -n $aksName -g $aksRg -o json | ConvertFrom-Json)
|
||||||
|
if (-not $aks) {
|
||||||
|
Write-Host "AKS $aksName not found in RG $aksRg" -ForegroundColor Red
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
Write-Host "Switching kubectl context to $aksRg/$aksName" -ForegroundColor Yellow
|
||||||
|
az aks get-credentials -g $aksRg -n $aksName
|
||||||
|
}
|
||||||
|
|
||||||
|
Write-Host "Installing cert-manager on current cluster"
|
||||||
|
|
||||||
|
kubectl apply --validate=false -f https://github.com/jetstack/cert-manager/releases/download/v0.11.0/cert-manager.yaml --validate=false
|
18
deploy/k8s/archived/helm-rbac.yaml
Normal file
18
deploy/k8s/archived/helm-rbac.yaml
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
apiVersion: v1
|
||||||
|
kind: ServiceAccount
|
||||||
|
metadata:
|
||||||
|
name: tiller
|
||||||
|
namespace: kube-system
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: ClusterRoleBinding
|
||||||
|
metadata:
|
||||||
|
name: tiller
|
||||||
|
roleRef:
|
||||||
|
apiGroup: rbac.authorization.k8s.io
|
||||||
|
kind: ClusterRole
|
||||||
|
name: cluster-admin
|
||||||
|
subjects:
|
||||||
|
- kind: ServiceAccount
|
||||||
|
name: tiller
|
||||||
|
namespace: kube-system
|
12
deploy/k8s/archived/helm/aks-httpaddon-cfg.yaml
Normal file
12
deploy/k8s/archived/helm/aks-httpaddon-cfg.yaml
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
apiVersion: v1
|
||||||
|
kind: ConfigMap
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
# addonmanager.kubernetes.io/mode: Reconcile
|
||||||
|
app: addon-http-application-routing-ingress-nginx
|
||||||
|
kubernetes.io/cluster-service: "true"
|
||||||
|
name: addon-http-application-routing-nginx-configuration
|
||||||
|
namespace: kube-system
|
||||||
|
data:
|
||||||
|
proxy-buffer-size: "128k"
|
||||||
|
proxy-buffers: "4 256k"
|
21
deploy/k8s/archived/helm/apigwmm/.helmignore
Normal file
21
deploy/k8s/archived/helm/apigwmm/.helmignore
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
# Patterns to ignore when building packages.
|
||||||
|
# This supports shell glob matching, relative path matching, and
|
||||||
|
# negation (prefixed with !). Only one pattern per line.
|
||||||
|
.DS_Store
|
||||||
|
# Common VCS dirs
|
||||||
|
.git/
|
||||||
|
.gitignore
|
||||||
|
.bzr/
|
||||||
|
.bzrignore
|
||||||
|
.hg/
|
||||||
|
.hgignore
|
||||||
|
.svn/
|
||||||
|
# Common backup files
|
||||||
|
*.swp
|
||||||
|
*.bak
|
||||||
|
*.tmp
|
||||||
|
*~
|
||||||
|
# Various IDEs
|
||||||
|
.project
|
||||||
|
.idea/
|
||||||
|
*.tmproj
|
5
deploy/k8s/archived/helm/apigwmm/Chart.yaml
Normal file
5
deploy/k8s/archived/helm/apigwmm/Chart.yaml
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
apiVersion: v1
|
||||||
|
appVersion: "1.0"
|
||||||
|
description: A Helm chart for Kubernetes
|
||||||
|
name: apigwmm
|
||||||
|
version: 0.1.0
|
75
deploy/k8s/archived/helm/apigwmm/envoy.yaml
Normal file
75
deploy/k8s/archived/helm/apigwmm/envoy.yaml
Normal file
@ -0,0 +1,75 @@
|
|||||||
|
admin:
|
||||||
|
access_log_path: "/dev/null"
|
||||||
|
address:
|
||||||
|
socket_address:
|
||||||
|
address: 0.0.0.0
|
||||||
|
port_value: 8001
|
||||||
|
static_resources:
|
||||||
|
listeners:
|
||||||
|
- address:
|
||||||
|
socket_address:
|
||||||
|
address: 0.0.0.0
|
||||||
|
port_value: 80
|
||||||
|
filter_chains:
|
||||||
|
- filters:
|
||||||
|
- name: envoy.http_connection_manager
|
||||||
|
config:
|
||||||
|
codec_type: auto
|
||||||
|
stat_prefix: ingress_http
|
||||||
|
route_config:
|
||||||
|
name: eshop_backend_route
|
||||||
|
virtual_hosts:
|
||||||
|
- name: eshop_backend
|
||||||
|
domains:
|
||||||
|
- "*"
|
||||||
|
routes:
|
||||||
|
- name: "m-short"
|
||||||
|
match:
|
||||||
|
prefix: "/m/"
|
||||||
|
route:
|
||||||
|
auto_host_rewrite: true
|
||||||
|
prefix_rewrite: "/marketing-api/"
|
||||||
|
cluster: marketing
|
||||||
|
- name: "m-long"
|
||||||
|
match:
|
||||||
|
prefix: "/marketing-api/"
|
||||||
|
route:
|
||||||
|
auto_host_rewrite: true
|
||||||
|
cluster: marketing
|
||||||
|
http_filters:
|
||||||
|
- name: envoy.router
|
||||||
|
access_log:
|
||||||
|
- name: envoy.file_access_log
|
||||||
|
filter:
|
||||||
|
not_health_check_filter: {}
|
||||||
|
config:
|
||||||
|
json_format:
|
||||||
|
time: "%START_TIME%"
|
||||||
|
protocol: "%PROTOCOL%"
|
||||||
|
duration: "%DURATION%"
|
||||||
|
request_method: "%REQ(:METHOD)%"
|
||||||
|
request_host: "%REQ(HOST)%"
|
||||||
|
path: "%REQ(X-ENVOY-ORIGINAL-PATH?:PATH)%"
|
||||||
|
response_flags: "%RESPONSE_FLAGS%"
|
||||||
|
route_name: "%ROUTE_NAME%"
|
||||||
|
upstream_host: "%UPSTREAM_HOST%"
|
||||||
|
upstream_cluster: "%UPSTREAM_CLUSTER%"
|
||||||
|
upstream_local_address: "%UPSTREAM_LOCAL_ADDRESS%"
|
||||||
|
path: "/tmp/access.log"
|
||||||
|
clusters:
|
||||||
|
- name: marketing
|
||||||
|
connect_timeout: 0.25s
|
||||||
|
type: logical_dns
|
||||||
|
lb_policy: round_robin
|
||||||
|
hosts:
|
||||||
|
- socket_address:
|
||||||
|
address: marketing-api
|
||||||
|
port_value: 80
|
||||||
|
- name: locations
|
||||||
|
connect_timeout: 0.25s
|
||||||
|
type: logical_dns
|
||||||
|
lb_policy: round_robin
|
||||||
|
hosts:
|
||||||
|
- socket_address:
|
||||||
|
address: locations-api
|
||||||
|
port_value: 80
|
2
deploy/k8s/archived/helm/apigwmm/templates/NOTES.txt
Normal file
2
deploy/k8s/archived/helm/apigwmm/templates/NOTES.txt
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
eShop API Gateway for Mobile Marketing services installed
|
||||||
|
----------------------------------------------------------
|
32
deploy/k8s/archived/helm/apigwmm/templates/_helpers.tpl
Normal file
32
deploy/k8s/archived/helm/apigwmm/templates/_helpers.tpl
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
{{/* vim: set filetype=mustache: */}}
|
||||||
|
{{/*
|
||||||
|
Expand the name of the chart.
|
||||||
|
*/}}
|
||||||
|
{{- define "apigwmm.name" -}}
|
||||||
|
{{- default .Chart.Name .Values.nameOverride | trunc 63 | trimSuffix "-" -}}
|
||||||
|
{{- end -}}
|
||||||
|
|
||||||
|
{{/*
|
||||||
|
Create a default fully qualified app name.
|
||||||
|
We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec).
|
||||||
|
If release name contains chart name it will be used as a full name.
|
||||||
|
*/}}
|
||||||
|
{{- define "apigwmm.fullname" -}}
|
||||||
|
{{- if .Values.fullnameOverride -}}
|
||||||
|
{{- .Values.fullnameOverride | trunc 63 | trimSuffix "-" -}}
|
||||||
|
{{- else -}}
|
||||||
|
{{- $name := default .Chart.Name .Values.nameOverride -}}
|
||||||
|
{{- if contains $name .Release.Name -}}
|
||||||
|
{{- .Release.Name | trunc 63 | trimSuffix "-" -}}
|
||||||
|
{{- else -}}
|
||||||
|
{{- printf "%s-%s" .Release.Name $name | trunc 63 | trimSuffix "-" -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
|
||||||
|
{{/*
|
||||||
|
Create chart name and version as used by the chart label.
|
||||||
|
*/}}
|
||||||
|
{{- define "apigwmm.chart" -}}
|
||||||
|
{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
|
||||||
|
{{- end -}}
|
52
deploy/k8s/archived/helm/apigwmm/templates/_names.tpl
Normal file
52
deploy/k8s/archived/helm/apigwmm/templates/_names.tpl
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
{{- define "suffix-name" -}}
|
||||||
|
{{- if .Values.app.name -}}
|
||||||
|
{{- .Values.app.name -}}
|
||||||
|
{{- else -}}
|
||||||
|
{{- .Release.Name -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
|
||||||
|
{{- define "sql-name" -}}
|
||||||
|
{{- if .Values.inf.sql.host -}}
|
||||||
|
{{- .Values.inf.sql.host -}}
|
||||||
|
{{- else -}}
|
||||||
|
{{- printf "%s" "sql-data" -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
|
||||||
|
{{- define "mongo-name" -}}
|
||||||
|
{{- if .Values.inf.mongo.host -}}
|
||||||
|
{{- .Values.inf.mongo.host -}}
|
||||||
|
{{- else -}}
|
||||||
|
{{- printf "%s" "nosql-data" -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
|
||||||
|
{{- define "url-of" -}}
|
||||||
|
{{- $name := first .}}
|
||||||
|
{{- $ctx := last .}}
|
||||||
|
{{- if eq $name "" -}}
|
||||||
|
{{- $ctx.Values.inf.k8s.dns -}}
|
||||||
|
{{- else -}}
|
||||||
|
{{- printf "%s/%s" $ctx.Values.inf.k8s.dns $name -}} {{/*Value is just <dns>/<name> */}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
{{- define "pathBase" -}}
|
||||||
|
{{- if .Values.inf.k8s.suffix -}}
|
||||||
|
{{- $suffix := include "suffix-name" . -}}
|
||||||
|
{{- printf "%s-%s" .Values.pathBase $suffix -}}
|
||||||
|
{{- else -}}
|
||||||
|
{{- .Values.pathBase -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
|
||||||
|
{{- define "fqdn-image" -}}
|
||||||
|
{{- if .Values.inf.registry -}}
|
||||||
|
{{- printf "%s/%s" .Values.inf.registry.server .Values.image.repository -}}
|
||||||
|
{{- else -}}
|
||||||
|
{{- .Values.image.repository -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
110
deploy/k8s/archived/helm/apigwmm/templates/deployment.yaml
Normal file
110
deploy/k8s/archived/helm/apigwmm/templates/deployment.yaml
Normal file
@ -0,0 +1,110 @@
|
|||||||
|
{{- $name := include "apigwmm.fullname" . -}}
|
||||||
|
{{- $cfgname := printf "%s-%s" "cfg" $name -}}
|
||||||
|
{{- $envoycfgname := printf "%s-%s" "envoy" $name -}}
|
||||||
|
apiVersion: apps/v1beta2
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
name: {{ template "apigwmm.fullname" . }}
|
||||||
|
labels:
|
||||||
|
ufo: {{ $cfgname}}
|
||||||
|
app: {{ template "apigwmm.name" . }}
|
||||||
|
chart: {{ template "apigwmm.chart" . }}
|
||||||
|
release: {{ .Release.Name }}
|
||||||
|
heritage: {{ .Release.Service }}
|
||||||
|
spec:
|
||||||
|
replicas: {{ .Values.replicaCount }}
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: {{ template "apigwmm.name" . }}
|
||||||
|
release: {{ .Release.Name }}
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: {{ template "apigwmm.name" . }}
|
||||||
|
release: {{ .Release.Name }}
|
||||||
|
{{ if .Values.inf.mesh.enabled -}}
|
||||||
|
annotations:
|
||||||
|
linkerd.io/inject: enabled
|
||||||
|
{{- end }}
|
||||||
|
spec:
|
||||||
|
{{ if .Values.inf.registry -}}
|
||||||
|
imagePullSecrets:
|
||||||
|
- name: {{ .Values.inf.registry.secretName }}
|
||||||
|
{{- end }}
|
||||||
|
volumes:
|
||||||
|
- name: config
|
||||||
|
configMap:
|
||||||
|
name: {{ $envoycfgname }}
|
||||||
|
items:
|
||||||
|
- key: envoy.yaml
|
||||||
|
path: envoy.yaml
|
||||||
|
containers:
|
||||||
|
- name: {{ .Chart.Name }}
|
||||||
|
{{ if .Values.probes -}}
|
||||||
|
{{- if .Values.probes.liveness -}}
|
||||||
|
livenessProbe:
|
||||||
|
httpGet:
|
||||||
|
port: {{ .Values.probes.liveness.port }}
|
||||||
|
path: {{ .Values.probes.liveness.path }}
|
||||||
|
initialDelaySeconds: {{ .Values.probes.liveness.initialDelaySeconds }}
|
||||||
|
periodSeconds: {{ .Values.probes.liveness.periodSeconds }}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- if .Values.probes -}}
|
||||||
|
{{- if .Values.probes.readiness }}
|
||||||
|
readinessProbe:
|
||||||
|
httpGet:
|
||||||
|
port: {{ .Values.probes.readiness.port }}
|
||||||
|
path: {{ .Values.probes.readiness.path }}
|
||||||
|
initialDelaySeconds: {{ .Values.probes.readiness.initialDelaySeconds }}
|
||||||
|
periodSeconds: {{ .Values.probes.readiness.periodSeconds }}
|
||||||
|
timeoutSeconds: {{ .Values.probes.readiness.timeoutSeconds }}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end }}
|
||||||
|
image: "{{ template "fqdn-image" . }}:{{ .Values.image.tag }}"
|
||||||
|
imagePullPolicy: IfNotPresent
|
||||||
|
volumeMounts:
|
||||||
|
- name: config
|
||||||
|
mountPath: {{ .Values.envoy.configPath }}
|
||||||
|
env:
|
||||||
|
- name: PATH_BASE
|
||||||
|
value: {{ include "pathBase" . }}
|
||||||
|
- name: k8sname
|
||||||
|
value: {{ .Values.clusterName }}
|
||||||
|
{{- if .Values.env.values -}}
|
||||||
|
{{- range .Values.env.values }}
|
||||||
|
- name: {{ .name }}
|
||||||
|
value: {{ .value | quote }}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- if .Values.env.configmap -}}
|
||||||
|
{{- range .Values.env.configmap }}
|
||||||
|
- name: {{ .name }}
|
||||||
|
valueFrom:
|
||||||
|
configMapKeyRef:
|
||||||
|
name: {{ $cfgname }}
|
||||||
|
key: {{ .key }}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end }}
|
||||||
|
ports:
|
||||||
|
- name: http
|
||||||
|
containerPort: 80
|
||||||
|
protocol: TCP
|
||||||
|
- name: admin
|
||||||
|
containerPort: 8001
|
||||||
|
protocol: TCP
|
||||||
|
resources:
|
||||||
|
{{ toYaml .Values.resources | indent 12 }}
|
||||||
|
{{- with .Values.nodeSelector }}
|
||||||
|
nodeSelector:
|
||||||
|
{{ toYaml . | indent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
{{- with .Values.affinity }}
|
||||||
|
affinity:
|
||||||
|
{{ toYaml . | indent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
{{- with .Values.tolerations }}
|
||||||
|
tolerations:
|
||||||
|
{{ toYaml . | indent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
|
14
deploy/k8s/archived/helm/apigwmm/templates/envoy-cm.yaml
Normal file
14
deploy/k8s/archived/helm/apigwmm/templates/envoy-cm.yaml
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
{{- $name := include "apigwmm.fullname" . -}}
|
||||||
|
|
||||||
|
apiVersion: v1
|
||||||
|
kind: ConfigMap
|
||||||
|
metadata:
|
||||||
|
name: "envoy-{{ $name }}"
|
||||||
|
labels:
|
||||||
|
app: {{ template "apigwmm.name" . }}
|
||||||
|
chart: {{ template "apigwmm.chart" .}}
|
||||||
|
release: {{ .Release.Name }}
|
||||||
|
heritage: {{ .Release.Service }}
|
||||||
|
data:
|
||||||
|
{{ (.Files.Glob "envoy.yaml").AsConfig | indent 2 }}
|
||||||
|
|
46
deploy/k8s/archived/helm/apigwmm/templates/ingress.yaml
Normal file
46
deploy/k8s/archived/helm/apigwmm/templates/ingress.yaml
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
{{- if .Values.ingress.enabled -}}
|
||||||
|
{{- $ingressPath := include "pathBase" . -}}
|
||||||
|
{{- $serviceName := .Values.app.svc.mobilemarketingapigw -}}
|
||||||
|
apiVersion: extensions/v1beta1
|
||||||
|
kind: Ingress
|
||||||
|
metadata:
|
||||||
|
name: {{ template "apigwmm.fullname" . }}
|
||||||
|
labels:
|
||||||
|
app: {{ template "apigwmm.name" . }}
|
||||||
|
chart: {{ template "apigwmm.chart" . }}
|
||||||
|
release: {{ .Release.Name }}
|
||||||
|
heritage: {{ .Release.Service }}
|
||||||
|
{{- with .Values.ingress.annotations }}
|
||||||
|
annotations:
|
||||||
|
{{ toYaml . | indent 4 }}
|
||||||
|
{{- end }}
|
||||||
|
{{- if and .Values.inf.tls.enabled .Values.inf.tls.issuer }}
|
||||||
|
cert-manager.io/issuer: {{ .Values.inf.tls.issuer }}
|
||||||
|
{{- end }}
|
||||||
|
{{- if .Values.inf.mesh.enabled }}
|
||||||
|
{{- with .Values.ingress.mesh.annotations }}
|
||||||
|
{{ toYaml . | indent 4 }}
|
||||||
|
{{- end }}
|
||||||
|
{{- end }}
|
||||||
|
spec:
|
||||||
|
{{- if .Values.ingress.tls }}
|
||||||
|
tls:
|
||||||
|
{{- range .Values.ingress.tls }}
|
||||||
|
- hosts:
|
||||||
|
{{- range .hosts }}
|
||||||
|
- {{ . }}
|
||||||
|
{{- end }}
|
||||||
|
secretName: {{ .secretName }}
|
||||||
|
{{- end }}
|
||||||
|
{{- end }}
|
||||||
|
rules:
|
||||||
|
{{- range .Values.ingress.hosts }}
|
||||||
|
- host: {{ . }}
|
||||||
|
http:
|
||||||
|
paths:
|
||||||
|
- path: {{ $ingressPath }}
|
||||||
|
backend:
|
||||||
|
serviceName: {{ $serviceName }}
|
||||||
|
servicePort: http
|
||||||
|
{{- end }}
|
||||||
|
{{- end }}
|
23
deploy/k8s/archived/helm/apigwmm/templates/service.yaml
Normal file
23
deploy/k8s/archived/helm/apigwmm/templates/service.yaml
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
name: {{ .Values.app.svc.mobilemarketingapigw }}
|
||||||
|
labels:
|
||||||
|
app: {{ template "apigwmm.name" . }}
|
||||||
|
chart: {{ template "apigwmm.chart" . }}
|
||||||
|
release: {{ .Release.Name }}
|
||||||
|
heritage: {{ .Release.Service }}
|
||||||
|
spec:
|
||||||
|
type: {{ .Values.service.type }}
|
||||||
|
ports:
|
||||||
|
- port: {{ .Values.service.port }}
|
||||||
|
targetPort: http
|
||||||
|
protocol: TCP
|
||||||
|
name: http
|
||||||
|
- port: {{ .Values.service.adminPort }}
|
||||||
|
targetPort: admin
|
||||||
|
protocol: TCP
|
||||||
|
name: admin
|
||||||
|
selector:
|
||||||
|
app: {{ template "apigwmm.name" . }}
|
||||||
|
release: {{ .Release.Name }}
|
45
deploy/k8s/archived/helm/apigwmm/values.yaml
Normal file
45
deploy/k8s/archived/helm/apigwmm/values.yaml
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
replicaCount: 1
|
||||||
|
clusterName: eshop-aks
|
||||||
|
pathBase: /mobilemarketingapigw
|
||||||
|
|
||||||
|
image:
|
||||||
|
repository: envoyproxy/envoy
|
||||||
|
tag: v1.11.1
|
||||||
|
|
||||||
|
service:
|
||||||
|
type: ClusterIP
|
||||||
|
port: 80
|
||||||
|
adminPort: 8001
|
||||||
|
|
||||||
|
ingress:
|
||||||
|
enabled: true
|
||||||
|
annotations:
|
||||||
|
nginx.ingress.kubernetes.io/rewrite-target: "/"
|
||||||
|
ingress.kubernetes.io/rewrite-target: "/"
|
||||||
|
tls: []
|
||||||
|
|
||||||
|
resources: {}
|
||||||
|
|
||||||
|
|
||||||
|
nodeSelector: {}
|
||||||
|
|
||||||
|
tolerations: []
|
||||||
|
|
||||||
|
affinity: {}
|
||||||
|
|
||||||
|
env: {}
|
||||||
|
|
||||||
|
envoy:
|
||||||
|
configPath: /etc/envoy
|
||||||
|
|
||||||
|
probes:
|
||||||
|
liveness:
|
||||||
|
path: /ready
|
||||||
|
initialDelaySeconds: 5
|
||||||
|
periodSeconds: 15
|
||||||
|
port: 8001
|
||||||
|
readiness:
|
||||||
|
path: /ready
|
||||||
|
initialDelaySeconds: 5
|
||||||
|
periodSeconds: 60
|
||||||
|
port: 8001
|
21
deploy/k8s/archived/helm/apigwms/.helmignore
Normal file
21
deploy/k8s/archived/helm/apigwms/.helmignore
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
# Patterns to ignore when building packages.
|
||||||
|
# This supports shell glob matching, relative path matching, and
|
||||||
|
# negation (prefixed with !). Only one pattern per line.
|
||||||
|
.DS_Store
|
||||||
|
# Common VCS dirs
|
||||||
|
.git/
|
||||||
|
.gitignore
|
||||||
|
.bzr/
|
||||||
|
.bzrignore
|
||||||
|
.hg/
|
||||||
|
.hgignore
|
||||||
|
.svn/
|
||||||
|
# Common backup files
|
||||||
|
*.swp
|
||||||
|
*.bak
|
||||||
|
*.tmp
|
||||||
|
*~
|
||||||
|
# Various IDEs
|
||||||
|
.project
|
||||||
|
.idea/
|
||||||
|
*.tmproj
|
5
deploy/k8s/archived/helm/apigwms/Chart.yaml
Normal file
5
deploy/k8s/archived/helm/apigwms/Chart.yaml
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
apiVersion: v1
|
||||||
|
appVersion: "1.0"
|
||||||
|
description: A Helm chart for Kubernetes
|
||||||
|
name: apigwms
|
||||||
|
version: 0.1.0
|
139
deploy/k8s/archived/helm/apigwms/envoy.yaml
Normal file
139
deploy/k8s/archived/helm/apigwms/envoy.yaml
Normal file
@ -0,0 +1,139 @@
|
|||||||
|
admin:
|
||||||
|
access_log_path: "/dev/null"
|
||||||
|
address:
|
||||||
|
socket_address:
|
||||||
|
address: 0.0.0.0
|
||||||
|
port_value: 8001
|
||||||
|
static_resources:
|
||||||
|
listeners:
|
||||||
|
- address:
|
||||||
|
socket_address:
|
||||||
|
address: 0.0.0.0
|
||||||
|
port_value: 80
|
||||||
|
filter_chains:
|
||||||
|
- filters:
|
||||||
|
- name: envoy.http_connection_manager
|
||||||
|
config:
|
||||||
|
codec_type: auto
|
||||||
|
stat_prefix: ingress_http
|
||||||
|
route_config:
|
||||||
|
name: eshop_backend_route
|
||||||
|
virtual_hosts:
|
||||||
|
- name: eshop_backend
|
||||||
|
domains:
|
||||||
|
- "*"
|
||||||
|
routes:
|
||||||
|
- name: "c-short"
|
||||||
|
match:
|
||||||
|
prefix: "/c/"
|
||||||
|
route:
|
||||||
|
auto_host_rewrite: true
|
||||||
|
prefix_rewrite: "/catalog-api/"
|
||||||
|
cluster: catalog
|
||||||
|
- name: "c-long"
|
||||||
|
match:
|
||||||
|
prefix: "/catalog-api/"
|
||||||
|
route:
|
||||||
|
auto_host_rewrite: true
|
||||||
|
cluster: catalog
|
||||||
|
- name: "o-short"
|
||||||
|
match:
|
||||||
|
prefix: "/o/"
|
||||||
|
route:
|
||||||
|
auto_host_rewrite: true
|
||||||
|
prefix_rewrite: "/ordering-api/"
|
||||||
|
cluster: ordering
|
||||||
|
- name: "o-long"
|
||||||
|
match:
|
||||||
|
prefix: "/ordering-api/"
|
||||||
|
route:
|
||||||
|
auto_host_rewrite: true
|
||||||
|
cluster: ordering
|
||||||
|
- name: "h-long"
|
||||||
|
match:
|
||||||
|
prefix: "/hub/notificationhub"
|
||||||
|
route:
|
||||||
|
auto_host_rewrite: true
|
||||||
|
cluster: signalr-hub
|
||||||
|
timeout: 300s
|
||||||
|
- name: "b-short"
|
||||||
|
match:
|
||||||
|
prefix: "/b/"
|
||||||
|
route:
|
||||||
|
auto_host_rewrite: true
|
||||||
|
prefix_rewrite: "/basket-api/"
|
||||||
|
cluster: basket
|
||||||
|
- name: "b-long"
|
||||||
|
match:
|
||||||
|
prefix: "/basket-api/"
|
||||||
|
route:
|
||||||
|
auto_host_rewrite: true
|
||||||
|
cluster: basket
|
||||||
|
- name: "agg"
|
||||||
|
match:
|
||||||
|
prefix: "/"
|
||||||
|
route:
|
||||||
|
auto_host_rewrite: true
|
||||||
|
prefix_rewrite: "/"
|
||||||
|
cluster: shoppingagg
|
||||||
|
http_filters:
|
||||||
|
- name: envoy.router
|
||||||
|
access_log:
|
||||||
|
- name: envoy.file_access_log
|
||||||
|
filter:
|
||||||
|
not_health_check_filter: {}
|
||||||
|
config:
|
||||||
|
json_format:
|
||||||
|
time: "%START_TIME%"
|
||||||
|
protocol: "%PROTOCOL%"
|
||||||
|
duration: "%DURATION%"
|
||||||
|
request_method: "%REQ(:METHOD)%"
|
||||||
|
request_host: "%REQ(HOST)%"
|
||||||
|
path: "%REQ(X-ENVOY-ORIGINAL-PATH?:PATH)%"
|
||||||
|
response_flags: "%RESPONSE_FLAGS%"
|
||||||
|
route_name: "%ROUTE_NAME%"
|
||||||
|
upstream_host: "%UPSTREAM_HOST%"
|
||||||
|
upstream_cluster: "%UPSTREAM_CLUSTER%"
|
||||||
|
upstream_local_address: "%UPSTREAM_LOCAL_ADDRESS%"
|
||||||
|
path: "/tmp/access.log"
|
||||||
|
clusters:
|
||||||
|
- name: shoppingagg
|
||||||
|
connect_timeout: 0.25s
|
||||||
|
type: strict_dns
|
||||||
|
lb_policy: round_robin
|
||||||
|
hosts:
|
||||||
|
- socket_address:
|
||||||
|
address: webshoppingagg
|
||||||
|
port_value: 80
|
||||||
|
- name: catalog
|
||||||
|
connect_timeout: 0.25s
|
||||||
|
type: strict_dns
|
||||||
|
lb_policy: round_robin
|
||||||
|
hosts:
|
||||||
|
- socket_address:
|
||||||
|
address: catalog-api
|
||||||
|
port_value: 80
|
||||||
|
- name: basket
|
||||||
|
connect_timeout: 0.25s
|
||||||
|
type: strict_dns
|
||||||
|
lb_policy: round_robin
|
||||||
|
hosts:
|
||||||
|
- socket_address:
|
||||||
|
address: basket-api
|
||||||
|
port_value: 80
|
||||||
|
- name: ordering
|
||||||
|
connect_timeout: 0.25s
|
||||||
|
type: strict_dns
|
||||||
|
lb_policy: round_robin
|
||||||
|
hosts:
|
||||||
|
- socket_address:
|
||||||
|
address: ordering-api
|
||||||
|
port_value: 80
|
||||||
|
- name: signalr-hub
|
||||||
|
connect_timeout: 0.25s
|
||||||
|
type: strict_dns
|
||||||
|
lb_policy: round_robin
|
||||||
|
hosts:
|
||||||
|
- socket_address:
|
||||||
|
address: ordering-signalrhub
|
||||||
|
port_value: 80
|
2
deploy/k8s/archived/helm/apigwms/templates/NOTES.txt
Normal file
2
deploy/k8s/archived/helm/apigwms/templates/NOTES.txt
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
eShop API Gateway for Mobile Shopping services installed
|
||||||
|
--------------------------------------------------------
|
32
deploy/k8s/archived/helm/apigwms/templates/_helpers.tpl
Normal file
32
deploy/k8s/archived/helm/apigwms/templates/_helpers.tpl
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
{{/* vim: set filetype=mustache: */}}
|
||||||
|
{{/*
|
||||||
|
Expand the name of the chart.
|
||||||
|
*/}}
|
||||||
|
{{- define "apigwms.name" -}}
|
||||||
|
{{- default .Chart.Name .Values.nameOverride | trunc 63 | trimSuffix "-" -}}
|
||||||
|
{{- end -}}
|
||||||
|
|
||||||
|
{{/*
|
||||||
|
Create a default fully qualified app name.
|
||||||
|
We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec).
|
||||||
|
If release name contains chart name it will be used as a full name.
|
||||||
|
*/}}
|
||||||
|
{{- define "apigwms.fullname" -}}
|
||||||
|
{{- if .Values.fullnameOverride -}}
|
||||||
|
{{- .Values.fullnameOverride | trunc 63 | trimSuffix "-" -}}
|
||||||
|
{{- else -}}
|
||||||
|
{{- $name := default .Chart.Name .Values.nameOverride -}}
|
||||||
|
{{- if contains $name .Release.Name -}}
|
||||||
|
{{- .Release.Name | trunc 63 | trimSuffix "-" -}}
|
||||||
|
{{- else -}}
|
||||||
|
{{- printf "%s-%s" .Release.Name $name | trunc 63 | trimSuffix "-" -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
|
||||||
|
{{/*
|
||||||
|
Create chart name and version as used by the chart label.
|
||||||
|
*/}}
|
||||||
|
{{- define "apigwms.chart" -}}
|
||||||
|
{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
|
||||||
|
{{- end -}}
|
52
deploy/k8s/archived/helm/apigwms/templates/_names.tpl
Normal file
52
deploy/k8s/archived/helm/apigwms/templates/_names.tpl
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
{{- define "suffix-name" -}}
|
||||||
|
{{- if .Values.app.name -}}
|
||||||
|
{{- .Values.app.name -}}
|
||||||
|
{{- else -}}
|
||||||
|
{{- .Release.Name -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
|
||||||
|
{{- define "sql-name" -}}
|
||||||
|
{{- if .Values.inf.sql.host -}}
|
||||||
|
{{- .Values.inf.sql.host -}}
|
||||||
|
{{- else -}}
|
||||||
|
{{- printf "%s" "sql-data" -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
|
||||||
|
{{- define "mongo-name" -}}
|
||||||
|
{{- if .Values.inf.mongo.host -}}
|
||||||
|
{{- .Values.inf.mongo.host -}}
|
||||||
|
{{- else -}}
|
||||||
|
{{- printf "%s" "nosql-data" -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
|
||||||
|
{{- define "url-of" -}}
|
||||||
|
{{- $name := first .}}
|
||||||
|
{{- $ctx := last .}}
|
||||||
|
{{- if eq $name "" -}}
|
||||||
|
{{- $ctx.Values.inf.k8s.dns -}}
|
||||||
|
{{- else -}}
|
||||||
|
{{- printf "%s/%s" $ctx.Values.inf.k8s.dns $name -}} {{/*Value is just <dns>/<name> */}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
{{- define "pathBase" -}}
|
||||||
|
{{- if .Values.inf.k8s.suffix -}}
|
||||||
|
{{- $suffix := include "suffix-name" . -}}
|
||||||
|
{{- printf "%s-%s" .Values.pathBase $suffix -}}
|
||||||
|
{{- else -}}
|
||||||
|
{{- .Values.pathBase -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
|
||||||
|
{{- define "fqdn-image" -}}
|
||||||
|
{{- if .Values.inf.registry -}}
|
||||||
|
{{- printf "%s/%s" .Values.inf.registry.server .Values.image.repository -}}
|
||||||
|
{{- else -}}
|
||||||
|
{{- .Values.image.repository -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
110
deploy/k8s/archived/helm/apigwms/templates/deployment.yaml
Normal file
110
deploy/k8s/archived/helm/apigwms/templates/deployment.yaml
Normal file
@ -0,0 +1,110 @@
|
|||||||
|
{{- $name := include "apigwms.fullname" . -}}
|
||||||
|
{{- $cfgname := printf "%s-%s" "cfg" $name -}}
|
||||||
|
{{- $envoycfgname := printf "%s-%s" "envoy" $name -}}
|
||||||
|
apiVersion: apps/v1beta2
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
name: {{ template "apigwms.fullname" . }}
|
||||||
|
labels:
|
||||||
|
ufo: {{ $cfgname}}
|
||||||
|
app: {{ template "apigwms.name" . }}
|
||||||
|
chart: {{ template "apigwms.chart" . }}
|
||||||
|
release: {{ .Release.Name }}
|
||||||
|
heritage: {{ .Release.Service }}
|
||||||
|
spec:
|
||||||
|
replicas: {{ .Values.replicaCount }}
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: {{ template "apigwms.name" . }}
|
||||||
|
release: {{ .Release.Name }}
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: {{ template "apigwms.name" . }}
|
||||||
|
release: {{ .Release.Name }}
|
||||||
|
{{ if .Values.inf.mesh.enabled -}}
|
||||||
|
annotations:
|
||||||
|
linkerd.io/inject: enabled
|
||||||
|
{{- end }}
|
||||||
|
spec:
|
||||||
|
{{ if .Values.inf.registry -}}
|
||||||
|
imagePullSecrets:
|
||||||
|
- name: {{ .Values.inf.registry.secretName }}
|
||||||
|
{{- end }}
|
||||||
|
volumes:
|
||||||
|
- name: config
|
||||||
|
configMap:
|
||||||
|
name: {{ $envoycfgname }}
|
||||||
|
items:
|
||||||
|
- key: envoy.yaml
|
||||||
|
path: envoy.yaml
|
||||||
|
containers:
|
||||||
|
- name: {{ .Chart.Name }}
|
||||||
|
{{ if .Values.probes -}}
|
||||||
|
{{- if .Values.probes.liveness -}}
|
||||||
|
livenessProbe:
|
||||||
|
httpGet:
|
||||||
|
port: {{ .Values.probes.liveness.port }}
|
||||||
|
path: {{ .Values.probes.liveness.path }}
|
||||||
|
initialDelaySeconds: {{ .Values.probes.liveness.initialDelaySeconds }}
|
||||||
|
periodSeconds: {{ .Values.probes.liveness.periodSeconds }}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- if .Values.probes -}}
|
||||||
|
{{- if .Values.probes.readiness }}
|
||||||
|
readinessProbe:
|
||||||
|
httpGet:
|
||||||
|
port: {{ .Values.probes.readiness.port }}
|
||||||
|
path: {{ .Values.probes.readiness.path }}
|
||||||
|
initialDelaySeconds: {{ .Values.probes.readiness.initialDelaySeconds }}
|
||||||
|
periodSeconds: {{ .Values.probes.readiness.periodSeconds }}
|
||||||
|
timeoutSeconds: {{ .Values.probes.readiness.timeoutSeconds }}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end }}
|
||||||
|
image: "{{ template "fqdn-image" . }}:{{ .Values.image.tag }}"
|
||||||
|
imagePullPolicy: IfNotPresent
|
||||||
|
volumeMounts:
|
||||||
|
- name: config
|
||||||
|
mountPath: {{ .Values.envoy.configPath }}
|
||||||
|
env:
|
||||||
|
- name: PATH_BASE
|
||||||
|
value: {{ include "pathBase" . }}
|
||||||
|
- name: k8sname
|
||||||
|
value: {{ .Values.clusterName }}
|
||||||
|
{{- if .Values.env.values -}}
|
||||||
|
{{- range .Values.env.values }}
|
||||||
|
- name: {{ .name }}
|
||||||
|
value: {{ .value | quote }}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- if .Values.env.configmap -}}
|
||||||
|
{{- range .Values.env.configmap }}
|
||||||
|
- name: {{ .name }}
|
||||||
|
valueFrom:
|
||||||
|
configMapKeyRef:
|
||||||
|
name: {{ $cfgname }}
|
||||||
|
key: {{ .key }}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end }}
|
||||||
|
ports:
|
||||||
|
- name: http
|
||||||
|
containerPort: 80
|
||||||
|
protocol: TCP
|
||||||
|
- name: admin
|
||||||
|
containerPort: 8001
|
||||||
|
protocol: TCP
|
||||||
|
resources:
|
||||||
|
{{ toYaml .Values.resources | indent 12 }}
|
||||||
|
{{- with .Values.nodeSelector }}
|
||||||
|
nodeSelector:
|
||||||
|
{{ toYaml . | indent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
{{- with .Values.affinity }}
|
||||||
|
affinity:
|
||||||
|
{{ toYaml . | indent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
{{- with .Values.tolerations }}
|
||||||
|
tolerations:
|
||||||
|
{{ toYaml . | indent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
|
14
deploy/k8s/archived/helm/apigwms/templates/envoy-cm.yaml
Normal file
14
deploy/k8s/archived/helm/apigwms/templates/envoy-cm.yaml
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
{{- $name := include "apigwms.fullname" . -}}
|
||||||
|
|
||||||
|
apiVersion: v1
|
||||||
|
kind: ConfigMap
|
||||||
|
metadata:
|
||||||
|
name: "envoy-{{ $name }}"
|
||||||
|
labels:
|
||||||
|
app: {{ template "apigwms.name" . }}
|
||||||
|
chart: {{ template "apigwms.chart" .}}
|
||||||
|
release: {{ .Release.Name }}
|
||||||
|
heritage: {{ .Release.Service }}
|
||||||
|
data:
|
||||||
|
{{ (.Files.Glob "envoy.yaml").AsConfig | indent 2 }}
|
||||||
|
|
47
deploy/k8s/archived/helm/apigwms/templates/ingress.yaml
Normal file
47
deploy/k8s/archived/helm/apigwms/templates/ingress.yaml
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
{{- if .Values.ingress.enabled -}}
|
||||||
|
{{- $ingressPath := include "pathBase" . -}}
|
||||||
|
{{- $serviceName := .Values.app.svc.mobileshoppingapigw -}}
|
||||||
|
|
||||||
|
apiVersion: extensions/v1beta1
|
||||||
|
kind: Ingress
|
||||||
|
metadata:
|
||||||
|
name: {{ template "apigwms.fullname" . }}
|
||||||
|
labels:
|
||||||
|
app: {{ template "apigwms.name" . }}
|
||||||
|
chart: {{ template "apigwms.chart" . }}
|
||||||
|
release: {{ .Release.Name }}
|
||||||
|
heritage: {{ .Release.Service }}
|
||||||
|
{{- with .Values.ingress.annotations }}
|
||||||
|
annotations:
|
||||||
|
{{ toYaml . | indent 4 }}
|
||||||
|
{{- end }}
|
||||||
|
{{- if and .Values.inf.tls.enabled .Values.inf.tls.issuer }}
|
||||||
|
cert-manager.io/issuer: {{ .Values.inf.tls.issuer }}
|
||||||
|
{{- end }}
|
||||||
|
{{- if .Values.inf.mesh.enabled }}
|
||||||
|
{{- with .Values.ingress.mesh.annotations }}
|
||||||
|
{{ toYaml . | indent 4 }}
|
||||||
|
{{- end }}
|
||||||
|
{{- end }}
|
||||||
|
spec:
|
||||||
|
{{- if .Values.ingress.tls }}
|
||||||
|
tls:
|
||||||
|
{{- range .Values.ingress.tls }}
|
||||||
|
- hosts:
|
||||||
|
{{- range .hosts }}
|
||||||
|
- {{ . }}
|
||||||
|
{{- end }}
|
||||||
|
secretName: {{ .secretName }}
|
||||||
|
{{- end }}
|
||||||
|
{{- end }}
|
||||||
|
rules:
|
||||||
|
{{- range .Values.ingress.hosts }}
|
||||||
|
- host: {{ . }}
|
||||||
|
http:
|
||||||
|
paths:
|
||||||
|
- path: {{ $ingressPath }}
|
||||||
|
backend:
|
||||||
|
serviceName: {{ $serviceName }}
|
||||||
|
servicePort: http
|
||||||
|
{{- end }}
|
||||||
|
{{- end }}
|
23
deploy/k8s/archived/helm/apigwms/templates/service.yaml
Normal file
23
deploy/k8s/archived/helm/apigwms/templates/service.yaml
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
name: {{ .Values.app.svc.mobileshoppingapigw }}
|
||||||
|
labels:
|
||||||
|
app: {{ template "apigwms.name" . }}
|
||||||
|
chart: {{ template "apigwms.chart" . }}
|
||||||
|
release: {{ .Release.Name }}
|
||||||
|
heritage: {{ .Release.Service }}
|
||||||
|
spec:
|
||||||
|
type: {{ .Values.service.type }}
|
||||||
|
ports:
|
||||||
|
- port: {{ .Values.service.port }}
|
||||||
|
targetPort: http
|
||||||
|
protocol: TCP
|
||||||
|
name: http
|
||||||
|
- port: {{ .Values.service.adminPort }}
|
||||||
|
targetPort: admin
|
||||||
|
protocol: TCP
|
||||||
|
name: admin
|
||||||
|
selector:
|
||||||
|
app: {{ template "apigwms.name" . }}
|
||||||
|
release: {{ .Release.Name }}
|
45
deploy/k8s/archived/helm/apigwms/values.yaml
Normal file
45
deploy/k8s/archived/helm/apigwms/values.yaml
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
replicaCount: 1
|
||||||
|
clusterName: eshop-aks
|
||||||
|
pathBase: /mobileshoppingapigw
|
||||||
|
|
||||||
|
image:
|
||||||
|
repository: envoyproxy/envoy
|
||||||
|
tag: v1.11.1
|
||||||
|
|
||||||
|
service:
|
||||||
|
type: ClusterIP
|
||||||
|
port: 80
|
||||||
|
adminPort: 8001
|
||||||
|
|
||||||
|
ingress:
|
||||||
|
enabled: true
|
||||||
|
annotations:
|
||||||
|
nginx.ingress.kubernetes.io/rewrite-target: "/"
|
||||||
|
ingress.kubernetes.io/rewrite-target: "/"
|
||||||
|
tls: []
|
||||||
|
|
||||||
|
resources: {}
|
||||||
|
|
||||||
|
|
||||||
|
nodeSelector: {}
|
||||||
|
|
||||||
|
tolerations: []
|
||||||
|
|
||||||
|
affinity: {}
|
||||||
|
|
||||||
|
env: {}
|
||||||
|
|
||||||
|
envoy:
|
||||||
|
configPath: /etc/envoy
|
||||||
|
|
||||||
|
probes:
|
||||||
|
liveness:
|
||||||
|
path: /ready
|
||||||
|
initialDelaySeconds: 5
|
||||||
|
periodSeconds: 15
|
||||||
|
port: 8001
|
||||||
|
readiness:
|
||||||
|
path: /ready
|
||||||
|
initialDelaySeconds: 5
|
||||||
|
periodSeconds: 60
|
||||||
|
port: 8001
|
21
deploy/k8s/archived/helm/apigwwm/.helmignore
Normal file
21
deploy/k8s/archived/helm/apigwwm/.helmignore
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
# Patterns to ignore when building packages.
|
||||||
|
# This supports shell glob matching, relative path matching, and
|
||||||
|
# negation (prefixed with !). Only one pattern per line.
|
||||||
|
.DS_Store
|
||||||
|
# Common VCS dirs
|
||||||
|
.git/
|
||||||
|
.gitignore
|
||||||
|
.bzr/
|
||||||
|
.bzrignore
|
||||||
|
.hg/
|
||||||
|
.hgignore
|
||||||
|
.svn/
|
||||||
|
# Common backup files
|
||||||
|
*.swp
|
||||||
|
*.bak
|
||||||
|
*.tmp
|
||||||
|
*~
|
||||||
|
# Various IDEs
|
||||||
|
.project
|
||||||
|
.idea/
|
||||||
|
*.tmproj
|
5
deploy/k8s/archived/helm/apigwwm/Chart.yaml
Normal file
5
deploy/k8s/archived/helm/apigwwm/Chart.yaml
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
apiVersion: v1
|
||||||
|
appVersion: "1.0"
|
||||||
|
description: A Helm chart for Kubernetes
|
||||||
|
name: apigwwm
|
||||||
|
version: 0.1.0
|
75
deploy/k8s/archived/helm/apigwwm/envoy.yaml
Normal file
75
deploy/k8s/archived/helm/apigwwm/envoy.yaml
Normal file
@ -0,0 +1,75 @@
|
|||||||
|
admin:
|
||||||
|
access_log_path: "/dev/null"
|
||||||
|
address:
|
||||||
|
socket_address:
|
||||||
|
address: 0.0.0.0
|
||||||
|
port_value: 8001
|
||||||
|
static_resources:
|
||||||
|
listeners:
|
||||||
|
- address:
|
||||||
|
socket_address:
|
||||||
|
address: 0.0.0.0
|
||||||
|
port_value: 80
|
||||||
|
filter_chains:
|
||||||
|
- filters:
|
||||||
|
- name: envoy.http_connection_manager
|
||||||
|
config:
|
||||||
|
codec_type: auto
|
||||||
|
stat_prefix: ingress_http
|
||||||
|
route_config:
|
||||||
|
name: eshop_backend_route
|
||||||
|
virtual_hosts:
|
||||||
|
- name: eshop_backend
|
||||||
|
domains:
|
||||||
|
- "*"
|
||||||
|
routes:
|
||||||
|
- name: "m-short"
|
||||||
|
match:
|
||||||
|
prefix: "/m/"
|
||||||
|
route:
|
||||||
|
auto_host_rewrite: true
|
||||||
|
prefix_rewrite: "/marketing-api/"
|
||||||
|
cluster: marketing
|
||||||
|
- name: "m-long"
|
||||||
|
match:
|
||||||
|
prefix: "/marketing-api/"
|
||||||
|
route:
|
||||||
|
auto_host_rewrite: true
|
||||||
|
cluster: marketing
|
||||||
|
http_filters:
|
||||||
|
- name: envoy.router
|
||||||
|
access_log:
|
||||||
|
- name: envoy.file_access_log
|
||||||
|
filter:
|
||||||
|
not_health_check_filter: {}
|
||||||
|
config:
|
||||||
|
json_format:
|
||||||
|
time: "%START_TIME%"
|
||||||
|
protocol: "%PROTOCOL%"
|
||||||
|
duration: "%DURATION%"
|
||||||
|
request_method: "%REQ(:METHOD)%"
|
||||||
|
request_host: "%REQ(HOST)%"
|
||||||
|
path: "%REQ(X-ENVOY-ORIGINAL-PATH?:PATH)%"
|
||||||
|
response_flags: "%RESPONSE_FLAGS%"
|
||||||
|
route_name: "%ROUTE_NAME%"
|
||||||
|
upstream_host: "%UPSTREAM_HOST%"
|
||||||
|
upstream_cluster: "%UPSTREAM_CLUSTER%"
|
||||||
|
upstream_local_address: "%UPSTREAM_LOCAL_ADDRESS%"
|
||||||
|
path: "/tmp/access.log"
|
||||||
|
clusters:
|
||||||
|
- name: marketing
|
||||||
|
connect_timeout: 0.25s
|
||||||
|
type: strict_dns
|
||||||
|
lb_policy: round_robin
|
||||||
|
hosts:
|
||||||
|
- socket_address:
|
||||||
|
address: marketing-api
|
||||||
|
port_value: 80
|
||||||
|
- name: locations
|
||||||
|
connect_timeout: 0.25s
|
||||||
|
type: strict_dns
|
||||||
|
lb_policy: round_robin
|
||||||
|
hosts:
|
||||||
|
- socket_address:
|
||||||
|
address: locations-api
|
||||||
|
port_value: 80
|
2
deploy/k8s/archived/helm/apigwwm/templates/NOTES.txt
Normal file
2
deploy/k8s/archived/helm/apigwwm/templates/NOTES.txt
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
eShop API Gateway for Web Marketing services installed
|
||||||
|
------------------------------------------------------
|
32
deploy/k8s/archived/helm/apigwwm/templates/_helpers.tpl
Normal file
32
deploy/k8s/archived/helm/apigwwm/templates/_helpers.tpl
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
{{/* vim: set filetype=mustache: */}}
|
||||||
|
{{/*
|
||||||
|
Expand the name of the chart.
|
||||||
|
*/}}
|
||||||
|
{{- define "apigwwm.name" -}}
|
||||||
|
{{- default .Chart.Name .Values.nameOverride | trunc 63 | trimSuffix "-" -}}
|
||||||
|
{{- end -}}
|
||||||
|
|
||||||
|
{{/*
|
||||||
|
Create a default fully qualified app name.
|
||||||
|
We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec).
|
||||||
|
If release name contains chart name it will be used as a full name.
|
||||||
|
*/}}
|
||||||
|
{{- define "apigwwm.fullname" -}}
|
||||||
|
{{- if .Values.fullnameOverride -}}
|
||||||
|
{{- .Values.fullnameOverride | trunc 63 | trimSuffix "-" -}}
|
||||||
|
{{- else -}}
|
||||||
|
{{- $name := default .Chart.Name .Values.nameOverride -}}
|
||||||
|
{{- if contains $name .Release.Name -}}
|
||||||
|
{{- .Release.Name | trunc 63 | trimSuffix "-" -}}
|
||||||
|
{{- else -}}
|
||||||
|
{{- printf "%s-%s" .Release.Name $name | trunc 63 | trimSuffix "-" -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
|
||||||
|
{{/*
|
||||||
|
Create chart name and version as used by the chart label.
|
||||||
|
*/}}
|
||||||
|
{{- define "apigwwm.chart" -}}
|
||||||
|
{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
|
||||||
|
{{- end -}}
|
52
deploy/k8s/archived/helm/apigwwm/templates/_names.tpl
Normal file
52
deploy/k8s/archived/helm/apigwwm/templates/_names.tpl
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
{{- define "suffix-name" -}}
|
||||||
|
{{- if .Values.app.name -}}
|
||||||
|
{{- .Values.app.name -}}
|
||||||
|
{{- else -}}
|
||||||
|
{{- .Release.Name -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
|
||||||
|
{{- define "sql-name" -}}
|
||||||
|
{{- if .Values.inf.sql.host -}}
|
||||||
|
{{- .Values.inf.sql.host -}}
|
||||||
|
{{- else -}}
|
||||||
|
{{- printf "%s" "sql-data" -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
|
||||||
|
{{- define "mongo-name" -}}
|
||||||
|
{{- if .Values.inf.mongo.host -}}
|
||||||
|
{{- .Values.inf.mongo.host -}}
|
||||||
|
{{- else -}}
|
||||||
|
{{- printf "%s" "nosql-data" -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
|
||||||
|
{{- define "url-of" -}}
|
||||||
|
{{- $name := first .}}
|
||||||
|
{{- $ctx := last .}}
|
||||||
|
{{- if eq $name "" -}}
|
||||||
|
{{- $ctx.Values.inf.k8s.dns -}}
|
||||||
|
{{- else -}}
|
||||||
|
{{- printf "%s/%s" $ctx.Values.inf.k8s.dns $name -}} {{/*Value is just <dns>/<name> */}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
{{- define "pathBase" -}}
|
||||||
|
{{- if .Values.inf.k8s.suffix -}}
|
||||||
|
{{- $suffix := include "suffix-name" . -}}
|
||||||
|
{{- printf "%s-%s" .Values.pathBase $suffix -}}
|
||||||
|
{{- else -}}
|
||||||
|
{{- .Values.pathBase -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
|
||||||
|
{{- define "fqdn-image" -}}
|
||||||
|
{{- if .Values.inf.registry -}}
|
||||||
|
{{- printf "%s/%s" .Values.inf.registry.server .Values.image.repository -}}
|
||||||
|
{{- else -}}
|
||||||
|
{{- .Values.image.repository -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
110
deploy/k8s/archived/helm/apigwwm/templates/deployment.yaml
Normal file
110
deploy/k8s/archived/helm/apigwwm/templates/deployment.yaml
Normal file
@ -0,0 +1,110 @@
|
|||||||
|
{{- $name := include "apigwwm.fullname" . -}}
|
||||||
|
{{- $cfgname := printf "%s-%s" "cfg" $name -}}
|
||||||
|
{{- $envoycfgname := printf "%s-%s" "envoy" $name -}}
|
||||||
|
apiVersion: apps/v1beta2
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
name: {{ template "apigwwm.fullname" . }}
|
||||||
|
labels:
|
||||||
|
ufo: {{ $cfgname}}
|
||||||
|
app: {{ template "apigwwm.name" . }}
|
||||||
|
chart: {{ template "apigwwm.chart" . }}
|
||||||
|
release: {{ .Release.Name }}
|
||||||
|
heritage: {{ .Release.Service }}
|
||||||
|
spec:
|
||||||
|
replicas: {{ .Values.replicaCount }}
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: {{ template "apigwwm.name" . }}
|
||||||
|
release: {{ .Release.Name }}
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: {{ template "apigwwm.name" . }}
|
||||||
|
release: {{ .Release.Name }}
|
||||||
|
{{ if .Values.inf.mesh.enabled -}}
|
||||||
|
annotations:
|
||||||
|
linkerd.io/inject: enabled
|
||||||
|
{{- end }}
|
||||||
|
spec:
|
||||||
|
{{ if .Values.inf.registry -}}
|
||||||
|
imagePullSecrets:
|
||||||
|
- name: {{ .Values.inf.registry.secretName }}
|
||||||
|
{{- end }}
|
||||||
|
volumes:
|
||||||
|
- name: config
|
||||||
|
configMap:
|
||||||
|
name: {{ $envoycfgname }}
|
||||||
|
items:
|
||||||
|
- key: envoy.yaml
|
||||||
|
path: envoy.yaml
|
||||||
|
containers:
|
||||||
|
- name: {{ .Chart.Name }}
|
||||||
|
{{ if .Values.probes -}}
|
||||||
|
{{- if .Values.probes.liveness -}}
|
||||||
|
livenessProbe:
|
||||||
|
httpGet:
|
||||||
|
port: {{ .Values.probes.liveness.port }}
|
||||||
|
path: {{ .Values.probes.liveness.path }}
|
||||||
|
initialDelaySeconds: {{ .Values.probes.liveness.initialDelaySeconds }}
|
||||||
|
periodSeconds: {{ .Values.probes.liveness.periodSeconds }}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- if .Values.probes -}}
|
||||||
|
{{- if .Values.probes.readiness }}
|
||||||
|
readinessProbe:
|
||||||
|
httpGet:
|
||||||
|
port: {{ .Values.probes.readiness.port }}
|
||||||
|
path: {{ .Values.probes.readiness.path }}
|
||||||
|
initialDelaySeconds: {{ .Values.probes.readiness.initialDelaySeconds }}
|
||||||
|
periodSeconds: {{ .Values.probes.readiness.periodSeconds }}
|
||||||
|
timeoutSeconds: {{ .Values.probes.readiness.timeoutSeconds }}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end }}
|
||||||
|
image: "{{ template "fqdn-image" . }}:{{ .Values.image.tag }}"
|
||||||
|
imagePullPolicy: IfNotPresent
|
||||||
|
volumeMounts:
|
||||||
|
- name: config
|
||||||
|
mountPath: {{ .Values.envoy.configPath }}
|
||||||
|
env:
|
||||||
|
- name: PATH_BASE
|
||||||
|
value: {{ include "pathBase" . }}
|
||||||
|
- name: k8sname
|
||||||
|
value: {{ .Values.clusterName }}
|
||||||
|
{{- if .Values.env.values -}}
|
||||||
|
{{- range .Values.env.values }}
|
||||||
|
- name: {{ .name }}
|
||||||
|
value: {{ .value | quote }}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- if .Values.env.configmap -}}
|
||||||
|
{{- range .Values.env.configmap }}
|
||||||
|
- name: {{ .name }}
|
||||||
|
valueFrom:
|
||||||
|
configMapKeyRef:
|
||||||
|
name: {{ $cfgname }}
|
||||||
|
key: {{ .key }}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end }}
|
||||||
|
ports:
|
||||||
|
- name: http
|
||||||
|
containerPort: 80
|
||||||
|
protocol: TCP
|
||||||
|
- name: admin
|
||||||
|
containerPort: 8001
|
||||||
|
protocol: TCP
|
||||||
|
resources:
|
||||||
|
{{ toYaml .Values.resources | indent 12 }}
|
||||||
|
{{- with .Values.nodeSelector }}
|
||||||
|
nodeSelector:
|
||||||
|
{{ toYaml . | indent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
{{- with .Values.affinity }}
|
||||||
|
affinity:
|
||||||
|
{{ toYaml . | indent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
{{- with .Values.tolerations }}
|
||||||
|
tolerations:
|
||||||
|
{{ toYaml . | indent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user