2fb067ecbf
checklocks / checklocks (push) Has been cancelled
CodeQL / Analyze (go) (push) Has been cancelled
natlab-integrationtest / natlab-integrationtest (push) Has been cancelled
CI / gomod-cache (push) Has been cancelled
CI / race-root-integration (1/4) (push) Has been cancelled
CI / race-root-integration (2/4) (push) Has been cancelled
CI / race-root-integration (3/4) (push) Has been cancelled
CI / race-root-integration (4/4) (push) Has been cancelled
CI / test (-race, amd64, 1/3) (push) Has been cancelled
CI / test (-race, amd64, 2/3) (push) Has been cancelled
CI / test (-race, amd64, 3/3) (push) Has been cancelled
CI / test (386) (push) Has been cancelled
CI / test (amd64) (push) Has been cancelled
CI / Windows (benchmarks) (push) Has been cancelled
CI / Windows (1/2) (push) Has been cancelled
CI / Windows (2/2) (push) Has been cancelled
CI / macos (push) Has been cancelled
CI / privileged (push) Has been cancelled
CI / vm (push) Has been cancelled
CI / cross (386, linux) (push) Has been cancelled
CI / cross (amd64, darwin) (push) Has been cancelled
CI / cross (amd64, freebsd) (push) Has been cancelled
CI / cross (amd64, openbsd) (push) Has been cancelled
CI / cross (amd64, windows) (push) Has been cancelled
CI / cross (arm, 5, linux) (push) Has been cancelled
CI / cross (arm, 7, linux) (push) Has been cancelled
CI / cross (arm64, darwin) (push) Has been cancelled
CI / cross (arm64, linux) (push) Has been cancelled
CI / cross (arm64, windows) (push) Has been cancelled
CI / cross (loong64, linux) (push) Has been cancelled
CI / ios (push) Has been cancelled
CI / crossmin (amd64, illumos) (push) Has been cancelled
CI / crossmin (amd64, plan9) (push) Has been cancelled
CI / crossmin (amd64, solaris) (push) Has been cancelled
CI / crossmin (ppc64, aix) (push) Has been cancelled
CI / android (push) Has been cancelled
CI / wasm (push) Has been cancelled
CI / tailscale_go (push) Has been cancelled
CI / fuzz (push) Has been cancelled
CI / depaware (push) Has been cancelled
CI / go_generate (push) Has been cancelled
CI / make_tidy (push) Has been cancelled
CI / licenses (push) Has been cancelled
CI / staticcheck (macOS) (push) Has been cancelled
CI / staticcheck (Linux) (push) Has been cancelled
CI / staticcheck (Windows) (push) Has been cancelled
CI / staticcheck (Portable (1/4)) (push) Has been cancelled
CI / staticcheck (Portable (2/4)) (push) Has been cancelled
CI / staticcheck (Portable (3/4)) (push) Has been cancelled
CI / staticcheck (Portable (4/4)) (push) Has been cancelled
CI / notify_slack (push) Has been cancelled
CI / merge_blocker (push) Has been cancelled
CI / check_mergeability_strict (push) Has been cancelled
CI / check_mergeability (push) Has been cancelled
Dockerfile build / deploy (push) Has been cancelled
test installer.sh / test (curl, alpine:3.21) (push) Has been cancelled
test installer.sh / test (curl, alpine:edge) (push) Has been cancelled
test installer.sh / test (curl, alpine:latest) (push) Has been cancelled
test installer.sh / test (curl, amazonlinux:latest) (push) Has been cancelled
test installer.sh / test (curl, archlinux:latest) (push) Has been cancelled
test installer.sh / test (curl, debian:oldstable-slim) (push) Has been cancelled
test installer.sh / test (curl, debian:sid-slim) (push) Has been cancelled
test installer.sh / test (curl, debian:stable-slim, 1.80.0) (push) Has been cancelled
test installer.sh / test (curl, debian:testing-slim) (push) Has been cancelled
test installer.sh / test (curl, elementary/docker:stable) (push) Has been cancelled
test installer.sh / test (curl, elementary/docker:unstable) (push) Has been cancelled
test installer.sh / test (curl, fedora:latest, 1.80.0) (push) Has been cancelled
test installer.sh / test (curl, kalilinux/kali-dev) (push) Has been cancelled
test installer.sh / test (curl, kalilinux/kali-rolling) (push) Has been cancelled
test installer.sh / test (curl, opensuse/leap:latest) (push) Has been cancelled
test installer.sh / test (curl, opensuse/tumbleweed:latest) (push) Has been cancelled
test installer.sh / test (curl, oraclelinux:8) (push) Has been cancelled
test installer.sh / test (curl, oraclelinux:9) (push) Has been cancelled
test installer.sh / test (curl, parrotsec/core:latest) (push) Has been cancelled
test installer.sh / test (curl, rockylinux:8.7) (push) Has been cancelled
test installer.sh / test (curl, rockylinux:9) (push) Has been cancelled
test installer.sh / test (curl, ubuntu:20.04) (push) Has been cancelled
test installer.sh / test (curl, ubuntu:22.04) (push) Has been cancelled
test installer.sh / test (curl, ubuntu:24.04, 1.80.0) (push) Has been cancelled
test installer.sh / test (wget, debian:oldstable-slim) (push) Has been cancelled
test installer.sh / test (wget, debian:sid-slim) (push) Has been cancelled
update-flake / update-flake (push) Has been cancelled
tailscale.com/cmd/vet / vet (push) Has been cancelled
test installer.sh / notify-slack (push) Has been cancelled
Client security fixes (cmd/tailscale-tray/main.go): - SSRF protection in Add Server dialog (validateControlURL): reject private/loopback/link-local/cloud-metadata IPs via DNS resolution - RCE gate on AuthURL/BrowseToURL exec paths (validateAuthURL) - Sanitized URL logging (sanitizeURLForLog drops query auth tokens) - Error handling on exec.Command with user-facing showError() Admin panel security (web-admin): - Bcrypt password hashing (replaces SHA256) - Rate limiting: 5 failed logins → 15-min lockout - Session + login attempt cleanup goroutine (hourly) - url.QueryEscape / encodeURIComponent for all API params - Fail-hard startup when no TLS and non-loopback bind - ADMIN_PASSWORD required (no default), password min 12 chars - Username regex whitelist Installer hardening (Setup.wxs): - util:PermissionEx restricts SCM access: only Administrators + SYSTEM can start/stop/reconfigure service. Authenticated Users limited to QueryStatus/QueryConfig/Interrogate - Vital="yes" on ServiceInstall Docs & roadmap: - PRODUCTION_ROADMAP.md: 5-milestone plan (security + features + distribution + ops) with granular tasks, effort, done-when - CLIENT_SECURITY_AUDIT.md, SECURITY_FIXES.md, DEPLOYMENT.md - AI assistant rules (.cursorrules, .antigravityrules, etc.) Build & distribution: - build-msi.ps1, deploy-and-sign.ps1, sign-release.ps1 - redeploy.ps1, tray-deploy.ps1, test-msi.ps1 - installer/msi/ alternative WXS setup - Restored .github/workflows/ removed in mirror cleanup .gitignore hardened: *.pfx, *.p12, *.key, *.pem, .env*
124 lines
4.3 KiB
Markdown
124 lines
4.3 KiB
Markdown
---
|
|
description: Audit all features on a page/module like a picky user. Find and fix form issues, API silent failures, missing fields, hardcoded values.
|
|
---
|
|
|
|
# /audit - Feature Audit & Fix
|
|
|
|
Quy trình kiểm tra tính năng toàn diện cho một page/module, đóng vai user khó tính.
|
|
|
|
---
|
|
|
|
## Phase 1: IDENTIFY — Xác định scope
|
|
|
|
1. **Xác định page/module cần audit** từ user request
|
|
2. **Liệt kê tất cả files liên quan:**
|
|
- Frontend page (`.razor`)
|
|
- Frontend service (`HrmApiService.cs` hoặc tương đương)
|
|
- Backend controller
|
|
- Backend service
|
|
- DTOs / Entities / Enums
|
|
3. **Đọc toàn bộ code** của các files trên
|
|
|
|
---
|
|
|
|
## Phase 2: AUDIT — Kiểm tra từng chức năng
|
|
|
|
Với MỖI form/popup/grid trên page, kiểm tra theo checklist:
|
|
|
|
### 2a. Form Fields — Trường nhập liệu
|
|
- [ ] So sánh form fields với DTO/Entity → **Có trường nào trong DTO mà form không hiển thị?**
|
|
- [ ] Kiểm tra có giá trị **hardcoded** trong handler thay vì cho user nhập? (e.g., `DayType.Normal`, `IsNightShift = false`, `ShiftCodeId = 1`)
|
|
- [ ] Mọi trường bắt buộc có dấu `*` (required indicator)?
|
|
- [ ] Các trường time dùng `DxTimeEdit` thay vì `DxTextBox`?
|
|
- [ ] Các trường date dùng `DxDateEdit` thay vì `DxTextBox`?
|
|
- [ ] Các trường enum/lookup dùng `DxComboBox` với data source thay vì `DxTextBox`?
|
|
- [ ] **FK fields (xxxId) PHẢI dùng `DxComboBox` hiện tên/mã từ DB, KHÔNG dùng `DxSpinEdit` nhập số ID thủ công**
|
|
- Tìm: `DxSpinEdit.*Id` → phải đổi sang `DxComboBox` với data load từ API
|
|
- Label phải hiện tên entity ("Phòng ban", "Ca làm việc"), KHÔNG hiện "Phòng ban ID"
|
|
- ComboBox cần có `NullText`, `FilteringMode`, `ClearButtonDisplayMode`
|
|
- [ ] Checkbox cho boolean fields?
|
|
|
|
### 2b. Validation — Kiểm tra ràng buộc
|
|
- [ ] Required fields có validation trước khi submit?
|
|
- [ ] Date range: ToDate >= FromDate?
|
|
- [ ] Time range: ToTime > FromTime (trừ ca đêm)?
|
|
- [ ] Số lượng/giá trị > 0 khi cần?
|
|
- [ ] Có hiện Toast warning với message cụ thể khi validation fail?
|
|
|
|
### 2c. API Error Handling — Xử lý lỗi API
|
|
- [ ] Mọi POST/PUT/DELETE API call có kiểm tra `resp.IsSuccessStatusCode`?
|
|
- [ ] Khi API fail, có **throw exception** (KHÔNG return default value im lặng)?
|
|
- [ ] Error message có đọc `resp.Content` để hiển thị chi tiết?
|
|
- [ ] Frontend handler có `try/catch` bao bọc API call?
|
|
- [ ] Catch block có hiện `Toast.Error()` với `ex.Message`?
|
|
|
|
### 2d. Popup / Form Reset
|
|
- [ ] `ShowAddXxx()` reset TẤT CẢ field về default (không chỉ một vài)?
|
|
- [ ] Date fields reset về `DateTime.Today` (không để giá trị cũ)?
|
|
- [ ] Nullable fields reset về `null`?
|
|
- [ ] String fields reset về `""`?
|
|
|
|
### 2e. Grid Display — Hiển thị dữ liệu
|
|
- [ ] Grid columns khớp với DTO properties cần hiển thị?
|
|
- [ ] Enum columns hiển thị text thay vì số (e.g., "Phép năm" thay vì "0")?
|
|
- [ ] Date/Time columns format đúng?
|
|
- [ ] Có column thừa hoặc thiếu?
|
|
|
|
### 2f. Data Integrity — Tính toàn vẹn dữ liệu
|
|
- [ ] Default values trong entity có hợp lý? (e.g., DateOnly default = 0001-01-01 → cần set mặc định)
|
|
- [ ] Foreign key relationships có valid? (e.g., EmployeeId phải tồn tại)
|
|
- [ ] Seed data có đủ cho tất cả dropdowns?
|
|
|
|
---
|
|
|
|
## Phase 3: REPORT — Báo cáo audit
|
|
|
|
Tạo danh sách issues theo severity:
|
|
|
|
```markdown
|
|
### 🔴 Critical — Silent failures, data loss
|
|
### 🟡 Medium — Missing fields, hardcoded values
|
|
### 🟢 Low — UI polish, format
|
|
```
|
|
|
|
---
|
|
|
|
## Phase 4: FIX — Sửa batch
|
|
|
|
// turbo-all
|
|
|
|
1. **Sửa tất cả issues trong batch** — ưu tiên Critical → Medium → Low
|
|
2. **Build:**
|
|
```powershell
|
|
dotnet build INS.HRM.slnx
|
|
```
|
|
3. **Test:**
|
|
```powershell
|
|
dotnet test src/INS.HRM.Backend/INS.HRM.Backend.csproj
|
|
```
|
|
4. **Start server:**
|
|
```powershell
|
|
dotnet run --project src/INS.HRM.Backend
|
|
```
|
|
|
|
---
|
|
|
|
## Phase 5: VERIFY — Xác nhận
|
|
|
|
5. Tóm tắt kết quả cho user:
|
|
- Số issues tìm được
|
|
- Số issues đã sửa
|
|
- Build status
|
|
- Test status
|
|
|
|
---
|
|
|
|
## Examples
|
|
|
|
```
|
|
/audit trang chấm công
|
|
/audit module nhân viên
|
|
/audit tất cả các form trên trang tổ chức
|
|
/audit page recruitment
|
|
```
|