-
-
Notifications
You must be signed in to change notification settings - Fork 148
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Fixed ResponseObjectFormat deserialization when set to auto - Added RankingOptions to FileSearchOptions - Fixed potential memory leaks when uploading files to various endpoints
- Loading branch information
1 parent
d79c4d4
commit 0a8a0d1
Showing
14 changed files
with
223 additions
and
84 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,50 @@ | ||
// Licensed under the MIT License. See LICENSE in the project root for license information. | ||
|
||
using System; | ||
using System.Text.Json.Serialization; | ||
|
||
namespace OpenAI | ||
{ | ||
/// <summary> | ||
/// The ranking options for the file search. | ||
/// <see href="https://platform.openai.com/docs/assistants/tools/file-search/customizing-file-search-settings"/> | ||
/// </summary> | ||
public sealed class RankingOptions | ||
{ | ||
/// <summary> | ||
/// Constructor. | ||
/// </summary> | ||
/// <param name="ranker"> | ||
/// The ranker to use for the file search. | ||
/// If not specified will use the `auto` ranker. | ||
/// </param> | ||
/// <param name="scoreThreshold"> | ||
/// The score threshold for the file search. | ||
/// All values must be a floating point number between 0 and 1. | ||
/// </param> | ||
/// <exception cref="ArgumentOutOfRangeException"></exception> | ||
[JsonConstructor] | ||
public RankingOptions(string ranker = "auto", float scoreThreshold = 0f) | ||
{ | ||
Ranker = ranker; | ||
ScoreThreshold = scoreThreshold switch | ||
{ | ||
< 0 => throw new ArgumentOutOfRangeException(nameof(scoreThreshold), "Score threshold must be greater than or equal to 0."), | ||
> 1 => throw new ArgumentOutOfRangeException(nameof(scoreThreshold), "Score threshold must be less than or equal to 1."), | ||
_ => scoreThreshold | ||
}; | ||
} | ||
|
||
/// <summary> | ||
/// The ranker to use for the file search. | ||
/// </summary> | ||
[JsonPropertyName("ranker")] | ||
public string Ranker { get; } | ||
|
||
/// <summary> | ||
/// The score threshold for the file search. | ||
/// </summary> | ||
[JsonPropertyName("score_threshold")] | ||
public float ScoreThreshold { get; } | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,34 @@ | ||
// Licensed under the MIT License. See LICENSE in the project root for license information. | ||
|
||
using System; | ||
using System.Text.Json; | ||
using System.Text.Json.Serialization; | ||
|
||
namespace OpenAI.Extensions | ||
{ | ||
internal sealed class ResponseFormatConverter : JsonConverter<ResponseFormatObject> | ||
{ | ||
public override ResponseFormatObject Read(ref Utf8JsonReader reader, Type typeToConvert, JsonSerializerOptions options) | ||
{ | ||
try | ||
{ | ||
if (reader.TokenType is JsonTokenType.Null or JsonTokenType.String) | ||
{ | ||
return ChatResponseFormat.Auto; | ||
} | ||
|
||
return JsonSerializer.Deserialize<ResponseFormatObject>(ref reader, options); | ||
} | ||
catch (Exception e) | ||
{ | ||
throw new Exception($"Error reading {typeof(ChatResponseFormat)} from JSON.", e); | ||
} | ||
} | ||
|
||
public override void Write(Utf8JsonWriter writer, ResponseFormatObject value, JsonSerializerOptions options) | ||
{ | ||
// serialize the object normally | ||
JsonSerializer.Serialize(writer, value, options); | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.