Compare commits

...
Sign in to create a new pull request.

12 commits

Author SHA1 Message Date
Chris Kruining
663e7a5f30
Merge branch 'main' into feature/swap-to-tricep-for-iac 2024-12-03 13:25:21 +01:00
Chris Kruining
f301f384d7
bug repro 2024-12-03 08:44:51 +01:00
Chris Kruining
47872137e0
Merge branch 'main' into feature/swap-to-tricep-for-iac 2024-12-03 07:14:53 +01:00
Chris Kruining
5b52bdbd7f
Merge branch 'main' into feature/swap-to-tricep-for-iac 2024-11-28 14:49:08 +01:00
Chris Kruining
fa86609db9
next try 2024-11-28 11:31:07 +01:00
Chris Kruining
007b812d7a
tricep should be public... 2024-11-28 11:22:56 +01:00
Chris Kruining
569e7a4cef
attempt 2 2024-11-28 10:53:37 +01:00
Chris Kruining
687f1e0a44
right 2024-11-28 10:48:14 +01:00
Chris Kruining
8faa5c7d55
getting an exception locally. seems there is a bug in the tricep output??? 2024-11-28 10:40:39 +01:00
Chris Kruining
99844d1537
Merge branch 'feature/swap-to-tricep-for-iac' of https://github.com/chris-kruining/calque into feature/swap-to-tricep-for-iac 2024-11-28 08:33:22 +01:00
Chris Kruining
e917ab12ed
kaas 2024-11-28 08:33:06 +01:00
Chris Kruining
22c733d8da
kaas 2024-11-28 07:18:53 +01:00
9 changed files with 144 additions and 136 deletions

View file

@ -47,6 +47,12 @@ jobs:
steps:
- uses: actions/checkout@v4
- name: Test bicep
uses: Azure/cli@v2
with:
inlineScript: |
az bicep build --file ./infrastructure/main.bicep --stdout
- name: Build container images
run: |
docker build . --file Dockerfile --tag ${{ secrets.ACR_LOGIN_SERVER }}/$IMAGE_NAME:${{needs.versionize.outputs.semver}}
@ -87,7 +93,6 @@ jobs:
- name: Deploy bicep
uses: Azure/cli@v2
with:
azcliversion: 2.66.0
inlineScript: |
az deployment sub create \
--location westeurope \

View file

