Some checks failed
CI / Lint & TypeCheck (push) Has been cancelled
CI / Unit Tests (push) Has been cancelled
CI / Build Frontend (push) Has been cancelled
CI / Rust Check (push) Has been cancelled
CI / Security Scan (push) Has been cancelled
CI / E2E Tests (push) Has been cancelled
- Fix TIMESTAMPTZ decode errors: add ::TEXT cast to all SELECT queries
where Row structs use String for TIMESTAMPTZ columns (~22 locations)
- Fix Axum 0.7 route params: {id} → :id in billing/knowledge/scheduled_task routes
- Fix JSONB bind: scheduled_task INSERT uses ::jsonb cast for input_payload
- Add billing_test.rs (14 tests): plans, subscription, usage, payments, invoices
- Add scheduled_task_test.rs (12 tests): CRUD, validation, isolation
- Add knowledge_test.rs (20 tests): categories, items, versions, search, analytics, permissions
- Fix auth test regression: 6 tests were failing due to TIMESTAMPTZ type mismatch
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
35 lines
845 B
Rust
35 lines
845 B
Rust
//! 更新 API Token last_used_at Worker
|
|
|
|
use async_trait::async_trait;
|
|
use sqlx::PgPool;
|
|
use serde::{Serialize, Deserialize};
|
|
use crate::error::SaasResult;
|
|
use super::Worker;
|
|
|
|
#[derive(Debug, Serialize, Deserialize)]
|
|
pub struct UpdateLastUsedArgs {
|
|
/// token_hash 用于 WHERE 条件匹配
|
|
pub token_hash: String,
|
|
}
|
|
|
|
pub struct UpdateLastUsedWorker;
|
|
|
|
#[async_trait]
|
|
impl Worker for UpdateLastUsedWorker {
|
|
type Args = UpdateLastUsedArgs;
|
|
|
|
fn name(&self) -> &str {
|
|
"update_last_used"
|
|
}
|
|
|
|
async fn perform(&self, db: &PgPool, args: Self::Args) -> SaasResult<()> {
|
|
let now = chrono::Utc::now();
|
|
sqlx::query("UPDATE api_tokens SET last_used_at = $1 WHERE token_hash = $2")
|
|
.bind(&now)
|
|
.bind(&args.token_hash)
|
|
.execute(db)
|
|
.await?;
|
|
Ok(())
|
|
}
|
|
}
|