Skip to content

Commit

Permalink
Merge pull request #29 from apigee/Issue27
Browse files Browse the repository at this point in the history
fix for #27
  • Loading branch information
ssvaidyanathan authored Jun 10, 2021
2 parents 6ebfb71 + 1cee874 commit 8be356d
Show file tree
Hide file tree
Showing 10 changed files with 135 additions and 18 deletions.
2 changes: 1 addition & 1 deletion pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@

<groupId>com.apigee.smartdocs.config</groupId>
<artifactId>apigee-smartdocs-maven-plugin</artifactId>
<version>2.1.2-SNAPSHOT</version>
<version>2.1.3-SNAPSHOT</version>
<packaging>maven-plugin</packaging>
<name>apigee-smartdocs-maven-plugin</name>
<description>Plugin to manage configuration for Smartdocs in Apigee Drupal developer portal</description>
Expand Down
3 changes: 2 additions & 1 deletion samples/Drupal8/DevPortal/apicatalog-config.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
{
"fields":{
"field_business_unit":"Petstore",
"field_image": "pets.png",
"field_business_unit":"Petstore",
"field_drop_down":"one",
"field_multi_value":[
"value1",
Expand Down
2 changes: 1 addition & 1 deletion samples/Drupal8/DevPortal/shared-pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@
<plugin>
<groupId>com.apigee.smartdocs.config</groupId>
<artifactId>apigee-smartdocs-maven-plugin</artifactId>
<version>2.1.1</version>
<version>2.1.2</version>
<executions>
<execution>
<id>smartdocs-deploy</id>
Expand Down
File renamed without changes.
Binary file added samples/Drupal8/DevPortal/specs/pets.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
3 changes: 3 additions & 0 deletions samples/Drupal8/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -96,9 +96,12 @@ For example, the default Categories field on API Doc is associated with the "API

Here is a sample metadata file (apicatalog-config.json) :

** NOTE: Support for API spec image is available from v2.1.2. Make sure the image is in the same folder as the spec and include the name of the file in the config file (see below)

```
{
"fields":{
"field_image": "pets.jpeg",
"field_business_unit": "ABC",
"field_multi_value":[
"item1",
Expand Down
Binary file modified samples/Drupal8/media/screenshot2.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
package com.apigee.smartdocs.config.mavenplugin;

import java.io.File;
import java.io.FilenameFilter;
import java.io.IOException;

import org.apache.maven.plugin.MojoExecutionException;
Expand All @@ -26,7 +27,6 @@

import com.apigee.smartdocs.config.rest.PortalRestUtil;
import com.apigee.smartdocs.config.utils.ServerProfile;
import com.google.api.client.util.Key;

/** ¡¡
* Goal to create API Docs in Apigee Developer Portal
Expand All @@ -37,7 +37,7 @@
* @phase install
*/

public class APIDocsMojo extends GatewayAbstractMojo {
public class APIDocsMojo extends PortalAbstractMojo {
static Logger logger = LoggerFactory.getLogger(APIDocsMojo.class);
private static File[] files = null;

Expand Down Expand Up @@ -126,8 +126,6 @@ public void execute() throws MojoExecutionException, MojoFailureException {
return;
}

Logger logger = LoggerFactory.getLogger(APIDocsMojo.class);

try {
init();
if (buildOption == OPTIONS.none) {
Expand Down Expand Up @@ -205,7 +203,12 @@ public void getOpenAPISpecs() throws MojoExecutionException {
// Scan the directory for files.
String directory = serverProfile.getPortalDirectory();
logger.info("Get OpenAPI Specs from " + directory);
files = new File(directory).listFiles();
files = new File(directory).listFiles(new FilenameFilter() {
@Override
public boolean accept(File dir, String name) {
return name.endsWith(".yaml") || name.endsWith(".yml") || name.endsWith(".json");
}
});
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@
import com.apigee.smartdocs.config.utils.ServerProfile;
import com.apigee.smartdocs.config.utils.PortalField;

public abstract class GatewayAbstractMojo extends AbstractMojo {
public abstract class PortalAbstractMojo extends AbstractMojo {

/**
* Directory containing the build files.
Expand Down Expand Up @@ -173,7 +173,7 @@ public abstract class GatewayAbstractMojo extends AbstractMojo {

public ServerProfile buildProfile;

public GatewayAbstractMojo() {
public PortalAbstractMojo() {
super();
}

Expand Down
126 changes: 118 additions & 8 deletions src/main/java/com/apigee/smartdocs/config/rest/PortalRestUtil.java
Original file line number Diff line number Diff line change
Expand Up @@ -203,6 +203,12 @@ public static class APIDocObject {
public Object links;
}

public static class ImageDocObject {
public JSONAPI jsonapi;
public Data data;
public Object links;
}

public static class APIErrorObject {
public JSONAPI jsonapi;
public List<Error> errors;
Expand Down Expand Up @@ -245,6 +251,7 @@ public static class Body{

public static class Relationships{
public Relationships_Spec field_apidoc_spec;
public Relationships_Spec field_image;
}

public static class Relationships_Data{
Expand Down Expand Up @@ -320,7 +327,6 @@ public static HttpResponse authenticate(ServerProfile profile) throws IOExceptio
* Run Cron
*/
public static void runCron(ServerProfile profile) throws IOException {
HttpResponse response = null;
try {
// First authenticate.
authenticate(profile);
Expand All @@ -330,7 +336,7 @@ public static void runCron(ServerProfile profile) throws IOException {
restRequest.setReadTimeout(0);
logger.info("Running Cron");

response = PortalRestUtil.executeRequest(restRequest);
PortalRestUtil.executeRequest(restRequest);
} catch (HttpResponseException e) {
throw e;
}
Expand All @@ -340,7 +346,9 @@ public static void runCron(ServerProfile profile) throws IOException {
/**
* Helper function to build the body for API Doc creations and updates.
*/
private static ByteArrayContent getAPIDocContent(ServerProfile profile, SpecObject spec, String uuid, String docId, boolean isUpdate) throws IOException {
private static ByteArrayContent constructAPIDocRequestBody(ServerProfile profile, SpecObject spec, String uuid, String docId, String imageId, boolean isUpdate) throws IOException {
boolean hasImage = false;
File imageFile = null;
Gson gson = new Gson();
JsonObject body = new JsonObject();
if (spec.getDescription() != null) {
Expand Down Expand Up @@ -368,8 +376,14 @@ private static ByteArrayContent getAPIDocContent(ServerProfile profile, SpecObje
for (String key : fieldsMap.keySet()) {
if(fieldsMap.get(key) instanceof List){
attributes.add(key, gson.toJsonTree(fieldsMap.get(key)));
}else
attributes.addProperty(key, (String)fieldsMap.get(key));
}
//no need to add to attributes for "field_image"
else if (key!=null && key.equals("field_image")){
hasImage = true;
imageFile = new File(profile.getPortalDirectory()+"/"+(String)fieldsMap.get(key));
}
else
attributes.addProperty(key, (String)fieldsMap.get(key));
}
}

Expand Down Expand Up @@ -407,8 +421,26 @@ private static ByteArrayContent getAPIDocContent(ServerProfile profile, SpecObje
field_apidoc_spec_data.addProperty("id", docId);
JsonObject field_apidoc_spec = new JsonObject();
field_apidoc_spec.add("data", field_apidoc_spec_data);

relationships.add("field_apidoc_spec", field_apidoc_spec);

//field_image
if(hasImage) {
JsonObject field_image_data = new JsonObject();
field_image_data.addProperty("type", "media--image");
if(!isUpdate) {
ImageDocObject imageDoc = importImage(profile, imageFile);
String mediaImageId = importMediaImage(profile, imageFile.getName(), imageDoc.data.id);
field_image_data.addProperty("id", mediaImageId);
}
else {
field_image_data.addProperty("id", imageId);
}
JsonObject field_image = new JsonObject();
field_image.add("data", field_image_data);

relationships.add("field_image", field_image);
}

JsonObject data = new JsonObject();
data.addProperty("type", "node--apidoc");
Expand Down Expand Up @@ -564,6 +596,84 @@ public static APIDocObject importAPIDoc(ServerProfile profile, File file) throws
}
}

/**
* Import an image
*/
public static ImageDocObject importImage(ServerProfile profile, File imageFile) throws IOException {
HttpResponse response = null;
try {
logger.info("Importing image..");
byte[] fileBytes = Files.readAllBytes(imageFile.toPath());
ByteArrayContent fileContent = new ByteArrayContent("application/octet-stream", fileBytes);
HttpRequest restRequest = REQUEST_FACTORY
.buildPostRequest(new GenericUrl(profile.getPortalURL() + "/jsonapi/media/image/field_media_image"), fileContent);
HttpHeaders headers = restRequest.getHeaders();
headers.setAccept("application/vnd.api+json");
headers.set("Content-Disposition", "file; filename=\""+imageFile.getName()+"\"");
headers.setBasicAuthentication(profile.getPortalUserName(), profile.getPortalPassword());
restRequest.setReadTimeout(0);
response = restRequest.execute();
logger.info("Image import complete..");
Gson gson = new Gson();
Reader reader = new InputStreamReader(response.getContent());

ImageDocObject model = gson.fromJson(reader, ImageDocObject.class);
if(model != null && model.data!=null) {
logger.info("Image uuid:" + model.data.id);
return model;
}
return null;

} catch (HttpResponseException e) {
throw new IOException(exceptionHandler(e));
}
}

/**
* Configure media-image
*/

public static String importMediaImage(ServerProfile profile, String fileName, String imageId) throws IOException {
HttpResponse response = null;
try {
String payload = "{\n"
+ " \"data\": {\n"
+ " \"type\": \"media--image\",\n"
+ " \"attributes\": {\n"
+ " \"name\": \""+fileName+"\"\n"
+ " },\n"
+ " \"relationships\": {\n"
+ " \"field_media_image\": {\n"
+ " \"data\": {\n"
+ " \"type\": \"file--file\",\n"
+ " \"id\": \""+imageId+"\"\n"
+ " }\n"
+ " }\n"
+ " }\n"
+ " }\n"
+ "}";
ByteArrayContent content = new ByteArrayContent("application/vnd.api+json", payload.getBytes());
HttpRequest restRequest = REQUEST_FACTORY
.buildPostRequest(new GenericUrl(profile.getPortalURL() + "/jsonapi/media/image"), content);
HttpHeaders headers = restRequest.getHeaders();
headers.setAccept("application/vnd.api+json");
headers.setBasicAuthentication(profile.getPortalUserName(), profile.getPortalPassword());
restRequest.setReadTimeout(0);
response = restRequest.execute();
Gson gson = new Gson();
Reader reader = new InputStreamReader(response.getContent());
ImageDocObject model = gson.fromJson(reader, ImageDocObject.class);
if(model != null && model.data!=null) {
logger.info("media--image uuid:" + model.data.id);
return model.data.id;
}
}
catch (HttpResponseException e) {
throw new IOException(exceptionHandler(e));
}
return null;
}

/**
* Import an API Doc
*/
Expand All @@ -572,7 +682,7 @@ public static void updateAPIDoc(ServerProfile profile, File file, APIDocResponse
SpecObject spec = parseSpec(profile, file);

logger.info("Update API catalog");
ByteArrayContent content = getAPIDocContent(profile, spec, doc.data.get(0).id, doc.data.get(0).relationships.field_apidoc_spec.data.id, true);
ByteArrayContent content = constructAPIDocRequestBody(profile, spec, doc.data.get(0).id, doc.data.get(0).relationships.field_apidoc_spec.data.id, doc.data.get(0).relationships.field_image.data.id, true);
HttpRequest restPatchRequest = APACHE_REQUEST_FACTORY.buildRequest(HttpMethods.PATCH, new GenericUrl(profile.getPortalURL() + "/jsonapi/node/apidoc/"+doc.data.get(0).id),
content);
HttpHeaders patchHeaders = restPatchRequest.getHeaders();
Expand Down Expand Up @@ -607,7 +717,7 @@ public static String createAPIDoc(ServerProfile profile, File file, APIDocObject
SpecObject spec = parseSpec(profile, file);

logger.info("Creating spec.." + doc.data.id);
ByteArrayContent content = getAPIDocContent(profile, spec, doc.data.id, null, false);
ByteArrayContent content = constructAPIDocRequestBody(profile, spec, doc.data.id, null, null, false);
HttpRequest restRequest = REQUEST_FACTORY
.buildPostRequest(new GenericUrl(profile.getPortalURL() + "/jsonapi/node/apidoc"), content);
HttpHeaders headers = restRequest.getHeaders();
Expand Down

0 comments on commit 8be356d

Please sign in to comment.