Support to retrieve the content of a file from a patch set via REST

By GET on
/changes/<change-id>/revisions/<revision-id>/files/<patch-id>/content
it is now possible to retrieve the content of a certain file from a
patch set. The file content is returned as base64 encoded string so
that also binary files can be handled.

Signed-off-by: Edwin Kempin <edwin.kempin@sap.com>
Change-Id: I429ce448c22b7b3b6ffd5503463676a798ea162a
This commit is contained in:
Edwin Kempin 2013-05-07 16:15:55 +02:00 committed by Dave Borowitz
parent def7f28354
commit aef44b033d
4 changed files with 118 additions and 0 deletions

View File

@ -1847,6 +1847,30 @@ describes the published comment.
} }
---- ----
[[get-content]]
Get Content
~~~~~~~~~~~
[verse]
'GET /changes/link:#change-id[\{change-id\}]/revisions/link:#revision-id[\{revision-id\}]/files/link:#patch-id[\{patch-id\}]/content'
Gets the content of a file from a certain revision.
.Request
----
GET /changes/myProject~master~I8473b95934b5732ac55d26311a706c9c2bde9940/revisions/674ac754f91e64a0efb8087e59a176484bd534d1/files/gerrit-server%2Fsrc%2Fmain%2Fjava%2Fcom%2Fgoogle%2Fgerrit%2Fserver%2Fproject%2FRefControl.java/content HTTP/1.0
----
The content is returned as base64 encoded string.
.Response
----
HTTP/1.1 200 OK
Content-Disposition: attachment
Content-Type: text/plain;charset=UTF-8
Ly8gQ29weXJpZ2h0IChDKSAyMDEwIFRoZSBBbmRyb2lkIE9wZW4gU291cmNlIFByb2plY...
----
[[set-reviewed]] [[set-reviewed]]
Set Reviewed Set Reviewed
~~~~~~~~~~~~ ~~~~~~~~~~~~

View File

@ -39,4 +39,8 @@ public class FileResource implements RestResource {
Account.Id getAccountId() { Account.Id getAccountId() {
return rev.getAccountId(); return rev.getAccountId();
} }
RevisionResource getRevision() {
return rev;
}
} }

View File

@ -0,0 +1,89 @@
// Copyright (C) 2013 The Android Open Source Project
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package com.google.gerrit.server.change;
import com.google.common.base.Charsets;
import com.google.common.io.BaseEncoding;
import com.google.gerrit.extensions.restapi.ResourceNotFoundException;
import com.google.gerrit.extensions.restapi.RestReadView;
import com.google.gerrit.extensions.restapi.StreamingResponse;
import com.google.gerrit.reviewdb.client.Project;
import com.google.gerrit.server.git.GitRepositoryManager;
import com.google.inject.Inject;
import org.eclipse.jgit.lib.ObjectId;
import org.eclipse.jgit.lib.ObjectLoader;
import org.eclipse.jgit.lib.Repository;
import org.eclipse.jgit.revwalk.RevCommit;
import org.eclipse.jgit.revwalk.RevWalk;
import org.eclipse.jgit.treewalk.TreeWalk;
import java.io.IOException;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
public class GetContent implements RestReadView<FileResource> {
private final GitRepositoryManager repoManager;
@Inject
GetContent(GitRepositoryManager repoManager) {
this.repoManager = repoManager;
}
@Override
public StreamingResponse apply(FileResource rsrc)
throws ResourceNotFoundException, IOException {
Project.NameKey project =
rsrc.getRevision().getControl().getProject().getNameKey();
Repository repo = repoManager.openRepository(project);
try {
RevWalk rw = new RevWalk(repo);
try {
RevCommit commit =
rw.parseCommit(ObjectId.fromString(rsrc.getRevision().getPatchSet()
.getRevision().get()));
TreeWalk tw =
TreeWalk.forPath(rw.getObjectReader(), rsrc.getPatchKey().get(),
commit.getTree().getId());
if (tw == null) {
throw new ResourceNotFoundException();
}
try {
final ObjectLoader loader = repo.open(tw.getObjectId(0));
return new StreamingResponse() {
@Override
public String getContentType() {
return "text/plain;charset=UTF-8";
}
@Override
public void stream(OutputStream out) throws IOException {
OutputStream b64Out = BaseEncoding.base64().encodingStream(
new OutputStreamWriter(out, Charsets.UTF_8));
loader.copyTo(b64Out);
b64Out.close();
}
};
} finally {
tw.release();
}
} finally {
rw.release();
}
} finally {
repo.close();
}
}
}

View File

@ -84,6 +84,7 @@ public class Module extends RestApiModule {
child(REVISION_KIND, "files").to(Files.class); child(REVISION_KIND, "files").to(Files.class);
put(FILE_KIND, "reviewed").to(PutReviewed.class); put(FILE_KIND, "reviewed").to(PutReviewed.class);
delete(FILE_KIND, "reviewed").to(DeleteReviewed.class); delete(FILE_KIND, "reviewed").to(DeleteReviewed.class);
get(FILE_KIND, "content").to(GetContent.class);
install(new FactoryModule() { install(new FactoryModule() {
@Override @Override