- llm table: add status field (published/unpublished, default unpublished)
- User-facing queries: filter by status='published' in 11 query points:
- utils.py: get_llms_by_catelog_to_customer, get_llms_by_catelog,
get_llm, get_llmproviders, get_llms_sort_by_provider
- v1 endpoints: chat/completions, image/generations, video/generations
- user pages: t2t, get_type_llms, list_catelog_models,
list_paging_catelog_llms, llmcheck
- CRUD: status column visible/editable with select dropdown
- Admin CRUD list shows ALL models regardless of status
- Migration SQL: sql/add_status_field.sql (existing models set to published)
40 lines
1.1 KiB
Plaintext
40 lines
1.1 KiB
Plaintext
if int(params_kw._is_mobile) == 1:
|
|
pagerows = 80
|
|
else:
|
|
pagerows = 260
|
|
page = int(params_kw.get('page', 1))
|
|
dbname = get_module_dbname('llmage')
|
|
db = DBPools()
|
|
async with db.sqlorContext(dbname) as sor:
|
|
sql = """select x.*,
|
|
z.input_fields,
|
|
y.system_message,
|
|
y.user_message,
|
|
y.assisant_message
|
|
from (
|
|
select distinct a.*, b.hfid, e.ioid, e.stream
|
|
from llm a
|
|
join llm_api_map m on a.id = m.llmid
|
|
join llmcatelog b on m.llmcatelogid = b.id
|
|
join upapp c on a.upappid = c.id
|
|
join uapi e on c.apisetid = e.apisetid and a.apiname = e.name
|
|
where a.status = 'published'
|
|
) x left join historyformat y on x.hfid = y.id
|
|
left join uapiio z on x.ioid = z.id
|
|
where m.llmcatelogid = ${llmcatelogid}$
|
|
and x.id != ${llmid}$
|
|
"""
|
|
ns = params_kw.copy()
|
|
ns.page = page
|
|
ns.pagerows = pagerows
|
|
recs = await sor.sqlPaging(sql, ns)
|
|
for r in recs.get('rows', []):
|
|
r.llmid = r.id
|
|
r.modelname = r.name
|
|
r.description = ''.join(''.join(r.description.split('\n')).split('\r'))
|
|
r.response_mode = r.stream
|
|
r.icon = entire_url('/appbase/show_icon.dspy') + f'?id={r.iconid}'
|
|
r.url = entire_url('/llmage/llminference.dspy')
|
|
return recs
|
|
return {}
|