Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Menu
Open sidebar
ox696c
ktransformers
Commits
c995bdbb
Commit
c995bdbb
authored
Apr 22, 2025
by
Alisehen
Browse files
add check-para
parent
48558801
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
114 additions
and
4 deletions
+114
-4
ktransformers/server/api/openai/endpoints/chat.py
ktransformers/server/api/openai/endpoints/chat.py
+62
-2
ktransformers/server/api/openai/legacy/completions.py
ktransformers/server/api/openai/legacy/completions.py
+52
-2
No files found.
ktransformers/server/api/openai/endpoints/chat.py
View file @
c995bdbb
...
...
@@ -13,7 +13,7 @@ from ktransformers.server.schemas.endpoints.chat import RawUsage, Role
from
ktransformers.server.backend.base
import
BackendInterfaceBase
from
ktransformers.server.config.config
import
Config
from
ktransformers.server.config.log
import
logger
from
fastapi.responses
import
JSONResponse
from
ktransformers.server.schemas.endpoints.chat
import
ChatCompletionChunk
# Define own data structure instead of importing from OpenAI
...
...
@@ -143,7 +143,67 @@ async def chat_completion(request: Request, create: ChatCompletionCreate):
# Process messages with tool functionality if needed
enhanced_messages
=
list
(
create
.
messages
)
if
create
.
model
!=
Config
().
model_name
:
return
JSONResponse
(
status_code
=
400
,
content
=
{
"error"
:
{
"message"
:
"Model not found"
,
"code"
:
404
,
"type"
:
"NotFound"
}
})
if
create
.
max_tokens
<
0
or
create
.
max_completion_tokens
<
0
:
return
JSONResponse
(
status_code
=
400
,
content
=
{
"object"
:
"error"
,
"message"
:
f
"max_new_tokens must be at least 0, got
{
create
.
max_tokens
}
."
,
"type"
:
"BadRequestError"
,
"param"
:
None
,
"code"
:
400
})
if
create
.
temperature
<
0
or
create
.
temperature
>
2
:
return
JSONResponse
(
status_code
=
400
,
content
=
{
"object"
:
"error"
,
"message"
:
f
"temperature must be in [0, 2], got
{
create
.
temperature
}
."
,
"type"
:
"BadRequestError"
,
"param"
:
None
,
"code"
:
400
})
if
create
.
top_p
<=
0
or
create
.
top_p
>
1
:
return
JSONResponse
(
status_code
=
400
,
content
=
{
"object"
:
"error"
,
"message"
:
f
"top_p must be in (0, 1], got
{
create
.
top_p
}
."
,
"type"
:
"BadRequestError"
,
"param"
:
None
,
"code"
:
400
})
if
create
.
frequency_penalty
<-
2
or
create
.
frequency_penalty
>
2
:
return
JSONResponse
(
status_code
=
400
,
content
=
{
"object"
:
"error"
,
"message"
:
f
"frequency_penalty must be in [-2, 2], got
{
create
.
frequency_penalty
}
."
,
"type"
:
"BadRequestError"
,
"param"
:
None
,
"code"
:
400
})
if
create
.
presence_penalty
<-
2
or
create
.
presence_penalty
>
2
:
return
JSONResponse
(
status_code
=
400
,
content
=
{
"object"
:
"error"
,
"message"
:
f
"presence_penalty must be in [-2, 2], got
{
create
.
presence_penalty
}
."
,
"type"
:
"BadRequestError"
,
"param"
:
None
,
"code"
:
400
})
# Check if tools are present
has_tools
=
create
.
tools
and
len
(
create
.
tools
)
>
0
...
...
ktransformers/server/api/openai/legacy/completions.py
View file @
c995bdbb
...
...
@@ -7,13 +7,63 @@ from ktransformers.server.utils.create_interface import get_interface
from
ktransformers.server.schemas.assistants.streaming
import
stream_response
from
ktransformers.server.schemas.legacy.completions
import
CompletionCreate
,
CompletionObject
from
ktransformers.server.schemas.endpoints.chat
import
RawUsage
from
fastapi.responses
import
JSONResponse
from
ktransformers.server.config.config
import
Config
router
=
APIRouter
()
@
router
.
post
(
"/completions"
,
tags
=
[
'openai'
])
async
def
create_completion
(
request
:
Request
,
create
:
CompletionCreate
):
id
=
str
(
uuid4
())
if
create
.
model
!=
Config
().
model_name
:
return
JSONResponse
(
status_code
=
400
,
content
=
{
"error"
:
{
"message"
:
"Model not found"
,
"code"
:
404
,
"type"
:
"NotFound"
}
})
if
create
.
max_tokens
<
0
:
return
JSONResponse
(
status_code
=
400
,
content
=
{
"object"
:
"error"
,
"message"
:
f
"max_new_tokens must be at least 0, got
{
create
.
max_tokens
}
."
,
"type"
:
"BadRequestError"
,
"param"
:
None
,
"code"
:
400
})
if
create
.
max_completion_tokens
<
0
:
return
JSONResponse
(
status_code
=
400
,
content
=
{
"object"
:
"error"
,
"message"
:
f
"max_new_tokens must be at least 0, got
{
create
.
max_completion_tokens
}
."
,
"type"
:
"BadRequestError"
,
"param"
:
None
,
"code"
:
400
})
if
create
.
temperature
<
0
or
create
.
temperature
>
2
:
return
JSONResponse
(
status_code
=
400
,
content
=
{
"object"
:
"error"
,
"message"
:
f
"temperature must be in [0, 2], got
{
create
.
temperature
}
."
,
"type"
:
"BadRequestError"
,
"param"
:
None
,
"code"
:
400
})
if
create
.
top_p
<=
0
or
create
.
top_p
>
1
:
return
JSONResponse
(
status_code
=
400
,
content
=
{
"object"
:
"error"
,
"message"
:
f
"top_p must be in (0, 1], got
{
create
.
top_p
}
."
,
"type"
:
"BadRequestError"
,
"param"
:
None
,
"code"
:
400
})
interface
=
get_interface
()
print
(
f
'COMPLETION INPUT:----
\n
{
create
.
prompt
}
\n
----'
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment