diff --git a/.github/workflows/main_smartwallet.yml b/.github/workflows/main_smartwallet.yml new file mode 100644 index 0000000..0e01962 --- /dev/null +++ b/.github/workflows/main_smartwallet.yml @@ -0,0 +1,88 @@ +# Docs for the Azure Web Apps Deploy action: https://github.com/Azure/webapps-deploy +# More GitHub Actions for Azure: https://github.com/Azure/actions + +name: Build and deploy ASP.Net Core app to Azure Web App - Smartwallet + +on: + push: + branches: + - main + workflow_dispatch: + +jobs: + build: + runs-on: windows-latest + permissions: + contents: read #This is required for actions/checkout + + steps: + - uses: actions/checkout@v4 + + - name: Set up .NET Core + uses: actions/setup-dotnet@v4 + with: + dotnet-version: '8.x' + + - name: Build with dotnet + run: dotnet build --configuration Release + + - name: dotnet publish + run: dotnet publish -c Release -o "${{env.DOTNET_ROOT}}/myapp" + + - name: Upload artifact for deployment job + uses: actions/upload-artifact@v4 + with: + name: .net-app + path: ${{env.DOTNET_ROOT}}/myapp + + deploy: + runs-on: windows-latest + needs: build + permissions: + id-token: write # Required for requesting the JWT + contents: read # Required for actions/checkout + + steps: + - name: Checkout repository + uses: actions/checkout@v4 + + - name: Set up .NET Core + uses: actions/setup-dotnet@v4 + with: + dotnet-version: '8.x' + + - name: Download artifact from build job + uses: actions/download-artifact@v4 + with: + name: .net-app + + - name: Login to Azure + uses: azure/login@v2 + with: + client-id: ${{ secrets.AZUREAPPSERVICE_CLIENTID_F3A380A3B77D44AF83A0C2AD7D9E04D7 }} + tenant-id: ${{ secrets.AZUREAPPSERVICE_TENANTID_BD645D025E5D422BA1884217379C67B3 }} + subscription-id: ${{ secrets.AZUREAPPSERVICE_SUBSCRIPTIONID_009404B2EC734D30A88CFA7832D39842 }} + + - name: Install dotnet-ef tool + run: | + dotnet tool install --global dotnet-ef --version 8.* + echo "PATH=$Env:PATH;$Env:USERPROFILE\.dotnet\tools" >> $GITHUB_ENV + + - name: Update database with EF Core migrations + working-directory: src/SmartWallet.Infrastructure + run: dotnet ef database update --startup-project ../SmartWallet.API + env: + ASPNETCORE_ENVIRONMENT: Production + JWT_SECRET: ${{ secrets.JWT_SECRET }} + DB_PATH: ${{ secrets.DB_PATH }} + + - name: Deploy to Azure Web App + id: deploy-to-webapp + uses: azure/webapps-deploy@v3 + with: + app-name: 'Smartwallet' + slot-name: 'Production' + package: ${{ env.DOTNET_ROOT }}/myapp + env: + DOTNET_ROOT: ${{ env.DOTNET_ROOT }} + DB_PATH: ${{ secrets.DB_PATH }} diff --git a/src/SmartWallet.API/Program.cs b/src/SmartWallet.API/Program.cs index 8f9afd3..f2a8f04 100644 --- a/src/SmartWallet.API/Program.cs +++ b/src/SmartWallet.API/Program.cs @@ -7,7 +7,8 @@ var builder = WebApplication.CreateBuilder(args); // --- cargar .env --- -Env.TraversePath().Load(); +if (File.Exists(".env")) + Env.TraversePath().Load(); // --- validar variables --- var jwtSecret = Environment.GetEnvironmentVariable("JWT_SECRET"); @@ -17,7 +18,7 @@ throw new InvalidOperationException("Faltan variables en .env: JWT_SECRET o DB_PATH."); builder.Configuration["Jwt:Key"] = jwtSecret; -builder.Configuration["ConnectionStrings:DefaultConnection"] = $"Data Source={dbPath}"; +builder.Configuration["ConnectionStrings:DefaultConnection"] = dbPath; // --- servicios --- builder.Services.AddControllers(); diff --git a/src/SmartWallet.Infrastructure/Extensions/ServiceCollectionExtension.cs b/src/SmartWallet.Infrastructure/Extensions/ServiceCollectionExtension.cs index 6a9d9ad..528b10a 100644 --- a/src/SmartWallet.Infrastructure/Extensions/ServiceCollectionExtension.cs +++ b/src/SmartWallet.Infrastructure/Extensions/ServiceCollectionExtension.cs @@ -46,7 +46,18 @@ public static IServiceCollection AddSmartWalletInfrastructure( // --- DbContext --- services.AddDbContext(options => - options.UseSqlServer(configuration.GetConnectionString("DefaultConnection"))); + options.UseSqlServer( + configuration.GetConnectionString("DefaultConnection"), + sqlOptions => + { + sqlOptions.EnableRetryOnFailure( + maxRetryCount: 5, // Reintenta hasta 5 veces + maxRetryDelay: TimeSpan.FromSeconds(10), // Espera entre reintentos + errorNumbersToAdd: null // Aplica a errores transitorios comunes + ); + } + ) + ); return services; }