forked from github/copilot-sdk-java
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathCreateSessionRequest.java
More file actions
276 lines (215 loc) · 8.5 KB
/
CreateSessionRequest.java
File metadata and controls
276 lines (215 loc) · 8.5 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
/*---------------------------------------------------------------------------------------------
* Copyright (c) Microsoft Corporation. All rights reserved.
*--------------------------------------------------------------------------------------------*/
package com.github.copilot.sdk.json;
import java.util.Collections;
import java.util.List;
import java.util.Map;
import com.fasterxml.jackson.annotation.JsonInclude;
import com.fasterxml.jackson.annotation.JsonProperty;
/**
* Internal request object for creating a new session.
* <p>
* This is a low-level class for JSON-RPC communication. For creating sessions,
* use
* {@link com.github.copilot.sdk.CopilotClient#createSession(SessionConfig)}.
*
* @see com.github.copilot.sdk.CopilotClient#createSession(SessionConfig)
* @see SessionConfig
* @since 1.0.0
*/
@JsonInclude(JsonInclude.Include.NON_NULL)
public final class CreateSessionRequest {
@JsonProperty("model")
private String model;
@JsonProperty("sessionId")
private String sessionId;
@JsonProperty("reasoningEffort")
private String reasoningEffort;
@JsonProperty("tools")
private List<ToolDef> tools;
@JsonProperty("systemMessage")
private SystemMessageConfig systemMessage;
@JsonProperty("availableTools")
private List<String> availableTools;
@JsonProperty("excludedTools")
private List<String> excludedTools;
@JsonProperty("provider")
private ProviderConfig provider;
@JsonProperty("requestPermission")
private Boolean requestPermission;
@JsonProperty("requestUserInput")
private Boolean requestUserInput;
@JsonProperty("hooks")
private Boolean hooks;
@JsonProperty("workingDirectory")
private String workingDirectory;
@JsonProperty("streaming")
private Boolean streaming;
@JsonProperty("mcpServers")
private Map<String, Object> mcpServers;
@JsonProperty("customAgents")
private List<CustomAgentConfig> customAgents;
@JsonProperty("infiniteSessions")
private InfiniteSessionConfig infiniteSessions;
@JsonProperty("skillDirectories")
private List<String> skillDirectories;
@JsonProperty("disabledSkills")
private List<String> disabledSkills;
@JsonProperty("configDir")
private String configDir;
/** Gets the model name. @return the model */
public String getModel() {
return model;
}
/** Sets the model name. @param model the model */
public void setModel(String model) {
this.model = model;
}
/** Gets the session ID. @return the session ID */
public String getSessionId() {
return sessionId;
}
/** Sets the session ID. @param sessionId the session ID */
public void setSessionId(String sessionId) {
this.sessionId = sessionId;
}
/** Gets the reasoning effort. @return the reasoning effort level */
public String getReasoningEffort() {
return reasoningEffort;
}
/**
* Sets the reasoning effort. @param reasoningEffort the reasoning effort level
*/
public void setReasoningEffort(String reasoningEffort) {
this.reasoningEffort = reasoningEffort;
}
/** Gets the tools. @return the tool definitions */
public List<ToolDef> getTools() {
return tools == null ? null : Collections.unmodifiableList(tools);
}
/** Sets the tools. @param tools the tool definitions */
public void setTools(List<ToolDef> tools) {
this.tools = tools;
}
/** Gets the system message config. @return the config */
public SystemMessageConfig getSystemMessage() {
return systemMessage;
}
/** Sets the system message config. @param systemMessage the config */
public void setSystemMessage(SystemMessageConfig systemMessage) {
this.systemMessage = systemMessage;
}
/** Gets available tools. @return the tool names */
public List<String> getAvailableTools() {
return availableTools == null ? null : Collections.unmodifiableList(availableTools);
}
/** Sets available tools. @param availableTools the tool names */
public void setAvailableTools(List<String> availableTools) {
this.availableTools = availableTools;
}
/** Gets excluded tools. @return the tool names */
public List<String> getExcludedTools() {
return excludedTools == null ? null : Collections.unmodifiableList(excludedTools);
}
/** Sets excluded tools. @param excludedTools the tool names */
public void setExcludedTools(List<String> excludedTools) {
this.excludedTools = excludedTools;
}
/** Gets the provider config. @return the provider */
public ProviderConfig getProvider() {
return provider;
}
/** Sets the provider config. @param provider the provider */
public void setProvider(ProviderConfig provider) {
this.provider = provider;
}
/** Gets request permission flag. @return the flag */
public Boolean getRequestPermission() {
return requestPermission;
}
/** Sets request permission flag. @param requestPermission the flag */
public void setRequestPermission(Boolean requestPermission) {
this.requestPermission = requestPermission;
}
/** Gets request user input flag. @return the flag */
public Boolean getRequestUserInput() {
return requestUserInput;
}
/** Sets request user input flag. @param requestUserInput the flag */
public void setRequestUserInput(Boolean requestUserInput) {
this.requestUserInput = requestUserInput;
}
/** Gets hooks flag. @return the flag */
public Boolean getHooks() {
return hooks;
}
/** Sets hooks flag. @param hooks the flag */
public void setHooks(Boolean hooks) {
this.hooks = hooks;
}
/** Gets working directory. @return the working directory */
public String getWorkingDirectory() {
return workingDirectory;
}
/** Sets working directory. @param workingDirectory the working directory */
public void setWorkingDirectory(String workingDirectory) {
this.workingDirectory = workingDirectory;
}
/** Gets streaming flag. @return the flag */
public Boolean getStreaming() {
return streaming;
}
/** Sets streaming flag. @param streaming the flag */
public void setStreaming(Boolean streaming) {
this.streaming = streaming;
}
/** Gets MCP servers. @return the servers map */
public Map<String, Object> getMcpServers() {
return mcpServers == null ? null : Collections.unmodifiableMap(mcpServers);
}
/** Sets MCP servers. @param mcpServers the servers map */
public void setMcpServers(Map<String, Object> mcpServers) {
this.mcpServers = mcpServers;
}
/** Gets custom agents. @return the agents */
public List<CustomAgentConfig> getCustomAgents() {
return customAgents == null ? null : Collections.unmodifiableList(customAgents);
}
/** Sets custom agents. @param customAgents the agents */
public void setCustomAgents(List<CustomAgentConfig> customAgents) {
this.customAgents = customAgents;
}
/** Gets infinite sessions config. @return the config */
public InfiniteSessionConfig getInfiniteSessions() {
return infiniteSessions;
}
/** Sets infinite sessions config. @param infiniteSessions the config */
public void setInfiniteSessions(InfiniteSessionConfig infiniteSessions) {
this.infiniteSessions = infiniteSessions;
}
/** Gets skill directories. @return the skill directories */
public List<String> getSkillDirectories() {
return skillDirectories == null ? null : Collections.unmodifiableList(skillDirectories);
}
/** Sets skill directories. @param skillDirectories the directories */
public void setSkillDirectories(List<String> skillDirectories) {
this.skillDirectories = skillDirectories;
}
/** Gets disabled skills. @return the disabled skill names */
public List<String> getDisabledSkills() {
return disabledSkills == null ? null : Collections.unmodifiableList(disabledSkills);
}
/** Sets disabled skills. @param disabledSkills the skill names to disable */
public void setDisabledSkills(List<String> disabledSkills) {
this.disabledSkills = disabledSkills;
}
/** Gets config directory. @return the config directory path */
public String getConfigDir() {
return configDir;
}
/** Sets config directory. @param configDir the config directory path */
public void setConfigDir(String configDir) {
this.configDir = configDir;
}
}