Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
37 commits
Select commit Hold shift + click to select a range
b8b202a
step1
Oumaima741 Jan 14, 2026
daea2e3
commit step1
Oumaima741 Jan 20, 2026
c8157fd
commit step1 meth2
Oumaima741 Jan 20, 2026
04ded05
commit step1
Oumaima741 Jan 20, 2026
836aec4
rydy
Oumaima741 Jan 20, 2026
0d99c81
step1
Oumaima741 Jan 20, 2026
bd79399
step
Oumaima741 Jan 20, 2026
c34926d
step
Oumaima741 Jan 20, 2026
ca19f72
fix
Oumaima741 Jan 20, 2026
960655e
test
Oumaima741 Jan 20, 2026
762412c
backend
Oumaima741 Jan 20, 2026
5704848
backend
Oumaima741 Jan 20, 2026
18b14a5
backendfinaly
Oumaima741 Jan 20, 2026
794abbc
frontend1
Oumaima741 Jan 20, 2026
f2c8549
frontend
Oumaima741 Jan 20, 2026
30ef926
frontend2
Oumaima741 Jan 20, 2026
5eb0fae
doterror
Oumaima741 Jan 20, 2026
d0fe724
front
Oumaima741 Jan 20, 2026
b5177d3
erreurtest
Oumaima741 Jan 20, 2026
c70d3f4
pushfinalfrontend
Oumaima741 Jan 20, 2026
7f61636
commitfront
Oumaima741 Jan 20, 2026
0b56186
testfinal
Oumaima741 Jan 20, 2026
9d15c1e
tag
Oumaima741 Jan 20, 2026
6775131
tag1
Oumaima741 Jan 21, 2026
64acca6
tagfinal
Oumaima741 Jan 21, 2026
6519fc1
qst2
Oumaima741 Jan 21, 2026
d82ac1e
modiftestcI
Oumaima741 Jan 21, 2026
f11269a
committestc2
Oumaima741 Jan 21, 2026
3c1d042
Merge pull request #1 from Oumaima741/feat2
Oumaima741 Jan 21, 2026
8256890
COMMITDOC
Oumaima741 Jan 21, 2026
60a6d1c
Merge branch 'main' of https://github.com/Oumaima741/parkndeploy
Oumaima741 Jan 21, 2026
1285a93
COMMITEXO2
Oumaima741 Jan 21, 2026
dbefcd4
Merge branch 'main' into feat2
Oumaima741 Jan 21, 2026
29b2a3a
COMMITQST
Oumaima741 Jan 21, 2026
8915af3
Merge branch 'feat2' of https://github.com/Oumaima741/parkndeploy int…
Oumaima741 Jan 21, 2026
abd4ae0
commitworkflow
Oumaima741 Jan 21, 2026
c7a86ca
commitci
Oumaima741 Jan 21, 2026
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
52 changes: 52 additions & 0 deletions .github/workflows/ci-pr.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
name: CI on Pull Request

on:
pull_request:
branches:
- main
types: [opened, synchronize, reopened]

jobs:
frontend:
runs-on: ubuntu-latest

steps:
- name: Checkout code
uses: actions/checkout@v4

- name: Setup Node.js
uses: actions/setup-node@v4
with:
node-version: '20'

- name: Install dependencies
run: npm ci
working-directory: ./frontend

- name: Build React app
run: npm run build
working-directory: ./frontend

- name: Run lint
run: npm run lint
working-directory: ./frontend

backend:
runs-on: ubuntu-latest

steps:
- name: Checkout code
uses: actions/checkout@v4

- name: Setup .NET SDK
uses: actions/setup-dotnet@v4
with:
dotnet-version: '9.0.x'

- name: Restore dependencies
run: dotnet restore
working-directory: ./backend

- name: Build backend in Release
run: dotnet build -c Release --no-restore
working-directory: ./backend
57 changes: 57 additions & 0 deletions .github/workflows/ci-release.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,57 @@
name: CI Release

on:
push:
tags:
- "*.*.*"
workflow_dispatch:

permissions:
contents: read

jobs:
build_backend_artifact:
runs-on: ubuntu-latest
steps:
- name: Checkout repository
uses: actions/checkout@v4

- name: Setup .NET SDK 9.0.x
uses: actions/setup-dotnet@v5
with:
dotnet-version: "9.0.x"

- name: Publish the app (Release)
working-directory: ./backend
run: dotnet publish -c Release --property:PublishDir=publish

- name: Upload backend artifact
uses: actions/upload-artifact@v4
with:
name: backend-artifact
path: backend/ParkNDeploy.Api/publish
retention-days: 5

