@mistralai/mistralai 2.0.0-alpha.1 → 2.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +8 -6
- package/esm/extra/structChat.d.ts.map +1 -1
- package/esm/extra/structChat.js +71 -4
- package/esm/extra/structChat.js.map +1 -1
- package/esm/funcs/betaConnectorsGetAuthUrl.d.ts +19 -0
- package/esm/funcs/betaConnectorsGetAuthUrl.d.ts.map +1 -0
- package/esm/funcs/betaConnectorsGetAuthUrl.js +90 -0
- package/esm/funcs/betaConnectorsGetAuthUrl.js.map +1 -0
- package/esm/funcs/betaObservabilityJudgesJudgeConversation.d.ts +16 -0
- package/esm/funcs/betaObservabilityJudgesJudgeConversation.d.ts.map +1 -0
- package/esm/funcs/betaObservabilityJudgesJudgeConversation.js +91 -0
- package/esm/funcs/betaObservabilityJudgesJudgeConversation.js.map +1 -0
- package/esm/lib/config.d.ts +2 -2
- package/esm/lib/config.js +2 -2
- package/esm/lib/config.js.map +1 -1
- package/esm/models/components/agentscompletionrequest.d.ts +6 -0
- package/esm/models/components/agentscompletionrequest.d.ts.map +1 -1
- package/esm/models/components/agentscompletionrequest.js +5 -0
- package/esm/models/components/agentscompletionrequest.js.map +1 -1
- package/esm/models/components/agentscompletionstreamrequest.d.ts +6 -0
- package/esm/models/components/agentscompletionstreamrequest.d.ts.map +1 -1
- package/esm/models/components/agentscompletionstreamrequest.js +5 -0
- package/esm/models/components/agentscompletionstreamrequest.js.map +1 -1
- package/esm/models/components/authurlresponse.d.ts +11 -0
- package/esm/models/components/authurlresponse.d.ts.map +1 -0
- package/esm/models/components/authurlresponse.js +20 -0
- package/esm/models/components/authurlresponse.js.map +1 -0
- package/esm/models/components/basemodelcard.d.ts +6 -0
- package/esm/models/components/basemodelcard.d.ts.map +1 -1
- package/esm/models/components/basemodelcard.js.map +1 -1
- package/esm/models/components/chatcompletionrequest.d.ts +6 -0
- package/esm/models/components/chatcompletionrequest.d.ts.map +1 -1
- package/esm/models/components/chatcompletionrequest.js +5 -0
- package/esm/models/components/chatcompletionrequest.js.map +1 -1
- package/esm/models/components/chatcompletionstreamrequest.d.ts +6 -0
- package/esm/models/components/chatcompletionstreamrequest.d.ts.map +1 -1
- package/esm/models/components/chatcompletionstreamrequest.js +5 -0
- package/esm/models/components/chatcompletionstreamrequest.js.map +1 -1
- package/esm/models/components/conversationresponse.d.ts +3 -5
- package/esm/models/components/conversationresponse.d.ts.map +1 -1
- package/esm/models/components/conversationresponse.js +1 -7
- package/esm/models/components/conversationresponse.js.map +1 -1
- package/esm/models/components/ftmodelcard.d.ts +6 -0
- package/esm/models/components/ftmodelcard.d.ts.map +1 -1
- package/esm/models/components/ftmodelcard.js.map +1 -1
- package/esm/models/components/imageurlchunk.d.ts +1 -1
- package/esm/models/components/index.d.ts +3 -0
- package/esm/models/components/index.d.ts.map +1 -1
- package/esm/models/components/index.js +3 -0
- package/esm/models/components/index.js.map +1 -1
- package/esm/models/components/instructrequest.d.ts +3 -0
- package/esm/models/components/instructrequest.d.ts.map +1 -1
- package/esm/models/components/instructrequest.js.map +1 -1
- package/esm/models/components/judgeconversationrequest.d.ts +22 -0
- package/esm/models/components/judgeconversationrequest.d.ts.map +1 -0
- package/esm/models/components/judgeconversationrequest.js +14 -0
- package/esm/models/components/judgeconversationrequest.js.map +1 -0
- package/esm/models/components/modelcapabilities.d.ts +8 -0
- package/esm/models/components/modelcapabilities.d.ts.map +1 -1
- package/esm/models/components/modelcapabilities.js +4 -0
- package/esm/models/components/modelcapabilities.js.map +1 -1
- package/esm/models/components/reasoningeffort.d.ts +10 -0
- package/esm/models/components/reasoningeffort.d.ts.map +1 -0
- package/esm/models/components/reasoningeffort.js +12 -0
- package/esm/models/components/reasoningeffort.js.map +1 -0
- package/esm/models/components/referencechunk.d.ts +11 -2
- package/esm/models/components/referencechunk.d.ts.map +1 -1
- package/esm/models/components/referencechunk.js +13 -2
- package/esm/models/components/referencechunk.js.map +1 -1
- package/esm/models/operations/connectorgetauthurlv1.d.ts +14 -0
- package/esm/models/operations/connectorgetauthurlv1.d.ts.map +1 -0
- package/esm/models/operations/connectorgetauthurlv1.js +20 -0
- package/esm/models/operations/connectorgetauthurlv1.js.map +1 -0
- package/esm/models/operations/index.d.ts +2 -0
- package/esm/models/operations/index.d.ts.map +1 -1
- package/esm/models/operations/index.js +2 -0
- package/esm/models/operations/index.js.map +1 -1
- package/esm/models/operations/judgeconversationv1observabilityjudgesjudgeidlivejudgingpost.d.ts +15 -0
- package/esm/models/operations/judgeconversationv1observabilityjudgesjudgeidlivejudgingpost.d.ts.map +1 -0
- package/esm/models/operations/judgeconversationv1observabilityjudgesjudgeidlivejudgingpost.js +22 -0
- package/esm/models/operations/judgeconversationv1observabilityjudgesjudgeidlivejudgingpost.js.map +1 -0
- package/esm/sdk/connectors.d.ts +7 -0
- package/esm/sdk/connectors.d.ts.map +1 -1
- package/esm/sdk/connectors.js +10 -0
- package/esm/sdk/connectors.js.map +1 -1
- package/esm/sdk/judges.d.ts +4 -0
- package/esm/sdk/judges.d.ts.map +1 -1
- package/esm/sdk/judges.js +7 -0
- package/esm/sdk/judges.js.map +1 -1
- package/examples/src/gcp/async_chat_no_streaming.ts +2 -2
- package/jsr.json +1 -1
- package/package.json +8 -3
- package/packages/mistralai-gcp/examples/chatComplete.example.ts +3 -3
- package/packages/mistralai-gcp/src/core.ts +1 -1
- package/packages/mistralai-gcp/src/funcs/chatComplete.ts +7 -7
- package/packages/mistralai-gcp/src/funcs/chatStream.ts +7 -7
- package/packages/mistralai-gcp/src/funcs/fimComplete.ts +7 -7
- package/packages/mistralai-gcp/src/funcs/fimStream.ts +7 -7
- package/packages/mistralai-gcp/src/models/errors/httpvalidationerror.ts +2 -2
- package/packages/mistralai-gcp/src/models/errors/mistralgoogleclouderror.ts +2 -2
- package/packages/mistralai-gcp/src/models/errors/responsevalidationerror.ts +2 -2
- package/packages/mistralai-gcp/src/models/errors/sdkerror.ts +2 -2
- package/packages/mistralai-gcp/src/sdk/sdk.ts +6 -5
- package/src/extra/structChat.ts +69 -3
- package/src/funcs/betaConnectorsGetAuthUrl.ts +186 -0
- package/src/funcs/betaObservabilityJudgesJudgeConversation.ts +188 -0
- package/src/lib/config.ts +2 -2
- package/src/models/components/agentscompletionrequest.ts +16 -0
- package/src/models/components/agentscompletionstreamrequest.ts +16 -0
- package/src/models/components/authurlresponse.ts +38 -0
- package/src/models/components/basemodelcard.ts +6 -0
- package/src/models/components/chatcompletionrequest.ts +16 -0
- package/src/models/components/chatcompletionstreamrequest.ts +16 -0
- package/src/models/components/conversationresponse.ts +2 -20
- package/src/models/components/ftmodelcard.ts +6 -0
- package/src/models/components/imageurlchunk.ts +1 -1
- package/src/models/components/index.ts +3 -0
- package/src/models/components/instructrequest.ts +3 -0
- package/src/models/components/judgeconversationrequest.ts +34 -0
- package/src/models/components/modelcapabilities.ts +12 -0
- package/src/models/components/reasoningeffort.ts +17 -0
- package/src/models/components/referencechunk.ts +32 -4
- package/src/models/operations/connectorgetauthurlv1.ts +42 -0
- package/src/models/operations/index.ts +2 -0
- package/src/models/operations/judgeconversationv1observabilityjudgesjudgeidlivejudgingpost.ts +49 -0
- package/src/sdk/connectors.ts +18 -0
- package/src/sdk/judges.ts +16 -0
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
|
|
3
|
+
* @generated-id: 5cfdc909f234
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
import * as z from "zod/v4";
|
|
7
|
+
import { ClosedEnum } from "../../types/enums.js";
|
|
8
|
+
|
|
9
|
+
export const ReasoningEffort = {
|
|
10
|
+
None: "none",
|
|
11
|
+
High: "high",
|
|
12
|
+
} as const;
|
|
13
|
+
export type ReasoningEffort = ClosedEnum<typeof ReasoningEffort>;
|
|
14
|
+
|
|
15
|
+
/** @internal */
|
|
16
|
+
export const ReasoningEffort$outboundSchema: z.ZodEnum<typeof ReasoningEffort> =
|
|
17
|
+
z.enum(ReasoningEffort);
|
|
@@ -7,18 +7,46 @@ import * as z from "zod/v4";
|
|
|
7
7
|
import { remap as remap$ } from "../../lib/primitives.js";
|
|
8
8
|
import { safeParse } from "../../lib/schemas.js";
|
|
9
9
|
import { Result as SafeParseResult } from "../../types/fp.js";
|
|
10
|
+
import { smartUnion } from "../../types/smartUnion.js";
|
|
10
11
|
import { SDKValidationError } from "../errors/sdkvalidationerror.js";
|
|
11
12
|
|
|
13
|
+
export type ReferenceId = string | number;
|
|
14
|
+
|
|
12
15
|
export type ReferenceChunk = {
|
|
13
16
|
type?: "reference" | undefined;
|
|
14
|
-
referenceIds: Array<number>;
|
|
17
|
+
referenceIds: Array<string | number>;
|
|
15
18
|
};
|
|
16
19
|
|
|
20
|
+
/** @internal */
|
|
21
|
+
export const ReferenceId$inboundSchema: z.ZodType<ReferenceId, unknown> =
|
|
22
|
+
smartUnion([z.string(), z.int()]);
|
|
23
|
+
/** @internal */
|
|
24
|
+
export type ReferenceId$Outbound = string | number;
|
|
25
|
+
|
|
26
|
+
/** @internal */
|
|
27
|
+
export const ReferenceId$outboundSchema: z.ZodType<
|
|
28
|
+
ReferenceId$Outbound,
|
|
29
|
+
ReferenceId
|
|
30
|
+
> = smartUnion([z.string(), z.int()]);
|
|
31
|
+
|
|
32
|
+
export function referenceIdToJSON(referenceId: ReferenceId): string {
|
|
33
|
+
return JSON.stringify(ReferenceId$outboundSchema.parse(referenceId));
|
|
34
|
+
}
|
|
35
|
+
export function referenceIdFromJSON(
|
|
36
|
+
jsonString: string,
|
|
37
|
+
): SafeParseResult<ReferenceId, SDKValidationError> {
|
|
38
|
+
return safeParse(
|
|
39
|
+
jsonString,
|
|
40
|
+
(x) => ReferenceId$inboundSchema.parse(JSON.parse(x)),
|
|
41
|
+
`Failed to parse 'ReferenceId' from JSON`,
|
|
42
|
+
);
|
|
43
|
+
}
|
|
44
|
+
|
|
17
45
|
/** @internal */
|
|
18
46
|
export const ReferenceChunk$inboundSchema: z.ZodType<ReferenceChunk, unknown> =
|
|
19
47
|
z.object({
|
|
20
48
|
type: z.literal("reference").default("reference"),
|
|
21
|
-
reference_ids: z.array(z.int()),
|
|
49
|
+
reference_ids: z.array(smartUnion([z.string(), z.int()])),
|
|
22
50
|
}).transform((v) => {
|
|
23
51
|
return remap$(v, {
|
|
24
52
|
"reference_ids": "referenceIds",
|
|
@@ -27,7 +55,7 @@ export const ReferenceChunk$inboundSchema: z.ZodType<ReferenceChunk, unknown> =
|
|
|
27
55
|
/** @internal */
|
|
28
56
|
export type ReferenceChunk$Outbound = {
|
|
29
57
|
type: "reference";
|
|
30
|
-
reference_ids: Array<number>;
|
|
58
|
+
reference_ids: Array<string | number>;
|
|
31
59
|
};
|
|
32
60
|
|
|
33
61
|
/** @internal */
|
|
@@ -36,7 +64,7 @@ export const ReferenceChunk$outboundSchema: z.ZodType<
|
|
|
36
64
|
ReferenceChunk
|
|
37
65
|
> = z.object({
|
|
38
66
|
type: z.literal("reference").default("reference" as const),
|
|
39
|
-
referenceIds: z.array(z.int()),
|
|
67
|
+
referenceIds: z.array(smartUnion([z.string(), z.int()])),
|
|
40
68
|
}).transform((v) => {
|
|
41
69
|
return remap$(v, {
|
|
42
70
|
referenceIds: "reference_ids",
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
|
|
3
|
+
* @generated-id: e84ab59852d5
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
import * as z from "zod/v4";
|
|
7
|
+
import { remap as remap$ } from "../../lib/primitives.js";
|
|
8
|
+
|
|
9
|
+
export type ConnectorGetAuthUrlV1Request = {
|
|
10
|
+
appReturnUrl?: string | null | undefined;
|
|
11
|
+
connectorIdOrName: string;
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
/** @internal */
|
|
15
|
+
export type ConnectorGetAuthUrlV1Request$Outbound = {
|
|
16
|
+
app_return_url?: string | null | undefined;
|
|
17
|
+
connector_id_or_name: string;
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
/** @internal */
|
|
21
|
+
export const ConnectorGetAuthUrlV1Request$outboundSchema: z.ZodType<
|
|
22
|
+
ConnectorGetAuthUrlV1Request$Outbound,
|
|
23
|
+
ConnectorGetAuthUrlV1Request
|
|
24
|
+
> = z.object({
|
|
25
|
+
appReturnUrl: z.nullable(z.string()).optional(),
|
|
26
|
+
connectorIdOrName: z.string(),
|
|
27
|
+
}).transform((v) => {
|
|
28
|
+
return remap$(v, {
|
|
29
|
+
appReturnUrl: "app_return_url",
|
|
30
|
+
connectorIdOrName: "connector_id_or_name",
|
|
31
|
+
});
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
export function connectorGetAuthUrlV1RequestToJSON(
|
|
35
|
+
connectorGetAuthUrlV1Request: ConnectorGetAuthUrlV1Request,
|
|
36
|
+
): string {
|
|
37
|
+
return JSON.stringify(
|
|
38
|
+
ConnectorGetAuthUrlV1Request$outboundSchema.parse(
|
|
39
|
+
connectorGetAuthUrlV1Request,
|
|
40
|
+
),
|
|
41
|
+
);
|
|
42
|
+
}
|
|
@@ -24,6 +24,7 @@ export * from "./agentsapiv1conversationsrestart.js";
|
|
|
24
24
|
export * from "./agentsapiv1conversationsrestartstream.js";
|
|
25
25
|
export * from "./connectorcalltoolv1.js";
|
|
26
26
|
export * from "./connectordeletev1.js";
|
|
27
|
+
export * from "./connectorgetauthurlv1.js";
|
|
27
28
|
export * from "./connectorgetv1.js";
|
|
28
29
|
export * from "./connectorlistv1.js";
|
|
29
30
|
export * from "./connectorupdatev1.js";
|
|
@@ -69,6 +70,7 @@ export * from "./jobsapiroutesfinetuningstartfinetuningjob.js";
|
|
|
69
70
|
export * from "./jobsapiroutesfinetuningunarchivefinetunedmodel.js";
|
|
70
71
|
export * from "./jobsapiroutesfinetuningupdatefinetunedmodel.js";
|
|
71
72
|
export * from "./judgechatcompletioneventv1observabilitychatcompletioneventseventidlivejudgingpost.js";
|
|
73
|
+
export * from "./judgeconversationv1observabilityjudgesjudgeidlivejudgingpost.js";
|
|
72
74
|
export * from "./judgedatasetrecordv1observabilitydatasetrecordsdatasetrecordidlivejudgingpost.js";
|
|
73
75
|
export * from "./librariesdeletev1.js";
|
|
74
76
|
export * from "./librariesdocumentsdeletev1.js";
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
|
|
3
|
+
* @generated-id: 1a19d380a20c
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
import * as z from "zod/v4";
|
|
7
|
+
import { remap as remap$ } from "../../lib/primitives.js";
|
|
8
|
+
import * as components from "../components/index.js";
|
|
9
|
+
|
|
10
|
+
export type JudgeConversationV1ObservabilityJudgesJudgeIdLiveJudgingPostRequest =
|
|
11
|
+
{
|
|
12
|
+
judgeId: string;
|
|
13
|
+
judgeConversationRequest: components.JudgeConversationRequest;
|
|
14
|
+
};
|
|
15
|
+
|
|
16
|
+
/** @internal */
|
|
17
|
+
export type JudgeConversationV1ObservabilityJudgesJudgeIdLiveJudgingPostRequest$Outbound =
|
|
18
|
+
{
|
|
19
|
+
judge_id: string;
|
|
20
|
+
JudgeConversationRequest: components.JudgeConversationRequest$Outbound;
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
/** @internal */
|
|
24
|
+
export const JudgeConversationV1ObservabilityJudgesJudgeIdLiveJudgingPostRequest$outboundSchema:
|
|
25
|
+
z.ZodType<
|
|
26
|
+
JudgeConversationV1ObservabilityJudgesJudgeIdLiveJudgingPostRequest$Outbound,
|
|
27
|
+
JudgeConversationV1ObservabilityJudgesJudgeIdLiveJudgingPostRequest
|
|
28
|
+
> = z.object({
|
|
29
|
+
judgeId: z.string(),
|
|
30
|
+
judgeConversationRequest:
|
|
31
|
+
components.JudgeConversationRequest$outboundSchema,
|
|
32
|
+
}).transform((v) => {
|
|
33
|
+
return remap$(v, {
|
|
34
|
+
judgeId: "judge_id",
|
|
35
|
+
judgeConversationRequest: "JudgeConversationRequest",
|
|
36
|
+
});
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
export function judgeConversationV1ObservabilityJudgesJudgeIdLiveJudgingPostRequestToJSON(
|
|
40
|
+
judgeConversationV1ObservabilityJudgesJudgeIdLiveJudgingPostRequest:
|
|
41
|
+
JudgeConversationV1ObservabilityJudgesJudgeIdLiveJudgingPostRequest,
|
|
42
|
+
): string {
|
|
43
|
+
return JSON.stringify(
|
|
44
|
+
JudgeConversationV1ObservabilityJudgesJudgeIdLiveJudgingPostRequest$outboundSchema
|
|
45
|
+
.parse(
|
|
46
|
+
judgeConversationV1ObservabilityJudgesJudgeIdLiveJudgingPostRequest,
|
|
47
|
+
),
|
|
48
|
+
);
|
|
49
|
+
}
|
package/src/sdk/connectors.ts
CHANGED
|
@@ -7,6 +7,7 @@ import { betaConnectorsCallTool } from "../funcs/betaConnectorsCallTool.js";
|
|
|
7
7
|
import { betaConnectorsCreate } from "../funcs/betaConnectorsCreate.js";
|
|
8
8
|
import { betaConnectorsDelete } from "../funcs/betaConnectorsDelete.js";
|
|
9
9
|
import { betaConnectorsGet } from "../funcs/betaConnectorsGet.js";
|
|
10
|
+
import { betaConnectorsGetAuthUrl } from "../funcs/betaConnectorsGetAuthUrl.js";
|
|
10
11
|
import { betaConnectorsList } from "../funcs/betaConnectorsList.js";
|
|
11
12
|
import { betaConnectorsUpdate } from "../funcs/betaConnectorsUpdate.js";
|
|
12
13
|
import { ClientSDK, RequestOptions } from "../lib/sdks.js";
|
|
@@ -49,6 +50,23 @@ export class Connectors extends ClientSDK {
|
|
|
49
50
|
));
|
|
50
51
|
}
|
|
51
52
|
|
|
53
|
+
/**
|
|
54
|
+
* Get the auth URL for a connector.
|
|
55
|
+
*
|
|
56
|
+
* @remarks
|
|
57
|
+
* Get the OAuth2 authorization URL for a connector to initiate user authentication.
|
|
58
|
+
*/
|
|
59
|
+
async getAuthUrl(
|
|
60
|
+
request: operations.ConnectorGetAuthUrlV1Request,
|
|
61
|
+
options?: RequestOptions,
|
|
62
|
+
): Promise<components.AuthUrlResponse> {
|
|
63
|
+
return unwrapAsync(betaConnectorsGetAuthUrl(
|
|
64
|
+
this,
|
|
65
|
+
request,
|
|
66
|
+
options,
|
|
67
|
+
));
|
|
68
|
+
}
|
|
69
|
+
|
|
52
70
|
/**
|
|
53
71
|
* Call Connector Tool
|
|
54
72
|
*
|
package/src/sdk/judges.ts
CHANGED
|
@@ -6,6 +6,7 @@
|
|
|
6
6
|
import { betaObservabilityJudgesCreate } from "../funcs/betaObservabilityJudgesCreate.js";
|
|
7
7
|
import { betaObservabilityJudgesDelete } from "../funcs/betaObservabilityJudgesDelete.js";
|
|
8
8
|
import { betaObservabilityJudgesFetch } from "../funcs/betaObservabilityJudgesFetch.js";
|
|
9
|
+
import { betaObservabilityJudgesJudgeConversation } from "../funcs/betaObservabilityJudgesJudgeConversation.js";
|
|
9
10
|
import { betaObservabilityJudgesList } from "../funcs/betaObservabilityJudgesList.js";
|
|
10
11
|
import { betaObservabilityJudgesUpdate } from "../funcs/betaObservabilityJudgesUpdate.js";
|
|
11
12
|
import { ClientSDK, RequestOptions } from "../lib/sdks.js";
|
|
@@ -83,4 +84,19 @@ export class Judges extends ClientSDK {
|
|
|
83
84
|
options,
|
|
84
85
|
));
|
|
85
86
|
}
|
|
87
|
+
|
|
88
|
+
/**
|
|
89
|
+
* Run a saved judge on a conversation
|
|
90
|
+
*/
|
|
91
|
+
async judgeConversation(
|
|
92
|
+
request:
|
|
93
|
+
operations.JudgeConversationV1ObservabilityJudgesJudgeIdLiveJudgingPostRequest,
|
|
94
|
+
options?: RequestOptions,
|
|
95
|
+
): Promise<components.JudgeOutput> {
|
|
96
|
+
return unwrapAsync(betaObservabilityJudgesJudgeConversation(
|
|
97
|
+
this,
|
|
98
|
+
request,
|
|
99
|
+
options,
|
|
100
|
+
));
|
|
101
|
+
}
|
|
86
102
|
}
|