| /* |
| * 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.servicecomb.toolkit.plugin; |
| |
| import java.io.File; |
| import java.io.IOException; |
| import java.util.HashMap; |
| import java.util.Map; |
| import java.util.Objects; |
| |
| import org.apache.maven.plugin.AbstractMojo; |
| import org.apache.maven.plugins.annotations.Execute; |
| import org.apache.maven.plugins.annotations.LifecyclePhase; |
| import org.apache.maven.plugins.annotations.Mojo; |
| import org.apache.maven.plugins.annotations.Parameter; |
| import org.apache.maven.plugins.annotations.ResolutionScope; |
| import org.apache.maven.project.MavenProject; |
| import org.apache.servicecomb.toolkit.codegen.GeneratorExternalConfigConstant; |
| import org.apache.servicecomb.toolkit.common.FileUtils; |
| import org.apache.servicecomb.toolkit.common.SourceType; |
| import org.slf4j.Logger; |
| import org.slf4j.LoggerFactory; |
| |
| @Mojo(name = "generate", defaultPhase = LifecyclePhase.COMPILE, requiresDependencyResolution = ResolutionScope.COMPILE, aggregator = true) |
| @Execute(goal = "generate", phase = LifecyclePhase.COMPILE) |
| public class GenerateMojo extends AbstractMojo { |
| |
| private static Logger LOGGER = LoggerFactory.getLogger(GenerateMojo.class); |
| |
| private String providerProjectNameSuffix = "-provider"; |
| |
| private String consumerProjectNameSuffix = "-consumer"; |
| |
| private String modelProjectNameSuffix = "-model"; |
| |
| @Parameter(defaultValue = "${project}") |
| private MavenProject project; |
| |
| @Parameter(defaultValue = "code") |
| private String sourceType; |
| |
| @Parameter(defaultValue = "yaml") |
| private String contractFileType; |
| |
| @Parameter(defaultValue = "html") |
| private String documentType; |
| |
| @Parameter |
| private String contractLocation; |
| |
| @Parameter(defaultValue = "./target") |
| private String outputDirectory; |
| |
| @Parameter |
| private ServiceConfig service; |
| |
| @Override |
| public void execute() { |
| |
| if (MavenPluginUtil.isParentProject(project)) { |
| for (MavenProject subProject : project.getCollectedProjects()) { |
| generate(subProject); |
| } |
| } else { |
| generate(project); |
| } |
| } |
| |
| private void generate(MavenProject project) { |
| |
| switch (SourceType.valueOf(sourceType.toUpperCase())) { |
| case CODE: |
| // generate contract file |
| String contractOutput = |
| outputDirectory + File.separator + "contract" + File.separator + project.getBasedir().getName(); |
| try { |
| FileUtils.createDirectory(contractOutput); |
| } catch (IOException e) { |
| throw new RuntimeException("Failed to generate contract", e); |
| } |
| |
| GenerateUtil.generateContract(project, contractOutput, contractFileType, "default"); |
| contractLocation = contractOutput; |
| if (Objects.requireNonNull(new File(contractOutput).listFiles()).length == 0) { |
| //noinspection ResultOfMethodCallIgnored |
| new File(contractOutput).delete(); |
| LOGGER.info("No contract in the code"); |
| return; |
| } |
| |
| break; |
| case CONTRACT: |
| if (contractLocation == null) { |
| throw new RuntimeException("Invalid or not config contract location"); |
| } |
| |
| if (!new File(contractLocation).exists()) { |
| throw new RuntimeException("Contract path " + contractLocation + " is not exists"); |
| } |
| |
| break; |
| default: |
| throw new RuntimeException("Not support source type " + sourceType); |
| } |
| |
| //generate microservice project |
| if (service == null) { |
| LOGGER.info("Cannot generate code without service configuration"); |
| } else { |
| String codeOutput = |
| outputDirectory + File.separator + "project" + File.separator; |
| try { |
| FileUtils.createDirectory(codeOutput); |
| Map<String, Object> externalConfig = new HashMap<>(); |
| externalConfig.put(GeneratorExternalConfigConstant.PROVIDER_PROJECT_NAME, |
| project.getBasedir().getName() + providerProjectNameSuffix); |
| externalConfig.put(GeneratorExternalConfigConstant.CONSUMER_PROJECT_NAME, |
| project.getBasedir().getName() + consumerProjectNameSuffix); |
| externalConfig.put(GeneratorExternalConfigConstant.MODEL_PROJECT_NAME, |
| project.getBasedir().getName() + modelProjectNameSuffix); |
| GenerateUtil.generateCode(service, contractLocation, codeOutput, externalConfig, "default"); |
| } catch (RuntimeException | IOException e) { |
| throw new RuntimeException("Failed to generate code", e); |
| } |
| } |
| |
| //generate document |
| String documentOutput = |
| outputDirectory + File.separator + "document" + File.separator + project.getBasedir().getName(); |
| try { |
| FileUtils.createDirectory(documentOutput); |
| GenerateUtil.generateDocument(contractLocation, documentOutput, "default"); |
| } catch (RuntimeException | IOException e) { |
| throw new RuntimeException("Failed to generate document", e); |
| } |
| } |
| } |