@ -1,4 +1,15 @@
import { Context } from 'types.bicep'
import { Context } from 'br/Tricep:types:latest'
import { with_name } from 'br/Tricep:common/context:latest'
import { with_managed_identity } from 'br/Tricep:common/identity:latest'
import {
container_app_environment
container_app
container
with_public_access
with_app_logs
with_auto_scaling
with_environment
} from 'br/Tricep:recommended/app/container-app:latest'
targetScope = 'resourceGroup'
@ -9,50 +20,26 @@ param registryUrl string
var appName = 'app'
resource environment 'Microsoft.App/managedEnvironments@2024-03-01' = {
name: 'cea-${context.locationAbbreviation}-${context.environment}-${context.projectName}'
location: context.location
properties: {
appLogsConfiguration: {
destination: 'azure-monitor'
var environmentConfig = container_app_environment(with_name(context, appName), [])
var appConfig = container_app(
context,
[
container({
name: '${context.project}-${appName}'
image: '${registryUrl}/${context.project}-${appName}:${version}'
})
],
[
with_managed_identity()
with_environment(environment.id)
with_auto_scaling(0, 1, {
ruleName: {
concurrentRequests: '10'
}
peerAuthentication: {
mtls: {
enabled: false
}
}
peerTrafficConfiguration: {
encryption: {
enabled: false
}
}
}
}
resource app 'Microsoft.App/containerApps@2024-03-01' = {
name: 'ca-${context.locationAbbreviation}-${context.environment}-${context.projectName}-app'
location: context.location
identity: {
type: 'SystemAssigned'
}
properties: {
environmentId: environment.id
configuration: {
activeRevisionsMode: 'Single'
ingress: {
external: true
targetPort: 3000
transport: 'auto'
allowInsecure: false
traffic: [
{
weight: 100
latestRevision: true
}
]
corsPolicy: {
})
with_public_access({
port: 3000
cors: {
allowedOrigins: [
// 'https://localhost:3000'
'*'
@ -62,7 +49,10 @@ resource app 'Microsoft.App/containerApps@2024-03-01' = {
allowedMethods: ['Get, POST']
maxAge: 0
}
}
})
{
properties: {
configuration: {
registries: [
{
identity: 'system'
@ -70,32 +60,22 @@ resource app 'Microsoft.App/containerApps@2024-03-01' = {
}
]
}
}
}
]
)
template: {
containers: [
{
image: '${registryUrl}/${context.projectName}-${appName}:${version}'
name: '${context.projectName}-${appName}'
resources: {
cpu: json('0.25')
memory: '0.5Gi'
}
}
]
scale: {
minReplicas: 1
maxReplicas: 2
rules: [
{
name: 'http-rule'
http: {
metadata: {
concurrentRequests: '50'
}
}
}
]
}
}
resource environment 'Microsoft.App/managedEnvironments@2024-03-01' = {
name: environmentConfig.name
location: environmentConfig.location
tags: environmentConfig.tags
properties: environmentConfig.properties
}
resource app 'Microsoft.App/containerApps@2024-03-01' = {
name: appConfig.name
location: appConfig.location
tags: appConfig.tags
identity: appConfig.identity
properties: appConfig.properties
}

View file

@ -1,11 +1,18 @@
{
"experimentalFeaturesEnabled": {
"assertions": true,
"testFramework": true,
"extensibility": true,
"resourceDerivedTypes": true,
"resourceTypedParamsAndOutputs": true,
"sourceMapping": true,
"symbolicNameCodegen": true
"resourceTypedParamsAndOutputs": true
},
"moduleAliases": {
"br": {
"Tricep": {
"registry": "acreuwprdtricep.azurecr.io"
}
}
},
"cloud": {
"currentProfile": "AzureCloud",
"credentialPrecedence": [
"AzureCLI"
]
}
}

View file

@ -1,8 +1,8 @@
import { Context } from 'types.bicep'
import { create_context } from 'br/Tricep:common/context:latest'
import { resource_group } from 'br/Tricep:recommended/resources/resource-group:latest'
targetScope = 'subscription'
param locationAbbreviation string
param location string
param environment string
param projectName string
@ -11,17 +11,21 @@ param version string
param registryUrl string
param deployedAt string = utcNow('yyyyMMdd')
var context = {
locationAbbreviation: locationAbbreviation
var context = create_context({
project: projectName
nameConventionTemplate: '$type-$environment-$location-$project'
location: location
environment: environment
projectName: projectName
deployedAt: deployedAt
}
tenant: tenant()
tags: {}
})
var resourceGroupConfig = resource_group(context, [])
resource calqueResourceGroup 'Microsoft.Resources/resourceGroups@2024-07-01' = {
name: 'rg-${locationAbbreviation}-${environment}-${projectName}'
location: location
name: resourceGroupConfig.name
location: resourceGroupConfig.location
}
module monitoring 'monitoring.bicep' = {

View file

@ -1,11 +1,18 @@
import { Context } from 'types.bicep'
import { Context } from 'br/Tricep:types:latest'
import { with_managed_identity } from 'br/Tricep:common/identity:latest'
import { log_analytics } from 'br/Tricep:recommended/operational-insights/log-analytics:latest'
targetScope = 'resourceGroup'
param context Context
// resource monitoring 'Microsoft.___/___@___' = {
// name: '___-${context.locationAbbreviation}-${context.environment}-${context.projectName}'
// location: context.location
// properties: {}
// }
var logAnalyticsConfig = log_analytics(context, [
with_managed_identity()
])
resource monitoring 'Microsoft.OperationalInsights/workspaces@2023-09-01' = {
name: logAnalyticsConfig.name
location: logAnalyticsConfig.location
tags: logAnalyticsConfig.tags
properties: logAnalyticsConfig.properties
}

View file

@ -1,6 +1,5 @@
using '../main.bicep'
param locationAbbreviation = 'euw'
param location = 'westeurope'
param environment = 'prd'
param projectName = 'calque'

View file

@ -1,18 +1,14 @@
import { Context } from 'types.bicep'
import { Context } from 'br/Tricep:types:latest'
import { with_managed_identity } from 'br/Tricep:common/identity:latest'
import { container_registry } from 'br/Tricep:recommended/container-registry/container-registry:latest'
targetScope = 'resourceGroup'
param context Context
resource registry 'Microsoft.ContainerRegistry/registries@2023-07-01' = {
name: 'acr${context.locationAbbreviation}${context.environment}${context.projectName}'
location: context.location
sku: {
name: 'Basic'
}
identity: {
type: 'SystemAssigned'
}
var registryConfig = container_registry(context, [
with_managed_identity()
{
properties: {
adminUserEnabled: true
dataEndpointEnabled: false
@ -21,3 +17,13 @@ resource registry 'Microsoft.ContainerRegistry/registries@2023-07-01' = {
}
}
}
])
resource registry 'Microsoft.ContainerRegistry/registries@2023-07-01' = {
name: registryConfig.name
location: registryConfig.location
tags: registryConfig.tags
sku: registryConfig.sku
identity: registryConfig.identity
properties: registryConfig.properties
}

View file

@ -0,0 +1,12 @@
import {
container
resources_xxs
} from 'br/Tricep:recommended/app/container-app:latest'
targetScope = 'resourceGroup'
var container1 = container({
name: 'name'
image: 'registry/project-app:latest'
resources: resources_xxs
})

View file

@ -1,12 +0,0 @@
@export()
type Context = {
@minLength(2)
locationAbbreviation: string
@minLength(2)
location: string
@minLength(3)
environment: string
@minLength(2)
projectName: string
deployedAt: string
}