Compare commits
	
		
			16 Commits
		
	
	
		
			19e182c53b
			...
			v3.1.5
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 8dedc9303b | |||
| 94c6db9b72 | |||
| 0afb57789b | |||
| 02a0f479dc | |||
| 841a5a492c | |||
| 17a716fcd0 | |||
| 7c04871fdd | |||
| af53f68d2c | |||
| 985f9754c4 | |||
| 4ed5f2ccad | |||
| 123ec13896 | |||
| 4a30af60e8 | |||
| e5d5284ee3 | |||
| cd74cd6d10 | |||
| 9c6fedc149 | |||
| 40aef686af | 
| @@ -28,6 +28,8 @@ jobs: | ||||
|     steps: | ||||
|     - name: Checkout code | ||||
|       uses: actions/checkout@v4 | ||||
|       with: | ||||
|         token: ${{ secrets.GITEA_TOKEN }} | ||||
|        | ||||
|     - name: Set up Python ${{ matrix.python-version }} | ||||
|       uses: actions/setup-python@v4 | ||||
| @@ -98,6 +100,8 @@ jobs: | ||||
|     steps: | ||||
|     - name: Checkout code | ||||
|       uses: actions/checkout@v4 | ||||
|       with: | ||||
|         token: ${{ secrets.GITEA_TOKEN }} | ||||
|        | ||||
|     - name: Set up Python | ||||
|       uses: actions/setup-python@v4 | ||||
| @@ -134,6 +138,8 @@ jobs: | ||||
|     steps: | ||||
|     - name: Checkout code | ||||
|       uses: actions/checkout@v4 | ||||
|       with: | ||||
|         token: ${{ secrets.GITEA_TOKEN }} | ||||
|        | ||||
|     - name: Set up Docker Buildx | ||||
|       uses: docker/setup-buildx-action@v3 | ||||
| @@ -193,6 +199,8 @@ jobs: | ||||
|     steps: | ||||
|     - name: Checkout code | ||||
|       uses: actions/checkout@v4 | ||||
|       with: | ||||
|         token: ${{ secrets.GITEA_TOKEN }} | ||||
|        | ||||
|     - name: Wait for VictoriaMetrics | ||||
|       run: | | ||||
| @@ -244,6 +252,8 @@ jobs: | ||||
|     steps: | ||||
|     - name: Checkout code | ||||
|       uses: actions/checkout@v4 | ||||
|       with: | ||||
|         token: ${{ secrets.GITEA_TOKEN }} | ||||
|        | ||||
|     - name: Deploy to staging | ||||
|       run: | | ||||
| @@ -269,6 +279,8 @@ jobs: | ||||
|     steps: | ||||
|     - name: Checkout code | ||||
|       uses: actions/checkout@v4 | ||||
|       with: | ||||
|         token: ${{ secrets.GITEA_TOKEN }} | ||||
|        | ||||
|     - name: Deploy to production | ||||
|       run: | | ||||
| @@ -296,6 +308,8 @@ jobs: | ||||
|     steps: | ||||
|     - name: Checkout code | ||||
|       uses: actions/checkout@v4 | ||||
|       with: | ||||
|         token: ${{ secrets.GITEA_TOKEN }} | ||||
|        | ||||
|     - name: Install Apache Bench | ||||
|       run: | | ||||
|   | ||||
| @@ -27,6 +27,8 @@ jobs: | ||||
|     steps: | ||||
|     - name: Checkout code | ||||
|       uses: actions/checkout@v4 | ||||
|       with: | ||||
|         token: ${{ secrets.GITEA_TOKEN }} | ||||
|        | ||||
|     - name: Set up Python | ||||
|       uses: actions/setup-python@v4 | ||||
| @@ -127,6 +129,8 @@ jobs: | ||||
|     steps: | ||||
|     - name: Checkout code | ||||
|       uses: actions/checkout@v4 | ||||
|       with: | ||||
|         token: ${{ secrets.GITEA_TOKEN }} | ||||
|        | ||||
|     - name: Set up Python | ||||
|       uses: actions/setup-python@v4 | ||||
| @@ -224,6 +228,8 @@ jobs: | ||||
|     steps: | ||||
|     - name: Checkout code | ||||
|       uses: actions/checkout@v4 | ||||
|       with: | ||||
|         token: ${{ secrets.GITEA_TOKEN }} | ||||
|        | ||||
|     - name: Set up Python | ||||
|       uses: actions/setup-python@v4 | ||||
| @@ -248,8 +254,8 @@ jobs: | ||||
|         project = 'Northern Thailand Ping River Monitor' | ||||
|         copyright = '2025, Ping River Monitor Team' | ||||
|         author = 'Ping River Monitor Team' | ||||
|         version = '3.1.1' | ||||
|         release = '3.1.1' | ||||
|         version = '3.1.3' | ||||
|         release = '3.1.3' | ||||
|          | ||||
|         extensions = [ | ||||
|             'sphinx.ext.autodoc', | ||||
|   | ||||
| @@ -7,7 +7,7 @@ on: | ||||
|   workflow_dispatch: | ||||
|     inputs: | ||||
|       version: | ||||
|         description: 'Release version (e.g., v3.1.1)' | ||||
|         description: 'Release version (e.g., v3.1.3)' | ||||
|         required: true | ||||
|         type: string | ||||
|  | ||||
| @@ -30,6 +30,7 @@ jobs: | ||||
|     - name: Checkout code | ||||
|       uses: actions/checkout@v4 | ||||
|       with: | ||||
|         token: ${{ secrets.GITEA_TOKEN }} | ||||
|         fetch-depth: 0 | ||||
|          | ||||
|     - name: Get version | ||||
| @@ -75,6 +76,8 @@ jobs: | ||||
|     steps: | ||||
|     - name: Checkout code | ||||
|       uses: actions/checkout@v4 | ||||
|       with: | ||||
|         token: ${{ secrets.GITEA_TOKEN }} | ||||
|        | ||||
|     - name: Set up Python ${{ matrix.python-version }} | ||||
|       uses: actions/setup-python@v4 | ||||
| @@ -113,6 +116,8 @@ jobs: | ||||
|     steps: | ||||
|     - name: Checkout code | ||||
|       uses: actions/checkout@v4 | ||||
|       with: | ||||
|         token: ${{ secrets.GITEA_TOKEN }} | ||||
|        | ||||
|     - name: Set up Docker Buildx | ||||
|       uses: docker/setup-buildx-action@v3 | ||||
| @@ -121,7 +126,7 @@ jobs: | ||||
|       uses: docker/login-action@v3 | ||||
|       with:  | ||||
|         registry: ${{ env.REGISTRY }} | ||||
|         username: ${{ github.actor }} | ||||
|         username: ${{ env.actions_user }} | ||||
|         password: ${{ secrets.GITEA_TOKEN }} | ||||
|          | ||||
|     - name: Build and push release images | ||||
| @@ -142,7 +147,7 @@ jobs: | ||||
|         cache-from: type=gha | ||||
|         cache-to: type=gha,mode=max | ||||
|       env: | ||||
|         GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||||
|         GITHUB_TOKEN: ${{ secrets.GITEA_TOKEN }} | ||||
|  | ||||
|   # Security scan for release | ||||
|   security-scan: | ||||
| @@ -153,22 +158,10 @@ jobs: | ||||
|     steps: | ||||
|     - name: Checkout code | ||||
|       uses: actions/checkout@v4 | ||||
|        | ||||
|     - name: Run Trivy vulnerability scanner | ||||
|       uses: aquasecurity/trivy-action@master | ||||
|       with: | ||||
|         image-ref: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ needs.create-release.outputs.version }} | ||||
|         format: 'sarif' | ||||
|         output: 'trivy-results.sarif' | ||||
|         github-token: ${{ secrets.GH_TOKEN }} | ||||
|       env: | ||||
|         GITHUB_TOKEN: ${{ secrets.GH_TOKEN }} | ||||
|         token: ${{ secrets.GITEA_TOKEN}} | ||||
|        | ||||
|  | ||||
|     - name: Upload Trivy scan results | ||||
|       uses: actions/upload-artifact@v3 | ||||
|       with: | ||||
|         name: security-scan-results | ||||
|         path: trivy-results.sarif | ||||
|  | ||||
|   # Deploy release to production | ||||
|   deploy-release: | ||||
| @@ -182,6 +175,8 @@ jobs: | ||||
|     steps: | ||||
|     - name: Checkout code | ||||
|       uses: actions/checkout@v4 | ||||
|       with: | ||||
|         token: ${{ secrets.GITEA_TOKEN }} | ||||
|        | ||||
|     - name: Deploy to production | ||||
|       run: | | ||||
|   | ||||
| @@ -25,6 +25,8 @@ jobs: | ||||
|     steps: | ||||
|       - name: Checkout code | ||||
|         uses: actions/checkout@v4 | ||||
|         with: | ||||
|           token: ${{ secrets.GITEA_TOKEN }} | ||||
|  | ||||
|       - name: Set up Python | ||||
|         uses: actions/setup-python@v4 | ||||
| @@ -61,16 +63,16 @@ jobs: | ||||
|  | ||||
|       - name: Check for critical vulnerabilities | ||||
|         run: | | ||||
|           echo "🔍 Checking for critical vulnerabilities..." | ||||
|           echo "Checking for critical vulnerabilities..." | ||||
|  | ||||
|           # Check Safety results | ||||
|           if [ -f safety-report.json ]; then | ||||
|             critical_count=$(jq '.vulnerabilities | length' safety-report.json 2>/dev/null || echo "0") | ||||
|             if [ "$critical_count" -gt 0 ]; then | ||||
|               echo "⚠️ Found $critical_count dependency vulnerabilities" | ||||
|               echo "Found $critical_count dependency vulnerabilities" | ||||
|               jq '.vulnerabilities[] | "- \(.package_name) \(.installed_version): \(.vulnerability_id)"' safety-report.json | ||||
|             else | ||||
|               echo "✅ No dependency vulnerabilities found" | ||||
|               echo "No dependency vulnerabilities found" | ||||
|             fi | ||||
|           fi | ||||
|  | ||||
| @@ -78,86 +80,9 @@ jobs: | ||||
|           if [ -f bandit-report.json ]; then | ||||
|             high_severity=$(jq '.results[] | select(.issue_severity == "HIGH") | length' bandit-report.json 2>/dev/null | wc -l) | ||||
|             if [ "$high_severity" -gt 0 ]; then | ||||
|               echo "⚠️ Found $high_severity high-severity security issues" | ||||
|               echo "Found $high_severity high-severity security issues" | ||||
|             else | ||||
|               echo "✅ No high-severity security issues found" | ||||
|             fi | ||||
|           fi | ||||
|  | ||||
|   # Docker image security scan | ||||
|   docker-security-scan: | ||||
|     name: Docker Security Scan | ||||
|     runs-on: ubuntu-latest | ||||
|  | ||||
|     steps: | ||||
|       - name: Checkout code | ||||
|         uses: actions/checkout@v4 | ||||
|  | ||||
|       - name: Check GitHub token availability | ||||
|         run: | | ||||
|           if [ -z "${{ secrets.GH_TOKEN }}" ]; then | ||||
|             echo "⚠️ GH_TOKEN not configured. Trivy scans may fail due to rate limits." | ||||
|             echo "💡 To fix: Add GH_TOKEN secret in repository settings" | ||||
|           else | ||||
|             echo "✅ GH_TOKEN is configured" | ||||
|           fi | ||||
|  | ||||
|       - name: Build Docker image for scanning | ||||
|         run: | | ||||
|           docker build -t ping-river-monitor:scan . | ||||
|         env: | ||||
|           GITHUB_TOKEN: ${{ secrets.GH_TOKEN }} | ||||
|  | ||||
|       - name: Run Trivy vulnerability scanner | ||||
|         uses: aquasecurity/trivy-action@master | ||||
|         with: | ||||
|           image-ref: "ping-river-monitor:scan" | ||||
|           format: "json" | ||||
|           output: "trivy-report.json" | ||||
|           github-token: ${{ secrets.GH_TOKEN }} | ||||
|         env: | ||||
|           GITHUB_TOKEN: ${{ secrets.GH_TOKEN }} | ||||
|         continue-on-error: true | ||||
|  | ||||
|       - name: Run Trivy filesystem scan | ||||
|         uses: aquasecurity/trivy-action@master | ||||
|         with: | ||||
|           scan-type: "fs" | ||||
|           scan-ref: "." | ||||
|           format: "json" | ||||
|           output: "trivy-fs-report.json" | ||||
|           github-token: ${{ secrets.GH_TOKEN }} | ||||
|         env: | ||||
|           GITHUB_TOKEN: ${{ secrets.GH_TOKEN }} | ||||
|         continue-on-error: true | ||||
|  | ||||
|       - name: Upload Trivy reports | ||||
|         uses: actions/upload-artifact@v3 | ||||
|         if: always() | ||||
|         with: | ||||
|           name: trivy-reports-${{ github.run_number }} | ||||
|           path: | | ||||
|             trivy-report.json | ||||
|             trivy-fs-report.json | ||||
|  | ||||
|       - name: Check Trivy results | ||||
|         run: | | ||||
|           echo "🔍 Analyzing Docker security scan results..." | ||||
|  | ||||
|           if [ -f trivy-report.json ]; then | ||||
|             critical_vulns=$(jq '.Results[]?.Vulnerabilities[]? | select(.Severity == "CRITICAL") | length' trivy-report.json 2>/dev/null | wc -l) | ||||
|             high_vulns=$(jq '.Results[]?.Vulnerabilities[]? | select(.Severity == "HIGH") | length' trivy-report.json 2>/dev/null | wc -l) | ||||
|              | ||||
|             echo "Critical vulnerabilities: $critical_vulns" | ||||
|             echo "High vulnerabilities: $high_vulns" | ||||
|              | ||||
|             if [ "$critical_vulns" -gt 0 ]; then | ||||
|               echo "❌ Critical vulnerabilities found in Docker image!" | ||||
|               exit 1 | ||||
|             elif [ "$high_vulns" -gt 5 ]; then | ||||
|               echo "⚠️ Many high-severity vulnerabilities found" | ||||
|             else | ||||
|               echo "✅ Docker image security scan passed" | ||||
|               echo "No high-severity security issues found" | ||||
|             fi | ||||
|           fi | ||||
|  | ||||
| @@ -169,6 +94,8 @@ jobs: | ||||
|     steps: | ||||
|       - name: Checkout code | ||||
|         uses: actions/checkout@v4 | ||||
|         with: | ||||
|           token: ${{ secrets.GITEA_TOKEN }} | ||||
|  | ||||
|       - name: Set up Python | ||||
|         uses: actions/setup-python@v4 | ||||
| @@ -183,7 +110,7 @@ jobs: | ||||
|  | ||||
|       - name: Check licenses | ||||
|         run: | | ||||
|           echo "📄 Checking dependency licenses..." | ||||
|           echo "Checking dependency licenses..." | ||||
|           pip-licenses --format=json --output-file=licenses.json | ||||
|           pip-licenses --format=markdown --output-file=licenses.md | ||||
|  | ||||
| @@ -192,11 +119,11 @@ jobs: | ||||
|  | ||||
|           for license in "${problematic_licenses[@]}"; do | ||||
|             if grep -i "$license" licenses.json; then | ||||
|               echo "⚠️ Found potentially problematic license: $license" | ||||
|               echo "Found potentially problematic license: $license" | ||||
|             fi | ||||
|           done | ||||
|  | ||||
|           echo "✅ License check completed" | ||||
|           echo "License check completed" | ||||
|  | ||||
|       - name: Upload license report | ||||
|         uses: actions/upload-artifact@v3 | ||||
| @@ -214,6 +141,8 @@ jobs: | ||||
|     steps: | ||||
|       - name: Checkout code | ||||
|         uses: actions/checkout@v4 | ||||
|         with: | ||||
|           token: ${{ secrets.GITEA_TOKEN }} | ||||
|  | ||||
|       - name: Set up Python | ||||
|         uses: actions/setup-python@v4 | ||||
| @@ -227,56 +156,15 @@ jobs: | ||||
|  | ||||
|       - name: Check for outdated packages | ||||
|         run: | | ||||
|           echo "📦 Checking for outdated packages..." | ||||
|           echo "Checking for outdated packages..." | ||||
|           pip install --root-user-action=ignore -r requirements.txt | ||||
|           pip list --outdated --format=json > outdated-packages.json || true | ||||
|  | ||||
|           if [ -s outdated-packages.json ]; then | ||||
|             echo "📋 Outdated packages found:" | ||||
|             echo "Outdated packages found:" | ||||
|             cat outdated-packages.json | jq -r '.[] | "- \(.name): \(.version) -> \(.latest_version)"' | ||||
|           else | ||||
|             echo "✅ All packages are up to date" | ||||
|           fi | ||||
|  | ||||
|       - name: Create dependency update issue | ||||
|         if: github.event_name == 'schedule' | ||||
|         run: | | ||||
|           if [ -s outdated-packages.json ] && [ "$(cat outdated-packages.json)" != "[]" ]; then | ||||
|             echo "📝 Creating dependency update issue..." | ||||
|              | ||||
|             # Create issue body | ||||
|             cat > issue-body.md << 'EOF' | ||||
|           ## 📦 Dependency Updates Available | ||||
|  | ||||
|           The following packages have updates available: | ||||
|  | ||||
|           EOF | ||||
|              | ||||
|             cat outdated-packages.json | jq -r '.[] | "- **\(.name)**: \(.version) → \(.latest_version)"' >> issue-body.md | ||||
|              | ||||
|             cat >> issue-body.md << 'EOF' | ||||
|  | ||||
|           ## 🔍 Security Impact | ||||
|  | ||||
|           Please review each update for: | ||||
|           - Security fixes | ||||
|           - Breaking changes | ||||
|           - Compatibility issues | ||||
|  | ||||
|           ## ✅ Action Items | ||||
|  | ||||
|           - [ ] Review changelog for each package | ||||
|           - [ ] Test updates in development environment | ||||
|           - [ ] Update requirements.txt | ||||
|           - [ ] Run full test suite | ||||
|           - [ ] Deploy to staging for validation | ||||
|  | ||||
|           --- | ||||
|           *This issue was automatically created by the security workflow.* | ||||
|           EOF | ||||
|              | ||||
|             echo "Issue body created. In a real implementation, you would create a Gitea issue here." | ||||
|             cat issue-body.md | ||||
|             echo "All packages are up to date" | ||||
|           fi | ||||
|  | ||||
|       - name: Upload dependency reports | ||||
| @@ -285,7 +173,6 @@ jobs: | ||||
|           name: dependency-reports-${{ github.run_number }} | ||||
|           path: | | ||||
|             outdated-packages.json | ||||
|             issue-body.md | ||||
|  | ||||
|   # Code quality metrics | ||||
|   code-quality: | ||||
| @@ -295,6 +182,8 @@ jobs: | ||||
|     steps: | ||||
|       - name: Checkout code | ||||
|         uses: actions/checkout@v4 | ||||
|         with: | ||||
|           token: ${{ secrets.GITEA_TOKEN }} | ||||
|  | ||||
|       - name: Set up Python | ||||
|         uses: actions/setup-python@v4 | ||||
| @@ -309,24 +198,24 @@ jobs: | ||||
|  | ||||
|       - name: Calculate code complexity | ||||
|         run: | | ||||
|           echo "📊 Calculating code complexity..." | ||||
|           echo "Calculating code complexity..." | ||||
|           radon cc src/ --json > complexity-report.json | ||||
|           radon mi src/ --json > maintainability-report.json | ||||
|  | ||||
|           echo "🔍 Complexity Summary:" | ||||
|           echo "Complexity Summary:" | ||||
|           radon cc src/ --average | ||||
|  | ||||
|           echo "🔧 Maintainability Summary:" | ||||
|           echo "Maintainability Summary:" | ||||
|           radon mi src/ | ||||
|  | ||||
|       - name: Find dead code | ||||
|         run: | | ||||
|           echo "🧹 Checking for dead code..." | ||||
|           echo "Checking for dead code..." | ||||
|           vulture src/ --json > dead-code-report.json || true | ||||
|  | ||||
|       - name: Check for code smells | ||||
|         run: | | ||||
|           echo "👃 Checking for code smells..." | ||||
|           echo "Checking for code smells..." | ||||
|           xenon --max-absolute B --max-modules A --max-average A src/ || true | ||||
|  | ||||
|       - name: Upload quality reports | ||||
| @@ -342,7 +231,7 @@ jobs: | ||||
|   security-summary: | ||||
|     name: Security Summary | ||||
|     runs-on: ubuntu-latest | ||||
|     needs: [dependency-scan, docker-security-scan, license-check, code-quality] | ||||
|     needs: [dependency-scan, license-check, code-quality] | ||||
|     if: always() | ||||
|  | ||||
|     steps: | ||||
| @@ -351,51 +240,47 @@ jobs: | ||||
|  | ||||
|       - name: Generate security summary | ||||
|         run: | | ||||
|           echo "# 🔒 Security Scan Summary" > security-summary.md | ||||
|           echo "# Security Scan Summary" > security-summary.md | ||||
|           echo "" >> security-summary.md | ||||
|           echo "**Scan Date:** $(date -u)" >> security-summary.md | ||||
|           echo "**Repository:** ${{ github.repository }}" >> security-summary.md | ||||
|           echo "**Commit:** ${{ github.sha }}" >> security-summary.md | ||||
|           echo "" >> security-summary.md | ||||
|  | ||||
|           echo "## 📊 Results" >> security-summary.md | ||||
|           echo "## Results" >> security-summary.md | ||||
|           echo "" >> security-summary.md | ||||
|  | ||||
|           # Dependency scan results | ||||
|           if [ -f security-reports-*/safety-report.json ]; then | ||||
|             vuln_count=$(jq '.vulnerabilities | length' security-reports-*/safety-report.json 2>/dev/null || echo "0") | ||||
|             if [ "$vuln_count" -eq 0 ]; then | ||||
|               echo "- ✅ **Dependency Scan**: No vulnerabilities found" >> security-summary.md | ||||
|               echo "- Dependency Scan: No vulnerabilities found" >> security-summary.md | ||||
|             else | ||||
|               echo "- ⚠️ **Dependency Scan**: $vuln_count vulnerabilities found" >> security-summary.md | ||||
|               echo "- Dependency Scan: $vuln_count vulnerabilities found" >> security-summary.md | ||||
|             fi | ||||
|           else | ||||
|             echo "- ❓ **Dependency Scan**: Results not available" >> security-summary.md | ||||
|             echo "- Dependency Scan: Results not available" >> security-summary.md | ||||
|           fi | ||||
|  | ||||
|           # Docker scan results | ||||
|           if [ -f trivy-reports-*/trivy-report.json ]; then | ||||
|             echo "- ✅ **Docker Scan**: Completed" >> security-summary.md | ||||
|           else | ||||
|             echo "- ❓ **Docker Scan**: Results not available" >> security-summary.md | ||||
|           fi | ||||
|           # Docker scan results (removed Trivy) | ||||
|           echo "- Docker Scan: Skipped (Trivy removed)" >> security-summary.md | ||||
|  | ||||
|           # License check results | ||||
|           if [ -f license-report-*/licenses.json ]; then | ||||
|             echo "- ✅ **License Check**: Completed" >> security-summary.md | ||||
|             echo "- License Check: Completed" >> security-summary.md | ||||
|           else | ||||
|             echo "- ❓ **License Check**: Results not available" >> security-summary.md | ||||
|             echo "- License Check: Results not available" >> security-summary.md | ||||
|           fi | ||||
|  | ||||
|           # Code quality results | ||||
|           if [ -f code-quality-reports-*/complexity-report.json ]; then | ||||
|             echo "- ✅ **Code Quality**: Analyzed" >> security-summary.md | ||||
|             echo "- Code Quality: Analyzed" >> security-summary.md | ||||
|           else | ||||
|             echo "- ❓ **Code Quality**: Results not available" >> security-summary.md | ||||
|             echo "- Code Quality: Results not available" >> security-summary.md | ||||
|           fi | ||||
|  | ||||
|           echo "" >> security-summary.md | ||||
|           echo "## 🔗 Detailed Reports" >> security-summary.md | ||||
|           echo "## Detailed Reports" >> security-summary.md | ||||
|           echo "" >> security-summary.md | ||||
|           echo "Detailed reports are available in the workflow artifacts." >> security-summary.md | ||||
|  | ||||
|   | ||||
| @@ -259,7 +259,7 @@ make health-check | ||||
|  | ||||
| **Deployment Date**: ___________   | ||||
| **Deployed By**: ___________   | ||||
| **Version**: v3.1.1   | ||||
| **Version**: v3.1.3   | ||||
| **Environment**: ___________   | ||||
|  | ||||
| **Sign-off**: | ||||
|   | ||||
| @@ -222,12 +222,12 @@ Your repository is now equipped with: | ||||
| 2. **Configure deployment environments** (staging/production) | ||||
| 3. **Set up monitoring dashboards** for workflow metrics | ||||
| 4. **Configure notifications** for team collaboration | ||||
| 5. **Create your first release** with `git tag v3.1.1` | ||||
| 5. **Create your first release** with `git tag v3.1.3` | ||||
|  | ||||
| Your **Northern Thailand Ping River Monitor** is now ready for professional development and deployment! 🎊 | ||||
|  | ||||
| --- | ||||
|  | ||||
| **Workflow Version**: v3.1.1   | ||||
| **Workflow Version**: v3.1.3   | ||||
| **Setup Date**: 2025-08-12   | ||||
| **Repository**: https://git.b4l.co.th/grabowski/Northern-Thailand-Ping-River-Monitor | ||||
| @@ -2,7 +2,7 @@ | ||||
|  | ||||
| A comprehensive real-time water level monitoring system for the Ping River Basin in Northern Thailand, covering Royal Irrigation Department (RID) stations from Chiang Dao to Nakhon Sawan with advanced data collection, storage, and visualization capabilities. | ||||
|  | ||||
| [](https://git.b4l.co.th/B4L/Northern-Thailand-Ping-River-Monitor/actions) [](https://git.b4l.co.th/B4L/Northern-Thailand-Ping-River-Monitor/actions) [](https://git.b4l.co.th/B4L/Northern-Thailand-Ping-River-Monitor/actions) [](https://python.org) [](https://fastapi.tiangolo.com) [](https://docker.com) [](LICENSE) [](https://git.b4l.co.th/B4L/Northern-Thailand-Ping-River-Monitor/releases) | ||||
| [](https://git.b4l.co.th/B4L/Northern-Thailand-Ping-River-Monitor/actions) [](https://git.b4l.co.th/B4L/Northern-Thailand-Ping-River-Monitor/actions) [](https://git.b4l.co.th/B4L/Northern-Thailand-Ping-River-Monitor/actions) [](https://python.org) [](https://fastapi.tiangolo.com) [](https://docker.com) [](LICENSE) [](https://git.b4l.co.th/B4L/Northern-Thailand-Ping-River-Monitor/releases) | ||||
|  | ||||
| ## 🌟 Features | ||||
|  | ||||
|   | ||||
| @@ -297,6 +297,6 @@ make validate-workflows | ||||
|  | ||||
| --- | ||||
|  | ||||
| **Workflow Version**: v3.1.1   | ||||
| **Workflow Version**: v3.1.3   | ||||
| **Last Updated**: 2025-08-12   | ||||
| **Maintained By**: Ping River Monitor Team | ||||
| @@ -29,7 +29,7 @@ def main(): | ||||
|         "FastAPI": generate_badge_url("FastAPI", "0.104%2B", "green"), | ||||
|         "Docker": generate_badge_url("Docker", "Ready", "blue"), | ||||
|         "License": generate_badge_url("License", "MIT", "green"), | ||||
|         "Version": generate_badge_url("Version", "v3.1.1", "blue"), | ||||
|         "Version": generate_badge_url("Version", "v3.1.3", "blue"), | ||||
|     } | ||||
|      | ||||
|     print("# Status Badges") | ||||
|   | ||||
| @@ -13,7 +13,7 @@ REM Add all files | ||||
| git add . | ||||
|  | ||||
| REM Initial commit | ||||
| git commit -m "Initial commit: Northern Thailand Ping River Monitor v3.1.1 | ||||
| git commit -m "Initial commit: Northern Thailand Ping River Monitor v3.1.3 | ||||
|  | ||||
| Features: | ||||
| - Real-time water level monitoring for Ping River Basin | ||||
|   | ||||
| @@ -66,7 +66,7 @@ fi | ||||
| git add . | ||||
|  | ||||
| # Initial commit | ||||
| git commit -m "Initial commit: Northern Thailand Ping River Monitor v3.1.1 | ||||
| git commit -m "Initial commit: Northern Thailand Ping River Monitor v3.1.3 | ||||
|  | ||||
| Features: | ||||
| - Real-time water level monitoring for Ping River Basin | ||||
|   | ||||
							
								
								
									
										16
									
								
								setup.py
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								setup.py
									
									
									
									
									
								
							| @@ -11,8 +11,18 @@ with open("README.md", "r", encoding="utf-8") as fh: | ||||
|     long_description = fh.read() | ||||
|  | ||||
| # Read requirements | ||||
| with open("requirements.txt", "r", encoding="utf-8") as fh: | ||||
|     requirements = [line.strip() for line in fh if line.strip() and not line.startswith("#")] | ||||
| try: | ||||
|     with open("requirements.txt", "r", encoding="utf-8") as fh: | ||||
|         requirements = [line.strip() for line in fh if line.strip() and not line.startswith("#")] | ||||
| except FileNotFoundError: | ||||
|     # Fallback to minimal requirements if file not found | ||||
|     requirements = [ | ||||
|         "requests>=2.31.0", | ||||
|         "schedule>=1.2.0", | ||||
|         "pandas>=2.1.0", | ||||
|         "fastapi>=0.104.0", | ||||
|         "uvicorn>=0.24.0", | ||||
|     ] | ||||
|  | ||||
| # Extract core requirements (exclude dev dependencies) | ||||
| core_requirements = [] | ||||
| @@ -22,7 +32,7 @@ for req in requirements: | ||||
|  | ||||
| setup( | ||||
|     name="northern-thailand-ping-river-monitor", | ||||
|     version="3.1.1", | ||||
|     version="3.1.3", | ||||
|     author="Ping River Monitor Team", | ||||
|     author_email="contact@example.com", | ||||
|     description="Real-time water level monitoring system for the Ping River Basin in Northern Thailand", | ||||
|   | ||||
| @@ -6,7 +6,7 @@ A comprehensive real-time water level monitoring system for the Ping River Basin | ||||
| in Northern Thailand, covering Royal Irrigation Department (RID) stations. | ||||
| """ | ||||
|  | ||||
| __version__ = "3.1.1" | ||||
| __version__ = "3.1.3" | ||||
| __author__ = "Ping River Monitor Team" | ||||
| __description__ = "Northern Thailand Ping River Monitoring System" | ||||
|  | ||||
|   | ||||
| @@ -297,7 +297,7 @@ Examples: | ||||
|     ) | ||||
|      | ||||
|     logger.info("🏔️ Northern Thailand Ping River Monitor starting...") | ||||
|     logger.info(f"Version: 3.1.1") | ||||
|     logger.info(f"Version: 3.1.3") | ||||
|     logger.info(f"Log level: {args.log_level}") | ||||
|      | ||||
|     try: | ||||
|   | ||||
| @@ -143,7 +143,7 @@ async def lifespan(app: FastAPI): | ||||
| app = FastAPI( | ||||
|     title="Northern Thailand Ping River Monitor API", | ||||
|     description="Real-time water level monitoring system for Northern Thailand's Ping River Basin stations", | ||||
|     version="3.1.1", | ||||
|     version="3.1.3", | ||||
|     lifespan=lifespan | ||||
| ) | ||||
|  | ||||
|   | ||||
| @@ -165,7 +165,7 @@ def test_logging(): | ||||
|  | ||||
| def main(): | ||||
|     """Run all tests""" | ||||
|     print("🧪 Running integration tests for Northern Thailand Ping River Monitor v3.1.1") | ||||
|     print("🧪 Running integration tests for Northern Thailand Ping River Monitor v3.1.3") | ||||
|     print("=" * 60) | ||||
|      | ||||
|     tests = [ | ||||
|   | ||||
		Reference in New Issue
	
	Block a user