-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathchanges_revision.go
697 lines (587 loc) · 29.2 KB
/
changes_revision.go
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
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
package gerrit
import (
"context"
"fmt"
"net/http"
"net/url"
)
// DiffInfo entity contains information about the diff of a file in a revision.
type DiffInfo struct {
MetaA DiffFileMetaInfo `json:"meta_a,omitempty"`
MetaB DiffFileMetaInfo `json:"meta_b,omitempty"`
ChangeType string `json:"change_type"`
IntralineStatus string `json:"intraline_status,omitempty"`
DiffHeader []string `json:"diff_header"`
Content []DiffContent `json:"content"`
WebLinks []DiffWebLinkInfo `json:"web_links,omitempty"`
Binary bool `json:"binary,omitempty"`
}
// BlameInfo entity stores the commit metadata with the row coordinates where it applies.
type BlameInfo struct {
Author string `json:"author"`
ID string `json:"id"`
Time int `json:"time"`
CommitMsg string `json:"commit_msg"`
Ranges []RangeInfo `json:"ranges"`
}
// RangeInfo entity stores the coordinates of a range.
type RangeInfo struct {
Start int `json:"start"`
End int `json:"end"`
}
// RelatedChangesInfo entity contains information about related changes.
type RelatedChangesInfo struct {
Changes []RelatedChangeAndCommitInfo `json:"changes"`
}
// FileInfo entity contains information about a file in a patch set.
type FileInfo struct {
Status string `json:"status,omitempty"`
Binary bool `json:"binary,omitempty"`
OldPath string `json:"old_path,omitempty"`
LinesInserted int `json:"lines_inserted,omitempty"`
LinesDeleted int `json:"lines_deleted,omitempty"`
SizeDelta int `json:"size_delta"`
Size int `json:"size"`
}
// ActionInfo entity describes a REST API call the client can make to manipulate a resource.
// These are frequently implemented by plugins and may be discovered at runtime.
type ActionInfo struct {
Method string `json:"method,omitempty"`
Label string `json:"label,omitempty"`
Title string `json:"title,omitempty"`
Enabled bool `json:"enabled,omitempty"`
}
// CommitInfo entity contains information about a commit.
type CommitInfo struct {
Commit string `json:"commit,omitempty"`
Parents []CommitInfo `json:"parents"`
Author GitPersonInfo `json:"author"`
Committer GitPersonInfo `json:"committer"`
Subject string `json:"subject"`
Message string `json:"message"`
WebLinks []WebLinkInfo `json:"web_links,omitempty"`
}
// MergeableInfo entity contains information about the mergeability of a change.
type MergeableInfo struct {
SubmitType string `json:"submit_type"`
Mergeable bool `json:"mergeable"`
MergeableInto []string `json:"mergeable_into,omitempty"`
}
// DiffOptions specifies the parameters for GetDiff call.
type DiffOptions struct {
// If the intraline parameter is specified, intraline differences are included in the diff.
Intraline bool `url:"intraline,omitempty"`
// The base parameter can be specified to control the base patch set from which the diff
// should be generated.
Base string `url:"base,omitempty"`
// The integer-valued request parameter parent can be specified to control the parent commit number
// against which the diff should be generated. This is useful for supporting review of merge commits.
// The value is the 1-based index of the parent’s position in the commit object.
Parent int `url:"parent,omitempty"`
// If the weblinks-only parameter is specified, only the diff web links are returned.
WeblinksOnly bool `url:"weblinks-only,omitempty"`
// The ignore-whitespace parameter can be specified to control how whitespace differences are reported in the result. Valid values are NONE, TRAILING, CHANGED or ALL.
IgnoreWhitespace string `url:"ignore-whitespace,omitempty"`
// The context parameter can be specified to control the number of lines of surrounding context in the diff.
// Valid values are ALL or number of lines.
Context string `url:"context,omitempty"`
}
// CommitOptions specifies the parameters for GetCommit call.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#get-commit
type CommitOptions struct {
// Adding query parameter links (for example /changes/.../commit?links) returns a CommitInfo with the additional field web_links.
Weblinks bool `url:"links,omitempty"`
}
// DescriptionInput entity contains information for setting a description.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#description-input
type DescriptionInput struct {
Description string `json:"description"`
}
// MergableOptions specifies the parameters for GetMergable call.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#get-mergeable
type MergableOptions struct {
// If the other-branches parameter is specified, the mergeability will also be checked for all other branches.
OtherBranches bool `url:"other-branches,omitempty"`
}
// FilesOptions specifies the parameters for ListFiles and ListFilesReviewed calls.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#list-files
type FilesOptions struct {
// The request parameter q changes the response to return a list of all files (modified or unmodified)
// that contain that substring in the path name. This is useful to implement suggestion services
// finding a file by partial name.
Q string `url:"q,omitempty"`
// The base parameter can be specified to control the base patch set from which the list of files
// should be generated.
//
// Note: This option is undocumented.
Base string `url:"base,omitempty"`
// The integer-valued request parameter parent changes the response to return a list of the files
// which are different in this commit compared to the given parent commit. This is useful for
// supporting review of merge commits. The value is the 1-based index of the parent’s position
// in the commit object.
Parent int `url:"parent,omitempty"`
}
// PatchOptions specifies the parameters for GetPatch call.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#get-patch
type PatchOptions struct {
// Adding query parameter zip (for example /changes/.../patch?zip) returns the patch as a single file inside of a ZIP archive.
// Clients can expand the ZIP to obtain the plain text patch, avoiding the need for a base64 decoding step.
// This option implies download.
Zip bool `url:"zip,omitempty"`
// Query parameter download (e.g. /changes/.../patch?download) will suggest the browser save the patch as commitsha1.diff.base64, for later processing by command line tools.
Download bool `url:"download,omitempty"`
// If the path parameter is set, the returned content is a diff of the single file that the path refers to.
Path string `url:"path,omitempty"`
}
// GetRevisionCommit retrieves a parsed commit of a revision.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#get-commit
func (c *Change) GetRevisionCommit(ctx context.Context, revisionID string, opt *CommitOptions) (*CommitInfo, *http.Response, error) {
// if reflect.TypeOf(revisionID).String() == "int" {
// revisionID = strconv.Itoa(revisionID.(int))
// }
//revisionID = revisionID.(string)
v := new(CommitInfo)
u := fmt.Sprintf("changes/%s/revisions/%s/commit", c.Base, revisionID)
resp, err := c.gerrit.Requester.Call(ctx, "GET", u, opt, v)
if err != nil {
return nil, resp, err
}
return v, resp, nil
}
// GetRevisionDescription retrieves the description of a patch set.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#get-description
func (c *Change) GetRevisionDescription(ctx context.Context, revisionID string) (string, *http.Response, error) {
v := new(string)
u := fmt.Sprintf("changes/%s/revisions/%s/description", c.Base, revisionID)
resp, err := c.gerrit.Requester.Call(ctx, "GET", u, nil, v)
if err != nil {
return "", resp, err
}
return *v, resp, nil
}
// SetRevisionDescription sets the description of a patch set.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#set-description
func (c *Change) SetRevisionDescription(ctx context.Context, revisionID string, input *DescriptionInput) (string, *http.Response, error) {
v := new(string)
u := fmt.Sprintf("changes/%s/revisions/%s/description", c.Base, revisionID)
resp, err := c.gerrit.Requester.Call(ctx, "PUT", u, input, v)
if err != nil {
return "", resp, err
}
return *v, resp, nil
}
// GetRevisionMergeDiff Returns the list of commits that are being integrated into a target branch by a merge commit.
//
// By default the first parent is assumed to be uninteresting. By using the parent option another parent can be set
// as uninteresting (parents are 1-based).
// The list of commits is returned as a list of CommitInfo entities.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#get-merge-list
func (c *Change) GetRevisionMergeDiff(ctx context.Context, revisionID string) (*[]CommitInfo, *http.Response, error) {
v := new([]CommitInfo)
u := fmt.Sprintf("changes/%s/revisions/%s/mergelist", c.Base, revisionID)
resp, err := c.gerrit.Requester.Call(ctx, "GET", u, nil, v)
if err != nil {
return nil, resp, err
}
return v, resp, nil
}
// GetRevisionActions retrieves revision actions of the revision of a change.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#get-revision-actions
func (c *Change) GetRevisionActions(ctx context.Context, revisionID string) (map[string]ActionInfo, *http.Response, error) {
v := make(map[string]ActionInfo)
u := fmt.Sprintf("changes/%s/revisions/%s/actions", c.Base, revisionID)
resp, err := c.gerrit.Requester.Call(ctx, "GET", u, nil, &v)
if err != nil {
return nil, resp, err
}
return v, resp, nil
}
// GetRevisionReview retrieves a review of a revision.
//
// As response a ChangeInfo entity with detailed labels and detailed accounts is returned that describes the review of the revision.
// The revision for which the review is retrieved is contained in the revisions field.
// In addition the current_revision field is set if the revision for which the review is retrieved is the current revision of the change.
// Please note that the returned labels are always for the current patch set.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#get-review
func (c *Change) GetRevisionReview(ctx context.Context, revisionID string) (*ChangeInfo, *http.Response, error) {
v := new(ChangeInfo)
u := fmt.Sprintf("changes/%s/revisions/%s/review", c.Base, revisionID)
resp, err := c.gerrit.Requester.Call(ctx, "GET", u, nil, v)
if err != nil {
return nil, resp, err
}
return v, resp, nil
}
// SetRevisionReview sets a review on a revision.
// The review must be provided in the request body as a ReviewInput entity.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#set-review
func (c *Change) SetRevisionReview(ctx context.Context, revisionID string, input *ReviewInput) (*ReviewResult, *http.Response, error) {
v := new(ReviewResult)
u := fmt.Sprintf("changes/%s/revisions/%s/review", c.Base, revisionID)
resp, err := c.gerrit.Requester.Call(ctx, "POST", u, input, v)
if err != nil {
return nil, resp, err
}
return v, resp, nil
}
// GetRevisionRelatedChanges retrieves related changes of a revision.
// Related changes are changes that either depend on, or are dependencies of the revision.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#get-related-changes
func (c *Change) GetRevisionRelatedChanges(ctx context.Context, revisionID string) (*RelatedChangesInfo, *http.Response, error) {
v := new(RelatedChangesInfo)
u := fmt.Sprintf("changes/%s/revisions/%s/related", c.Base, revisionID)
resp, err := c.gerrit.Requester.Call(ctx, "GET", u, nil, v)
if err != nil {
return nil, resp, err
}
return v, resp, nil
}
// RebaseRevision rebase a revision.
// The review must be provided in the request body as a RebaseInput entity.
// If the revision cannot be rebased, e.g. due to conflicts, the response is “409 Conflict”
// and the error message is contained in the response body.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#rebase-revision
func (c *Change) RebaseRevision(ctx context.Context, revisionID string, input *RebaseInput) (*ChangeInfo, *http.Response, error) {
v := new(ChangeInfo)
u := fmt.Sprintf("changes/%s/revisions/%s/rebase", c.Base, revisionID)
resp, err := c.gerrit.Requester.Call(ctx, "POST", u, input, v)
if err != nil {
return nil, resp, err
}
return v, resp, nil
}
// SubmitRevision Submit a revision. As response a ChangeInfo entity is returned that describes the submitted/merged change.
// As response a ChangeInfo entity is returned that describes the submitted/merged change.
// If the revision cannot be submitted, e.g. because the submit rule doesn’t allow submitting the revision or
// the revision is not the current revision, the response is “409 Conflict” and the error message is contained in the response body.
// and the error message is contained in the response body.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#submit-revision
func (c *Change) SubmitRevision(ctx context.Context, revisionID string) (*ChangeInfo, *http.Response, error) {
v := new(ChangeInfo)
u := fmt.Sprintf("changes/%s/revisions/%s/submit", c.Base, revisionID)
resp, err := c.gerrit.Requester.Call(ctx, "POST", u, nil, v)
if err != nil {
return nil, resp, err
}
return v, resp, nil
}
// GetRevisionPatch Gets the formatted patch for one revision.
// The formatted patch is returned as text encoded inside base64.
// Adding query parameter zip (for example /changes/.../patch?zip) returns the patch as a single file inside of a ZIP archive.
// Clients can expand the ZIP to obtain the plain text patch, avoiding the need for a base64 decoding step.
// This option implies download.
//
// Query parameter download (e.g. /changes/.../patch?download) will suggest the browser save the patch as commitsha1.diff.base64, for later processing by command line tools.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#get-patch
func (c *Change) GetRevisionPatch(ctx context.Context, revisionID string, opt *PatchOptions) (*http.Response, error) {
u := fmt.Sprintf("changes/%s/revisions/%s/patch", c.Base, revisionID)
return c.gerrit.Requester.Call(ctx, "GET", u, opt, nil)
}
// GetRevisionMergeable gets the method the server will use to submit (merge) the change and an indicator if the change is currently mergeable.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#get-mergeable
func (c *Change) GetRevisionMergeable(ctx context.Context, revisionID string, opt *MergableOptions) (*MergeableInfo, *http.Response, error) {
v := new(MergeableInfo)
u := fmt.Sprintf("changes/%s/revisions/%s/mergeable", c.Base, revisionID)
resp, err := c.gerrit.Requester.Call(ctx, "GET", u, opt, v)
if err != nil {
return nil, resp, err
}
return v, resp, nil
}
// GetRevisionSubmitType gets the method the server will use to submit (merge) the change.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#get-submit-type
func (c *Change) GetRevisionSubmitType(ctx context.Context, revisionID string) (string, *http.Response, error) {
v := new(string)
u := fmt.Sprintf("changes/%s/revisions/%s/submit_type", c.Base, revisionID)
resp, err := c.gerrit.Requester.Call(ctx, "GET", u, nil, v)
if err != nil {
return "", resp, err
}
return *v, resp, nil
}
// TestRevisionSubmitType tests the submit_type Prolog rule in the project, or the one given.
//
// Request body may be either the Prolog code as text/plain or a RuleInput object.
// The query parameter filters may be set to SKIP to bypass parent project filters while testing a project-specific rule.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#test-submit-type
func (c *Change) TestRevisionSubmitType(ctx context.Context, revisionID string, input *RuleInput) (string, *http.Response, error) {
v := new(string)
u := fmt.Sprintf("changes/%s/revisions/%s/test.submit_type", c.Base, revisionID)
resp, err := c.gerrit.Requester.Call(ctx, "POST", u, input, v)
if err != nil {
return "", resp, err
}
return *v, resp, nil
}
// TestRevisionSubmitRule tests the submit_rule Prolog rule in the project, or the one given.
//
// Request body may be either the Prolog code as text/plain or a RuleInput object.
// The query parameter filters may be set to SKIP to bypass parent project filters while testing a project-specific rule.
//
// The response is a list of SubmitRecord entries describing the permutations that satisfy the tested submit rule.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#test-submit-rule
func (c *Change) TestRevisionSubmitRule(ctx context.Context, revisionID string, input *RuleInput) (*[]SubmitRecord, *http.Response, error) {
v := new([]SubmitRecord)
u := fmt.Sprintf("changes/%s/revisions/%s/test.submit_rule", c.Base, revisionID)
resp, err := c.gerrit.Requester.Call(ctx, "POST", u, input, v)
if err != nil {
return nil, resp, err
}
return v, resp, nil
}
// ListRevisionDrafts lists the draft comments of a revision that belong to the calling user.
// Returns a map of file paths to lists of CommentInfo entries.
// The entries in the map are sorted by file path.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#list-drafts
func (c *Change) ListRevisionDrafts(ctx context.Context, revisionID string) (map[string][]CommentInfo, *http.Response, error) {
v := make(map[string][]CommentInfo)
u := fmt.Sprintf("changes/%s/revisions/%s/drafts/", c.Base, revisionID)
resp, err := c.gerrit.Requester.Call(ctx, "GET", u, nil, &v)
if err != nil {
return nil, resp, err
}
return v, resp, nil
}
// CreateRevisionDraft creates a draft comment on a revision.
// The new draft comment must be provided in the request body inside a CommentInput entity.
//
// As response a CommentInfo entity is returned that describes the draft comment.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#create-draft
func (c *Change) CreateRevisionDraft(ctx context.Context, revisionID string, input *CommentInput) (*CommentInfo, *http.Response, error) {
v := new(CommentInfo)
u := fmt.Sprintf("changes/%s/revisions/%s/drafts", c.Base, revisionID)
resp, err := c.gerrit.Requester.Call(ctx, "PUT", u, input, v)
if err != nil {
return nil, resp, err
}
return v, resp, nil
}
// GetRevisionDraft retrieves a draft comment of a revision that belongs to the calling user.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#get-draft
func (c *Change) GetRevisionDraft(ctx context.Context, revisionID, draftID string) (*CommentInfo, *http.Response, error) {
v := new(CommentInfo)
u := fmt.Sprintf("changes/%s/revisions/%s/drafts/%s", c.Base, revisionID, draftID)
resp, err := c.gerrit.Requester.Call(ctx, "GET", u, nil, v)
if err != nil {
return nil, resp, err
}
return v, resp, nil
}
// UpdateRevisionDraft updates a draft comment on a revision.
// The new draft comment must be provided in the request body inside a CommentInput entity.
//
// As response a CommentInfo entity is returned that describes the draft comment.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#update-draft
func (c *Change) UpdateRevisionDraft(ctx context.Context, revisionID, draftID string, input *CommentInput) (*CommentInfo, *http.Response, error) {
v := new(CommentInfo)
u := fmt.Sprintf("changes/%s/revisions/%s/drafts/%s", c.Base, revisionID, draftID)
resp, err := c.gerrit.Requester.Call(ctx, "PUT", u, input, v)
if err != nil {
return nil, resp, err
}
return v, resp, nil
}
// DeleteRevisionDraft deletes a draft comment from a revision.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#delete-draft
func (c *Change) DeleteRevisionDraft(ctx context.Context, revisionID, draftID string) (*http.Response, error) {
u := fmt.Sprintf("changes/%s/revisions/%s/drafts/%s", c.Base, revisionID, draftID)
return c.gerrit.Requester.Call(ctx, "DELETE", u, nil, nil)
}
// ListRevisionComments lists the published comments of a revision.
// As result a map is returned that maps the file path to a list of CommentInfo entries.
// The entries in the map are sorted by file path and only include file (or inline) comments.
// Use the Get Change Detail endpoint to retrieve the general change message (or comment).
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#list-comments
func (c *Change) ListRevisionComments(ctx context.Context, revisionID string) (map[string][]CommentInfo, *http.Response, error) {
v := make(map[string][]CommentInfo)
u := fmt.Sprintf("changes/%s/revisions/%s/comments/", c.Base, revisionID)
resp, err := c.gerrit.Requester.Call(ctx, "GET", u, nil, &v)
if err != nil {
return nil, resp, err
}
return v, resp, nil
}
// GetRevisionComment retrieves a published comment of a revision.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#get-comment
func (c *Change) GetRevisionComment(ctx context.Context, revisionID, commentID string) (*CommentInfo, *http.Response, error) {
v := new(CommentInfo)
u := fmt.Sprintf("changes/%s/revisions/%s/comments/%s", c.Base, revisionID, commentID)
resp, err := c.gerrit.Requester.Call(ctx, "GET", u, nil, v)
if err != nil {
return nil, resp, err
}
return v, resp, nil
}
// DeleteRevisionComment deletes a published comment of a revision.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#delete-comment
func (c *Change) DeleteRevisionComment(ctx context.Context, revisionID, commentID string) (*http.Response, error) {
u := fmt.Sprintf("changes/%s/revisions/%s/comments/%s", c.Base, revisionID, commentID)
return c.gerrit.Requester.Call(ctx, "DELETE", u, nil, nil)
}
// ListRevisionRobotComments Lists the robot comments of a revision.
// Return a map that maps the file path to a list of RobotCommentInfo entries. The entries in the map are sorted by file path.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#list-change-robot-comments
func (c *Change) ListRevisionRobotComments(ctx context.Context, revisionID string) (map[string][]RobotCommentInfo, *http.Response, error) {
v := make(map[string][]RobotCommentInfo)
u := fmt.Sprintf("changes/%s/revisions/%s/robotcomments/", c.Base, revisionID)
resp, err := c.gerrit.Requester.Call(ctx, "GET", u, nil, &v)
if err != nil {
return nil, resp, err
}
return v, resp, nil
}
// GetRevisionRobotComments retrieves a robot comment of a revision.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#get-robot-comment
func (c *Change) GetRevisionRobotComments(ctx context.Context, revisionID, commentID string) (*RobotCommentInfo, *http.Response, error) {
v := new(RobotCommentInfo)
u := fmt.Sprintf("changes/%s/revisions/%s/robotcomments/%s", c.Base, revisionID, commentID)
resp, err := c.gerrit.Requester.Call(ctx, "GET", u, nil, &v)
if err != nil {
return nil, resp, err
}
return v, resp, nil
}
// ListRevisionFiles lists the files that were modified, added or deleted in a revision.
// As result a map is returned that maps the file path to a list of FileInfo entries.
// The entries in the map are sorted by file path.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#list-files
func (c *Change) ListRevisionFiles(ctx context.Context, revisionID string, opt *FilesOptions) (map[string]FileInfo, *http.Response, error) {
v := make(map[string]FileInfo)
u := fmt.Sprintf("changes/%s/revisions/%s/files/", c.Base, revisionID)
resp, err := c.gerrit.Requester.Call(ctx, "GET", u, opt, &v)
if err != nil {
return nil, resp, err
}
return v, resp, nil
}
// GetRevisionFileContent gets the content of a file from a certain revision.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#get-content
func (c *Change) GetRevisionFileContent(ctx context.Context, revisionID, fileID string) (string, *http.Response, error) {
v := new(string)
u := fmt.Sprintf("changes/%s/revisions/%s/files/%s/content", c.Base, revisionID, url.PathEscape(fileID))
resp, err := c.gerrit.Requester.Call(ctx, "GET", u, nil, &v)
if err != nil {
return "", resp, err
}
return *v, resp, nil
}
// GetRevisionFileContentType gets the content type of a file from a certain revision.
// This is nearly the same as GetContent.
// But if only the content type is required, callers should use HEAD to avoid downloading the encoded file contents.
//
// For further documentation see GetContent.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#get-content
func (c *Change) GetRevisionFileContentType(ctx context.Context, revisionID, fileID string) (*http.Response, error) {
u := fmt.Sprintf("changes/%s/revisions/%s/files/%s/content", c.Base, revisionID, url.PathEscape(fileID))
return c.gerrit.Requester.Call(ctx, "HEAD", u, nil, nil)
}
func (c *Change) DownloadRevisionFileContent(ctx context.Context, revisionID, fileID string) (*http.Response, error) {
u := fmt.Sprintf("changes/%s/revisions/%s/files/%s/download", c.Base, revisionID, url.PathEscape(fileID))
return c.gerrit.Requester.Call(ctx, "GET", u, nil, nil)
}
// GetRevisionFileDiff gets the diff of a file from a certain revision.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#get-diff
func (c *Change) GetRevisionFileDiff(ctx context.Context, revisionID, fileID string, opt *DiffOptions) (*DiffInfo, *http.Response, error) {
v := new(DiffInfo)
u := fmt.Sprintf("changes/%s/revisions/%s/files/%s/diff", c.Base, revisionID, url.PathEscape(fileID))
resp, err := c.gerrit.Requester.Call(ctx, "GET", u, opt, v)
if err != nil {
return nil, resp, err
}
return v, resp, nil
}
func (c *Change) GetRevisionFileBlame(ctx context.Context, revisionID, fileID string) (*[]BlameInfo, *http.Response, error) {
v := new([]BlameInfo)
u := fmt.Sprintf("changes/%s/revisions/%s/files/%s/blame", c.Base, revisionID, url.PathEscape(fileID))
resp, err := c.gerrit.Requester.Call(ctx, "GET", u, nil, v)
if err != nil {
return nil, resp, err
}
return v, resp, nil
}
// ListRevisionFilesReviewed lists the files that were modified, added or deleted in a revision.
// Unlike ListFiles, the response of ListFilesReviewed is a list of the paths the caller
// has marked as reviewed. Clients that also need the FileInfo should make two requests.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#list-files
func (c *Change) ListRevisionFilesReviewed(ctx context.Context, revisionID string, opt *FilesOptions) ([]string, *http.Response, error) {
v := new([]string)
u := fmt.Sprintf("changes/%s/revisions/%s/files/", c.Base, revisionID)
o := struct {
FilesOptions
// The request parameter reviewed changes the response to return a list of the paths the caller has marked as reviewed.
Reviewed bool `url:"reviewed,omitempty"`
}{
Reviewed: true,
}
if opt != nil {
o.FilesOptions = *opt
}
resp, err := c.gerrit.Requester.Call(ctx, "GET", u, o, v)
if err != nil {
return nil, resp, err
}
return *v, resp, nil
}
// SetRevisionFileReviewed marks a file of a revision as reviewed by the calling user.
//
// If the file was already marked as reviewed by the calling user the response is “200 OK”.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#set-reviewed
func (c *Change) SetRevisionFileReviewed(ctx context.Context, revisionID, fileID string) (*http.Response, error) {
u := fmt.Sprintf("changes/%s/revisions/%s/files/%s/reviewed", c.Base, revisionID, url.PathEscape(fileID))
return c.gerrit.Requester.Call(ctx, "PUT", u, nil, nil)
}
// DeleteRevisionFileReviewed deletes the reviewed flag of the calling user from a file of a revision.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#delete-reviewed
func (c *Change) DeleteRevisionFileReviewed(ctx context.Context, revisionID, fileID string) (*http.Response, error) {
u := fmt.Sprintf("changes/%s/revisions/%s/files/%s/reviewed", c.Base, revisionID, url.PathEscape(fileID))
return c.gerrit.Requester.Call(ctx, "DELETE", u, nil, nil)
}
// CherryPickRevision publishes a draft revision.
//
// Gerrit API docs: https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#cherry-pick
func (c *Change) CherryPickRevision(ctx context.Context, revisionID string, input *CherryPickInput) (*ChangeInfo, *http.Response, error) {
v := new(ChangeInfo)
u := fmt.Sprintf("changes/%s/revisions/%s/cherrypick", c.Base, revisionID)
resp, err := c.gerrit.Requester.Call(ctx, "POST", u, input, v)
if err != nil {
return nil, resp, err
}
return v, resp, nil
}