build_frontend_artifact:
runs-on: ubuntu-latest
steps:
- name: Checkout repository
uses: actions/checkout@v4

- name: Setup Node.js
uses: actions/setup-node@v4
with:
node-version: "20"

- name: Build the app
working-directory: ./frontend
run: |
npm ci
npm run build

- name: Upload frontend artifact
uses: actions/upload-artifact@v4
with:
name: frontend-artifact
path: frontend/dist
retention-days: 5
124 changes: 124 additions & 0 deletions .github/workflows/deploy-infra-and-apps.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,124 @@
on:
workflow_run:
workflows: ["CI Release"]
types: [completed]
workflow_dispatch:



env:
AZURE_RG_NAME: rg-${{ vars.PROJECT_NAME }}-${{ vars.AZURE_RESOURCE_IDENTIFIER }}

permissions:
id-token: write

jobs:
deploy_infrastructure:

runs-on: ubuntu-latest
environment: production
outputs:
appServiceName: ${{ steps.bicep_deploy.outputs.appServiceName }}
staticWebAppName: ${{ steps.bicep_deploy.outputs.staticWebAppName }}




steps:
- name: Checkout repository
uses: actions/checkout@v4

- name: Login to Azure
uses: azure/login@v2
with:
client-id: ${{ secrets.AZURE_CLIENT_ID }}
tenant-id: ${{ secrets.AZURE_TENANT_ID }}
subscription-id: ${{ secrets.AZURE_SUBSCRIPTION_ID }}
enable-AzPSSession: true

- name: Create resource group if not exists
run: |
az group show --name ${{ env.AZURE_RG_NAME }} ||
az group create --name ${{ env.AZURE_RG_NAME }} --location ${{ secrets.AZURE_REGION }}

- name: Deploy bicep
id: bicep_deploy
uses: azure/arm-deploy@v2
with:
subscriptionId: ${{ secrets.AZURE_SUBSCRIPTION }}
region: ${{ secrets.AZURE_REGION }}
template: ./infrastructure/main.bicep
parameters: project=${{ vars.PROJECT_NAME }} location=${{ secrets.AZURE_REGION }} swaLocation=${{ secrets.AZURE_SWA_REGION }} identifier=${{ vars.AZURE_RESOURCE_IDENTIFIER }}
resourceGroupName: ${{ env.AZURE_RG_NAME }}

deploy_backend:
runs-on: ubuntu-latest
needs: deploy_infrastructure
environment: production

steps:
- name: Checkout repository
uses: actions/checkout@v4

- name: Setup .NET SDK 9.0.x
uses: actions/setup-dotnet@v4
with:
dotnet-version: '9.0.x'

- name: Publish the app
run: dotnet publish -c Release --property:PublishDir=publish # Publish the app to the API project publish folder
working-directory: ./backend # Specify where to find the solution file in repository

- name: Login to Azure
uses: azure/login@v2
with:
client-id: ${{ secrets.AZURE_CLIENT_ID }}
tenant-id: ${{ secrets.AZURE_TENANT_ID }}
subscription-id: ${{ secrets.AZURE_SUBSCRIPTION_ID }}

- name: Deploy backend to App Service
uses: azure/webapps-deploy@v2
with:
app-name: ${{ needs.deploy_infrastructure.outputs.appServiceName }} # Access to the previous job output to get the appServiceName deployed with bicep
package: ./backend/ParkNDeploy.Api/publish # Path to the previously published app
# deploy_infrastructure ...
# deploy_infrastructure ...

deploy_frontend:
runs-on: ubuntu-latest
needs: deploy_infrastructure
environment: production

steps:
- name: Checkout repository
uses: actions/checkout@v4

- name: Build the app
run: npm install && npm run build
working-directory: ./frontend

- name: Login to Azure
uses: azure/login@v2
with:
client-id: ${{ secrets.AZURE_CLIENT_ID }}
tenant-id: ${{ secrets.AZURE_TENANT_ID }}
subscription-id: ${{ secrets.AZURE_SUBSCRIPTION_ID }}

# Login to Azure
# ...

- name: Get Static Web App deployment token
run: |
SWA_DEPLOYMENT_TOKEN=$(az staticwebapp secrets list -n ${{ needs.deploy_infrastructure.outputs.staticWebAppName }} -o tsv --query properties.apiKey)
echo SWA_DEPLOYMENT_TOKEN=$SWA_DEPLOYMENT_TOKEN >> $GITHUB_ENV

