feat(import): track release date evidence tiers
This commit is contained in:
@@ -28,6 +28,8 @@ type ModelPricing struct {
|
||||
SourceURL string
|
||||
ModelSourceURL string
|
||||
ReleaseDate string
|
||||
DateConfidence string
|
||||
DateSourceKind string
|
||||
Modality string
|
||||
SceneTags []string
|
||||
}
|
||||
@@ -47,6 +49,8 @@ type zhipuModelMetadata struct {
|
||||
Prefix string
|
||||
ReleaseDate string
|
||||
ModelSourceURL string
|
||||
DateConfidence string
|
||||
DateSourceKind string
|
||||
}
|
||||
|
||||
var zhipuModelMetadataRules = []zhipuModelMetadata{
|
||||
@@ -54,36 +58,50 @@ var zhipuModelMetadataRules = []zhipuModelMetadata{
|
||||
Prefix: "glm-5-turbo",
|
||||
ReleaseDate: "2026-03-15",
|
||||
ModelSourceURL: "https://www.zhipuai.cn/en/research/155",
|
||||
DateConfidence: "official_primary",
|
||||
DateSourceKind: "official_announcement",
|
||||
},
|
||||
{
|
||||
Prefix: "glm-5.1",
|
||||
ReleaseDate: "2026-04-07",
|
||||
ModelSourceURL: "https://www.zhipuai.cn/zh/research",
|
||||
DateConfidence: "official_primary",
|
||||
DateSourceKind: "official_announcement",
|
||||
},
|
||||
{
|
||||
Prefix: "glm-5",
|
||||
ReleaseDate: "2026-02-11",
|
||||
ModelSourceURL: "https://www.zhipuai.cn/zh/research/154",
|
||||
DateConfidence: "official_primary",
|
||||
DateSourceKind: "official_announcement",
|
||||
},
|
||||
{
|
||||
Prefix: "glm-4.7-flash",
|
||||
ReleaseDate: "2026-01-19",
|
||||
ModelSourceURL: "https://www.zhipuai.cn/zh/news/148",
|
||||
DateConfidence: "official_primary",
|
||||
DateSourceKind: "official_announcement",
|
||||
},
|
||||
{
|
||||
Prefix: "glm-4.7",
|
||||
ReleaseDate: "2025-12-21",
|
||||
ModelSourceURL: "https://www.zhipuai.cn/zh/research",
|
||||
DateConfidence: "official_primary",
|
||||
DateSourceKind: "official_announcement",
|
||||
},
|
||||
{
|
||||
Prefix: "glm-4.6v",
|
||||
ReleaseDate: "2025-12-07",
|
||||
ModelSourceURL: "https://www.zhipuai.cn/zh/research/144",
|
||||
DateConfidence: "official_primary",
|
||||
DateSourceKind: "official_announcement",
|
||||
},
|
||||
{
|
||||
Prefix: "glm-tts",
|
||||
ReleaseDate: "2025-12-10",
|
||||
ModelSourceURL: "https://www.zhipuai.cn/zh/research",
|
||||
DateConfidence: "official_primary",
|
||||
DateSourceKind: "official_announcement",
|
||||
},
|
||||
}
|
||||
|
||||
@@ -96,17 +114,32 @@ func enrichZhipuModelMetadata(model ModelPricing) ModelPricing {
|
||||
if metadata.ModelSourceURL != "" {
|
||||
model.ModelSourceURL = metadata.ModelSourceURL
|
||||
}
|
||||
if metadata.DateConfidence != "" {
|
||||
model.DateConfidence = metadata.DateConfidence
|
||||
}
|
||||
if metadata.DateSourceKind != "" {
|
||||
model.DateSourceKind = metadata.DateSourceKind
|
||||
}
|
||||
return model
|
||||
}
|
||||
}
|
||||
if model.ModelSourceURL == "" {
|
||||
model.ModelSourceURL = model.SourceURL
|
||||
}
|
||||
if model.DateConfidence == "" {
|
||||
model.DateConfidence = "unknown"
|
||||
}
|
||||
if model.DateSourceKind == "" {
|
||||
model.DateSourceKind = "unknown"
|
||||
}
|
||||
return model
|
||||
}
|
||||
|
||||
func hasExplicitModelMetadata(model ModelPricing) bool {
|
||||
return strings.TrimSpace(model.ReleaseDate) != "" || firstNonEmpty(model.ModelSourceURL) != "" && model.ModelSourceURL != model.SourceURL
|
||||
return strings.TrimSpace(model.ReleaseDate) != "" ||
|
||||
firstNonEmpty(model.ModelSourceURL) != "" && model.ModelSourceURL != model.SourceURL ||
|
||||
strings.TrimSpace(model.DateConfidence) != "" && model.DateConfidence != "unknown" ||
|
||||
strings.TrimSpace(model.DateSourceKind) != "" && model.DateSourceKind != "unknown"
|
||||
}
|
||||
|
||||
func main() {
|
||||
@@ -228,9 +261,9 @@ func main() {
|
||||
err = db.QueryRow("SELECT id FROM models WHERE external_id = $1", p.ModelID).Scan(&modelID)
|
||||
if err == sql.ErrNoRows {
|
||||
err = db.QueryRow(
|
||||
`INSERT INTO models (external_id, name, provider_id, modality, context_length, status, source, batch_id, source_url, release_date)
|
||||
VALUES ($1, $2, $3, $4, $5, 'active', $6, $7, $8, $9) RETURNING id`,
|
||||
p.ModelID, p.ModelName, providerID, p.Modality, p.ContextLength, p.OperatorName, batchID, firstNonEmpty(p.ModelSourceURL, p.SourceURL), releaseDateValue(p.ReleaseDate),
|
||||
`INSERT INTO models (external_id, name, provider_id, modality, context_length, status, source, batch_id, source_url, release_date, date_confidence, date_source_kind)
|
||||
VALUES ($1, $2, $3, $4, $5, 'active', $6, $7, $8, $9, $10, $11) RETURNING id`,
|
||||
p.ModelID, p.ModelName, providerID, p.Modality, p.ContextLength, p.OperatorName, batchID, firstNonEmpty(p.ModelSourceURL, p.SourceURL), releaseDateValue(p.ReleaseDate), p.DateConfidence, p.DateSourceKind,
|
||||
).Scan(&modelID)
|
||||
}
|
||||
if err != nil {
|
||||
@@ -244,12 +277,20 @@ func main() {
|
||||
ELSE COALESCE(NULLIF(source_url, ''), $2)
|
||||
END,
|
||||
release_date = CASE
|
||||
WHEN $4 AND $3::date IS NOT NULL THEN $3::date
|
||||
WHEN $4 THEN $3::date
|
||||
ELSE COALESCE(release_date, $3::date)
|
||||
END,
|
||||
date_confidence = CASE
|
||||
WHEN $4 THEN $5
|
||||
ELSE COALESCE(NULLIF(date_confidence, ''), $5, 'unknown')
|
||||
END,
|
||||
date_source_kind = CASE
|
||||
WHEN $4 THEN $6
|
||||
ELSE COALESCE(NULLIF(date_source_kind, ''), $6, 'unknown')
|
||||
END,
|
||||
updated_at = CURRENT_TIMESTAMP
|
||||
WHERE id = $1`,
|
||||
modelID, firstNonEmpty(p.ModelSourceURL, p.SourceURL), releaseDateValue(p.ReleaseDate), hasExplicitModelMetadata(p),
|
||||
modelID, firstNonEmpty(p.ModelSourceURL, p.SourceURL), releaseDateValue(p.ReleaseDate), hasExplicitModelMetadata(p), p.DateConfidence, p.DateSourceKind,
|
||||
); err != nil {
|
||||
log.Printf("Model metadata update error for %s: %v", p.ModelID, err)
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user