/*
* Copyright 2015 ArcBees Inc.
*
* 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.gwtplatform.dispatch.rest.processors.subresource;
import com.google.auto.service.AutoService;
import com.gwtplatform.dispatch.rest.processors.DispatchRestContextProcessor;
import com.gwtplatform.dispatch.rest.processors.resource.ResourceMethod;
import com.gwtplatform.dispatch.rest.processors.resource.ResourceMethodProcessor;
import com.gwtplatform.processors.tools.logger.Logger;
import com.gwtplatform.processors.tools.outputter.CodeSnippet;
import com.gwtplatform.processors.tools.outputter.Outputter;
import com.gwtplatform.processors.tools.utils.Utils;
import static com.gwtplatform.dispatch.rest.processors.NameUtils.qualifiedMethodName;
@AutoService(ResourceMethodProcessor.class)
public class SubResourceMethodProcessor extends DispatchRestContextProcessor<ResourceMethod, CodeSnippet>
implements ResourceMethodProcessor {
private static final String TEMPLATE = "/com/gwtplatform/dispatch/rest/processors/subresource/SubResourceMethod.vm";
private final SubResourceProcessor subResourceProcessor;
public SubResourceMethodProcessor() {
subResourceProcessor = new SubResourceProcessor();
}
@Override
public synchronized void init(Logger logger, Utils utils, Outputter outputter) {
super.init(logger, utils, outputter);
subResourceProcessor.init(logger, utils, outputter);
}
@Override
public boolean canProcess(ResourceMethod method) {
return method instanceof SubResourceMethod;
}
@Override
public CodeSnippet process(ResourceMethod resourceMethod) {
SubResourceMethod subResourceMethod = (SubResourceMethod) resourceMethod;
String methodName = qualifiedMethodName(resourceMethod);
SubResource subResource = subResourceMethod.getSubResource();
logger.debug("Generating sub-resource method `%s`.", methodName);
CodeSnippet code = outputter.configure(TEMPLATE)
.withParam("method", subResourceMethod.getMethod())
.withParam("subResourceType", subResource.getType())
.withParam("subResourceArguments", subResource.getFields())
.withErrorLogParameter(methodName)
.parse();
subResourceProcessor.process(subResource);
return code;
}
@Override
public void processLast() {
subResourceProcessor.processLast();
}
}