# Deploy frontend to Static Web App
# ...
- name: Deploy frontend to Static Web App
uses: azure/static-web-apps-deploy@v1
with:
azure_static_web_apps_api_token: ${{ env.SWA_DEPLOYMENT_TOKEN }}
app_location: frontend/dist
action: upload
skip_app_build: true
skip_api_build: true
1 change: 1 addition & 0 deletions backend/ParkNDeploy.Api/appsettings.Development.json
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
"LogLevel": {
"Default": "Information",
"Microsoft.AspNetCore": "Warning"

}
}
}
2 changes: 1 addition & 1 deletion frontend/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
<link rel="icon" type="image/svg+xml" href="/vite.svg" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>ParkNDeploy</title>
</head>
</head>\\coucou modifSDQSDCS
<body>
<div id="root"></div>
<script type="module" src="/src/main.tsx"></script>
Expand Down
53 changes: 53 additions & 0 deletions infrastructure/main.bicep
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
targetScope = 'resourceGroup' // We'll deploy the resources in the provided resource group

// Parameters to easily construct resource names
param location string
param project string

// Here we'll add an identifier to create a unique name for the App Service Plan, for example your trigram, so that everyone could deploy his own parkndeploy instance
param identifier string

param swaLocation string
// Create the AppServicePlan through the AppServicePlan module
module appServicePlan 'modules/appServicePlan.bicep' = {
name: 'appServicePlan'
params: {
location: location
project: project
identifier: identifier
}
}

// Create the AppService through the AppService module
module appService 'modules/appService.bicep' = {
name: 'appService'
params: {
location: location
project: project
identifier: identifier
planId: appServicePlan.outputs.planId // Use the appServicePlan output to get its id back => an App Service needs to reference its App Service Plan
}
}
module staticWebApp 'modules/staticWebApp.bicep' = {
name: 'staticWebApp'
params: {
location: swaLocation
project: project
identifier: identifier
}
}
// Previous resources
// ...
module staticWebAppBackend 'modules/staticWebAppBackend.bicep' = {
name: 'staticWebAppBackend'
params: {
backendBindedResourceId: appService.outputs.appServiceId
swaName: staticWebApp.outputs.swaName
location: location
}
}

// Outputs
// ...
output appServiceName string = appService.outputs.appServiceName // Export AppServiceName in order to deploy the API later on
output staticWebAppName string = staticWebApp.outputs.swaName // Export StaticWebAppName in order to deploy the Frontend late
25 changes: 25 additions & 0 deletions infrastructure/modules/appService.bicep
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
param location string
param project string
param identifier string

// App Service Plan identifier that will host our App Service
param planId string

resource app 'Microsoft.Web/sites@2022-03-01' = {
name: '${project}-app-${identifier}'
location: location

properties: {
serverFarmId: planId
reserved: true

siteConfig: {
linuxFxVersion: 'DOTNETCORE|9.0' // Specify to setup the .NET Core 9.0 runtime (used by our backend API) on the Linux machine under the hood
}
}
}

output appServiceName string = app.name // Export the App Service name for deployment
// Previous outputs
// ...
output appServiceId string = app.id
20 changes: 20 additions & 0 deletions infrastructure/modules/appServicePlan.bicep
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
param location string
param project string
param identifier string

resource plan 'Microsoft.Web/serverfarms@2022-09-01' = {
name: '${project}-plan-${identifier}'
location: location

sku: {
name: 'F1' // We use F1 pricing plan (free one) as we don't need specific features
}

kind: 'app,linux' // Allow to deploy on an App Service using Linux OS

properties: {
reserved: true // Specifity of App Service with Linux OS
}
}

output planId string = plan.id // Export the App Service identifier
16 changes: 16 additions & 0 deletions infrastructure/modules/staticWebApp.bicep
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
param location string
param project string
param identifier string

resource swa 'Microsoft.Web/staticSites@2024-04-01' = {
name: '${project}-swa-${identifier}'
location: location

sku: {
name: 'Standard'
tier: 'Standard'
}
properties: {} // Even empty, it's mandatory ...
}

output swaName string = swa.name // Expose Static Web App name as we did for App Service for deployment purpose
11 changes: 11 additions & 0 deletions infrastructure/modules/staticWebAppBackend.bicep
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
param backendBindedResourceId string
param swaName string
param location string

resource staticWebAppBackend 'Microsoft.Web/staticSites/linkedBackends@2022-03-01' = {
name: '${swaName}/backend'
properties: {
backendResourceId: backendBindedResourceId
region: location
}
}