@@ -30,9 +30,10 @@ type Dataset struct {
30
30
}
31
31
32
32
type datasetRequest struct {
33
- Input string `json:"input"`
34
- Workspace string `json:"workspace"`
35
- DatasetToolRepo string `json:"datasetToolRepo"`
33
+ Input string `json:"input"`
34
+ WorkspaceID string `json:"workspaceID"`
35
+ DatasetToolRepo string `json:"datasetToolRepo"`
36
+ Env []string `json:"env"`
36
37
}
37
38
38
39
type createDatasetArgs struct {
@@ -47,6 +48,11 @@ type addDatasetElementArgs struct {
47
48
ElementContent string `json:"elementContent"`
48
49
}
49
50
51
+ type addDatasetElementsArgs struct {
52
+ DatasetID string `json:"datasetID"`
53
+ Elements []DatasetElement `json:"elements"`
54
+ }
55
+
50
56
type listDatasetElementArgs struct {
51
57
DatasetID string `json:"datasetID"`
52
58
}
@@ -56,15 +62,16 @@ type getDatasetElementArgs struct {
56
62
Element string `json:"element"`
57
63
}
58
64
59
- func (g * GPTScript ) ListDatasets (ctx context.Context , workspace string ) ([]DatasetMeta , error ) {
60
- if workspace == "" {
61
- workspace = os .Getenv ("GPTSCRIPT_WORKSPACE_DIR " )
65
+ func (g * GPTScript ) ListDatasets (ctx context.Context , workspaceID string ) ([]DatasetMeta , error ) {
66
+ if workspaceID == "" {
67
+ workspaceID = os .Getenv ("GPTSCRIPT_WORKSPACE_ID " )
62
68
}
63
69
64
70
out , err := g .runBasicCommand (ctx , "datasets" , datasetRequest {
65
71
Input : "{}" ,
66
- Workspace : workspace ,
72
+ WorkspaceID : workspaceID ,
67
73
DatasetToolRepo : g .globalOpts .DatasetToolRepo ,
74
+ Env : g .globalOpts .Env ,
68
75
})
69
76
if err != nil {
70
77
return nil , err
@@ -77,9 +84,9 @@ func (g *GPTScript) ListDatasets(ctx context.Context, workspace string) ([]Datas
77
84
return datasets , nil
78
85
}
79
86
80
- func (g * GPTScript ) CreateDataset (ctx context.Context , workspace , name , description string ) (Dataset , error ) {
81
- if workspace == "" {
82
- workspace = os .Getenv ("GPTSCRIPT_WORKSPACE_DIR " )
87
+ func (g * GPTScript ) CreateDataset (ctx context.Context , workspaceID , name , description string ) (Dataset , error ) {
88
+ if workspaceID == "" {
89
+ workspaceID = os .Getenv ("GPTSCRIPT_WORKSPACE_ID " )
83
90
}
84
91
85
92
args := createDatasetArgs {
@@ -93,8 +100,9 @@ func (g *GPTScript) CreateDataset(ctx context.Context, workspace, name, descript
93
100
94
101
out , err := g .runBasicCommand (ctx , "datasets/create" , datasetRequest {
95
102
Input : string (argsJSON ),
96
- Workspace : workspace ,
103
+ WorkspaceID : workspaceID ,
97
104
DatasetToolRepo : g .globalOpts .DatasetToolRepo ,
105
+ Env : g .globalOpts .Env ,
98
106
})
99
107
if err != nil {
100
108
return Dataset {}, err
@@ -107,9 +115,9 @@ func (g *GPTScript) CreateDataset(ctx context.Context, workspace, name, descript
107
115
return dataset , nil
108
116
}
109
117
110
- func (g * GPTScript ) AddDatasetElement (ctx context.Context , workspace , datasetID , elementName , elementDescription , elementContent string ) (DatasetElementMeta , error ) {
111
- if workspace == "" {
112
- workspace = os .Getenv ("GPTSCRIPT_WORKSPACE_DIR " )
118
+ func (g * GPTScript ) AddDatasetElement (ctx context.Context , workspaceID , datasetID , elementName , elementDescription , elementContent string ) (DatasetElementMeta , error ) {
119
+ if workspaceID == "" {
120
+ workspaceID = os .Getenv ("GPTSCRIPT_WORKSPACE_ID " )
113
121
}
114
122
115
123
args := addDatasetElementArgs {
@@ -125,8 +133,9 @@ func (g *GPTScript) AddDatasetElement(ctx context.Context, workspace, datasetID,
125
133
126
134
out , err := g .runBasicCommand (ctx , "datasets/add-element" , datasetRequest {
127
135
Input : string (argsJSON ),
128
- Workspace : workspace ,
136
+ WorkspaceID : workspaceID ,
129
137
DatasetToolRepo : g .globalOpts .DatasetToolRepo ,
138
+ Env : g .globalOpts .Env ,
130
139
})
131
140
if err != nil {
132
141
return DatasetElementMeta {}, err
@@ -139,9 +148,32 @@ func (g *GPTScript) AddDatasetElement(ctx context.Context, workspace, datasetID,
139
148
return element , nil
140
149
}
141
150
142
- func (g * GPTScript ) ListDatasetElements (ctx context.Context , workspace , datasetID string ) ([]DatasetElementMeta , error ) {
143
- if workspace == "" {
144
- workspace = os .Getenv ("GPTSCRIPT_WORKSPACE_DIR" )
151
+ func (g * GPTScript ) AddDatasetElements (ctx context.Context , workspaceID , datasetID string , elements []DatasetElement ) error {
152
+ if workspaceID == "" {
153
+ workspaceID = os .Getenv ("GPTSCRIPT_WORKSPACE_ID" )
154
+ }
155
+
156
+ args := addDatasetElementsArgs {
157
+ DatasetID : datasetID ,
158
+ Elements : elements ,
159
+ }
160
+ argsJSON , err := json .Marshal (args )
161
+ if err != nil {
162
+ return fmt .Errorf ("failed to marshal element args: %w" , err )
163
+ }
164
+
165
+ _ , err = g .runBasicCommand (ctx , "datasets/add-elements" , datasetRequest {
166
+ Input : string (argsJSON ),
167
+ WorkspaceID : workspaceID ,
168
+ DatasetToolRepo : g .globalOpts .DatasetToolRepo ,
169
+ Env : g .globalOpts .Env ,
170
+ })
171
+ return err
172
+ }
173
+
174
+ func (g * GPTScript ) ListDatasetElements (ctx context.Context , workspaceID , datasetID string ) ([]DatasetElementMeta , error ) {
175
+ if workspaceID == "" {
176
+ workspaceID = os .Getenv ("GPTSCRIPT_WORKSPACE_ID" )
145
177
}
146
178
147
179
args := listDatasetElementArgs {
@@ -154,8 +186,9 @@ func (g *GPTScript) ListDatasetElements(ctx context.Context, workspace, datasetI
154
186
155
187
out , err := g .runBasicCommand (ctx , "datasets/list-elements" , datasetRequest {
156
188
Input : string (argsJSON ),
157
- Workspace : workspace ,
189
+ WorkspaceID : workspaceID ,
158
190
DatasetToolRepo : g .globalOpts .DatasetToolRepo ,
191
+ Env : g .globalOpts .Env ,
159
192
})
160
193
if err != nil {
161
194
return nil , err
@@ -168,9 +201,9 @@ func (g *GPTScript) ListDatasetElements(ctx context.Context, workspace, datasetI
168
201
return elements , nil
169
202
}
170
203
171
- func (g * GPTScript ) GetDatasetElement (ctx context.Context , workspace , datasetID , elementName string ) (DatasetElement , error ) {
172
- if workspace == "" {
173
- workspace = os .Getenv ("GPTSCRIPT_WORKSPACE_DIR " )
204
+ func (g * GPTScript ) GetDatasetElement (ctx context.Context , workspaceID , datasetID , elementName string ) (DatasetElement , error ) {
205
+ if workspaceID == "" {
206
+ workspaceID = os .Getenv ("GPTSCRIPT_WORKSPACE_ID " )
174
207
}
175
208
176
209
args := getDatasetElementArgs {
@@ -184,8 +217,9 @@ func (g *GPTScript) GetDatasetElement(ctx context.Context, workspace, datasetID,
184
217
185
218
out , err := g .runBasicCommand (ctx , "datasets/get-element" , datasetRequest {
186
219
Input : string (argsJSON ),
187
- Workspace : workspace ,
220
+ WorkspaceID : workspaceID ,
188
221
DatasetToolRepo : g .globalOpts .DatasetToolRepo ,
222
+ Env : g .globalOpts .Env ,
189
223
})
190
224
if err != nil {
191
225
return DatasetElement {}, err
0 commit comments