// *************************************************************************************************************************** | |
// * Licensed to the Apache Software Foundation (ASF) under one or more contributor license agreements. See the NOTICE file * | |
// * distributed with this work for additional information regarding copyright ownership. The ASF licenses this file * | |
// * to you 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 org.apache.juneau.examples.rest; | |
import static org.apache.juneau.rest.annotation.HookEvent.*; | |
import java.util.*; | |
import org.apache.juneau.jsonschema.annotation.ExternalDocs; | |
import org.apache.juneau.config.*; | |
import org.apache.juneau.http.annotation.*; | |
import org.apache.juneau.http.annotation.Query; | |
import org.apache.juneau.rest.*; | |
import org.apache.juneau.rest.annotation.*; | |
import org.apache.juneau.rest.client.*; | |
import org.apache.juneau.rest.helper.*; | |
/** | |
* Sample resource that shows how to mirror query results from a Docker registry. | |
*/ | |
@RestResource( | |
path="/docker", | |
title="Sample Docker resource", | |
description="Docker registry explorer", | |
htmldoc=@HtmlDoc( | |
navlinks={ | |
"up: request:/..", | |
"options: servlet:/?method=OPTIONS", | |
"source: $C{Source/gitHub}/org/apache/juneau/examples/rest/$R{servletClassSimple}.java" | |
}, | |
// Pull in aside contents from file. | |
aside="$F{resources/DockerRegistryResourceAside.html}" | |
), | |
swagger=@ResourceSwagger( | |
contact=@Contact(name="Apache 2.0",url="http://www.apache.org/licenses/LICENSE-2.0.html"), | |
version="2.0", | |
termsOfService="You are on your own.", | |
externalDocs=@ExternalDocs(description="Apache Juneau",url="http://juneau.apache.org") | |
) | |
) | |
public class DockerRegistryResource extends BasicRestServlet { | |
private static final long serialVersionUID = 1L; | |
// Get registry URL from examples.cfg file. | |
private String registryUrl; | |
RestClient rc; | |
/** | |
* Initializes the registry URL and rest client. | |
* | |
* @param builder The resource config. | |
* @throws Exception | |
*/ | |
@RestHook(INIT) | |
public void initRegistry(RestContextBuilder builder) throws Exception { | |
Config cf = builder.getConfig(); | |
registryUrl = cf.getString("DockerRegistry/url"); | |
rc = RestClient.create().build(); | |
} | |
@Override /* Servlet */ | |
public synchronized void destroy() { | |
rc.closeQuietly(); | |
super.destroy(); | |
} | |
/** [GET /] - Show child resources. */ | |
@RestMethod | |
public ResourceDescriptions get(RestRequest req) { | |
return new ResourceDescriptions() | |
.append("search", "Search Registry") | |
; | |
} | |
/** | |
* PUT request handler. | |
* Replaces the feed with the specified content, and then mirrors it as the response. | |
*/ | |
@RestMethod | |
public QueryResults search(@Query("q") String q) throws Exception { | |
String url = registryUrl + "/search" + (q == null ? "" : "?q=" + q); | |
synchronized(rc) { | |
return rc.doGet(url).getResponse(QueryResults.class); | |
} | |
} | |
public static class QueryResults { | |
public int num_results; | |
public String query; | |
public List<DockerImage> results; | |
} | |
public static class DockerImage { | |
public String name, description; | |
} | |
} |