dist_agent_lang 1.0.5

A hybrid programming language for decentralized and centralized network integration
Documentation
name: "CodeQL Analysis"

on:
  push:
    branches: [ "main" ]
  pull_request:
    branches: [ "main" ]
  schedule:
    # Run weekly on Sunday at 00:00 UTC
    - cron: '0 0 * * 0'
  workflow_dispatch: {}   # Run manually from Actions tab

jobs:
  analyze:
    name: Analyze
    runs-on: ubuntu-latest
    env:
      SSL_CERT_FILE: /etc/ssl/certs/ca-certificates.crt
      CARGO_HTTP_CAINFO: /etc/ssl/certs/ca-certificates.crt
    permissions:
      actions: read
      contents: read
      security-events: write

    strategy:
      fail-fast: false
      matrix:
        language: [ 'rust' ]

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

    - name: Fix CA cert path for Cargo/curl
      run: |
        sudo mkdir -p /usr/local/etc/ca-certificates
        sudo ln -sf /etc/ssl/certs/ca-certificates.crt /usr/local/etc/ca-certificates/cert.pem
        sudo update-ca-certificates

    - name: Install Rust toolchain
      uses: actions-rs/toolchain@v1
      with:
        toolchain: stable
        components: rustfmt, clippy
        profile: minimal

    - name: Cache Cargo dependencies
      uses: actions/cache@v3
      with:
        path: |
          ~/.cargo/bin/
          ~/.cargo/registry/index/
          ~/.cargo/registry/cache/
          ~/.cargo/git/db/
          target/
        key: ${{ runner.os }}-cargo-${{ hashFiles('**/Cargo.lock') }}
        restore-keys: |
          ${{ runner.os }}-cargo-

    - name: Initialize CodeQL
      uses: github/codeql-action/init@v3
      with:
        languages: ${{ matrix.language }}
        # Use security-extended queries for better coverage
        queries: security-extended

    - name: Build Rust project with full analysis
      run: |
        # Clean build for better CodeQL analysis
        cargo clean
        # Build with all features for complete analysis
        cargo build --all-features --verbose

    - name: Perform CodeQL Analysis
      uses: github/codeql-action/analyze@v3
      with:
        category: "/language:rust"