Избегайте генерации build.gradle при использовании swagger-codegen-plugin - PullRequest
1 голос
/ 17 марта 2020

Мы используем gradle.plugin.org.detoeuf: swagger-codegen-plugin. Мы хотим изменить содержимое файла build.gradle в выходном каталоге.

Мы добавили файл gradle.build в .swagger-codegen-ignore, но ОБА. .Swagger-codegen -ignore файл и файл gradle.build воссоздаются каждый раз, когда мы вызываем задачу swagger.

Наш раздел swagger выглядит следующим образом:

swagger {
    inputSpec = "${project.projectDir}/swagger/backoffice-service-api-swagger.json"
    outputDir = file("${project.projectDir}/../backoffice-service-api-client/")
    lang = 'java'
    additionalProperties = [
            'invokerPackage'         : 'com.aaa.bbb.backoffice.service',
            'modelPackage'           : 'com.aaa.bbb.backoffice.service.model',
            'apiPackage'             : 'com.aaa.bbb.backoffice.service.api',
            'dateLibrary'            : 'joda',
            'groupId'                : 'com.aaa.bbb',
            'artifactId'             : 'backoffice-service-api-client',
            'artifactVersion'        : '1.0.0',
            'hideGenerationTimestamp': 'true',
            'dateLibrary'            : 'java8'
    ]
    systemProperties = ["apiTests" : "false"]
}

.swagger-codegen-ignore file выглядит так это -

# Swagger Codegen Ignore
# Generated by swagger-codegen https://github.com/swagger-api/swagger-codegen

# Use this file to prevent files from being overwritten by the generator.
# The patterns follow closely to .gitignore or .dockerignore.

# As an example, the C# client generator defines ApiClient.cs.
# You can make changes and tell Swagger Codgen to ignore just this file by uncommenting the following line:
#ApiClient.cs

# You can match any string of characters against a directory, file or extension with a single asterisk (*):
#foo/*/qux
# The above matches foo/bar/qux and foo/baz/qux, but not foo/bar/baz/qux

# You can recursively match patterns against a directory, file or extension with a double asterisk (**):
#foo/**/qux
# This matches foo/bar/qux, foo/baz/qux, and foo/bar/baz/qux

# You can also negate patterns with an exclamation (!).
# For example, you can ignore all files in a docs folder with the file extension .md:
#docs/*.md
# Then explicitly reverse the ignore rule for a single file:
#!docs/README.md
build.gradle

1 Ответ

0 голосов
/ 19 марта 2020

Вы можете добавить опцию ignoreFileOverride в дополнительные свойства, как показано ниже. Файлы, предоставленные в опции ignoreFileOverride, не существуют в проекте, тогда swagger-codegen сгенерирует их, а если файлы существуют в проекте, swagger-codegen их проигнорирует.

swagger {
    inputSpec = "${project.projectDir}/swagger/backoffice-service-api-swagger.json"
    outputDir = file("${project.projectDir}/../backoffice-service-api-client/")
    lang = 'java'
    additionalProperties = [
            'invokerPackage'         : 'com.aaa.bbb.backoffice.service',
            'modelPackage'           : 'com.aaa.bbb.backoffice.service.model',
            'apiPackage'             : 'com.aaa.bbb.backoffice.service.api',
            'dateLibrary'            : 'joda',
            'groupId'                : 'com.aaa.bbb',
            'artifactId'             : 'backoffice-service-api-client',
            'artifactVersion'        : '1.0.0',
            'hideGenerationTimestamp': 'true',
            'dateLibrary'            : 'java8',
            'ignoreFileOverride'     : '.swagger-codegen-ignore,build.gradle'
    ]
    systemProperties = ["apiTests" : "false"]
}
...