Class PDKPipelineTsProject.Builder

    • Method Detail

      • name

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder name​(String name)
        (experimental) This is the name of your project.

        Default: $BASEDIR

        Parameters:
        name - This is the name of your project. This parameter is required.
        Returns:
        this
      • logging

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder logging​(io.github.cdklabs.projen.LoggerOptions logging)
        (experimental) Configure logging options such as verbosity.

        Default: {}

        Parameters:
        logging - Configure logging options such as verbosity. This parameter is required.
        Returns:
        this
      • outdir

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder outdir​(String outdir)
        (experimental) The root directory of the project.

        Relative to this directory, all files are synthesized.

        If this project has a parent, this directory is relative to the parent directory and it cannot be the same as the parent or any of it's other sub-projects.

        Default: "."

        Parameters:
        outdir - The root directory of the project. This parameter is required.
        Returns:
        this
      • parent

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder parent​(io.github.cdklabs.projen.Project parent)
        (experimental) The parent project, if this project is part of a bigger project.

        Parameters:
        parent - The parent project, if this project is part of a bigger project. This parameter is required.
        Returns:
        this
      • projenCommand

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder projenCommand​(String projenCommand)
        (experimental) The shell command to use in order to run the projen CLI.

        Can be used to customize in special environments.

        Default: "npx projen"

        Parameters:
        projenCommand - The shell command to use in order to run the projen CLI. This parameter is required.
        Returns:
        this
      • projenrcJson

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder projenrcJson​(Boolean projenrcJson)
        (experimental) Generate (once) .projenrc.json (in JSON). Set to `false` in order to disable .projenrc.json generation.

        Default: false

        Parameters:
        projenrcJson - Generate (once) .projenrc.json (in JSON). Set to `false` in order to disable .projenrc.json generation. This parameter is required.
        Returns:
        this
      • projenrcJsonOptions

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder projenrcJsonOptions​(io.github.cdklabs.projen.ProjenrcOptions projenrcJsonOptions)
        (experimental) Options for .projenrc.json.

        Default: - default options

        Parameters:
        projenrcJsonOptions - Options for .projenrc.json. This parameter is required.
        Returns:
        this
      • autoApproveOptions

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder autoApproveOptions​(io.github.cdklabs.projen.github.AutoApproveOptions autoApproveOptions)
        (experimental) Enable and configure the 'auto approve' workflow.

        Default: - auto approve is disabled

        Parameters:
        autoApproveOptions - Enable and configure the 'auto approve' workflow. This parameter is required.
        Returns:
        this
      • autoMergeOptions

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder autoMergeOptions​(io.github.cdklabs.projen.github.AutoMergeOptions autoMergeOptions)
        (experimental) Configure options for automatic merging on GitHub.

        Has no effect if github.mergify is set to false.

        Default: - see defaults in `AutoMergeOptions`

        Parameters:
        autoMergeOptions - Configure options for automatic merging on GitHub. This parameter is required.
        Returns:
        this
      • clobber

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder clobber​(Boolean clobber)
        (experimental) Add a `clobber` task which resets the repo to origin.

        Default: true

        Parameters:
        clobber - Add a `clobber` task which resets the repo to origin. This parameter is required.
        Returns:
        this
      • devContainer

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder devContainer​(Boolean devContainer)
        (experimental) Add a VSCode development environment (used for GitHub Codespaces).

        Default: false

        Parameters:
        devContainer - Add a VSCode development environment (used for GitHub Codespaces). This parameter is required.
        Returns:
        this
      • github

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder github​(Boolean github)
        (experimental) Enable GitHub integration.

        Enabled by default for root projects. Disabled for non-root projects.

        Default: true

        Parameters:
        github - Enable GitHub integration. This parameter is required.
        Returns:
        this
      • githubOptions

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder githubOptions​(io.github.cdklabs.projen.github.GitHubOptions githubOptions)
        (experimental) Options for GitHub integration.

        Default: - see GitHubOptions

        Parameters:
        githubOptions - Options for GitHub integration. This parameter is required.
        Returns:
        this
      • gitpod

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder gitpod​(Boolean gitpod)
        (experimental) Add a Gitpod development environment.

        Default: false

        Parameters:
        gitpod - Add a Gitpod development environment. This parameter is required.
        Returns:
        this
      • mergify

        @Stability(Deprecated)
        @Deprecated
        public PDKPipelineTsProject.Builder mergify​(Boolean mergify)
        Deprecated.
        use `githubOptions.mergify` instead
        (deprecated) Whether mergify should be enabled on this repository or not.

        Default: true

        Parameters:
        mergify - Whether mergify should be enabled on this repository or not. This parameter is required.
        Returns:
        this
      • mergifyOptions

        @Stability(Deprecated)
        @Deprecated
        public PDKPipelineTsProject.Builder mergifyOptions​(io.github.cdklabs.projen.github.MergifyOptions mergifyOptions)
        Deprecated.
        use `githubOptions.mergifyOptions` instead
        (deprecated) Options for mergify.

        Default: - default options

        Parameters:
        mergifyOptions - Options for mergify. This parameter is required.
        Returns:
        this
      • projectType

        @Stability(Deprecated)
        @Deprecated
        public PDKPipelineTsProject.Builder projectType​(io.github.cdklabs.projen.ProjectType projectType)
        Deprecated.
        no longer supported at the base project level
        (deprecated) Which type of project this is (library/app).

        Default: ProjectType.UNKNOWN

        Parameters:
        projectType - Which type of project this is (library/app). This parameter is required.
        Returns:
        this
      • projenTokenSecret

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder projenTokenSecret​(String projenTokenSecret)
        (experimental) The name of a secret which includes a GitHub Personal Access Token to be used by projen workflows.

        This token needs to have the repo, workflows and packages scope.

        Default: "PROJEN_GITHUB_TOKEN"

        Parameters:
        projenTokenSecret - The name of a secret which includes a GitHub Personal Access Token to be used by projen workflows. This parameter is required.
        Returns:
        this
      • readme

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder readme​(io.github.cdklabs.projen.SampleReadmeProps readme)
        (experimental) The README setup.

        Default: - { filename: 'README.md', contents: '# replace this' }

        Example:

         "{ filename: 'readme.md', contents: '# title' }"
         

        Parameters:
        readme - The README setup. This parameter is required.
        Returns:
        this
      • stale

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder stale​(Boolean stale)
        (experimental) Auto-close of stale issues and pull request.

        See staleOptions for options.

        Default: true

        Parameters:
        stale - Auto-close of stale issues and pull request. This parameter is required.
        Returns:
        this
      • staleOptions

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder staleOptions​(io.github.cdklabs.projen.github.StaleOptions staleOptions)
        (experimental) Auto-close stale issues and pull requests.

        To disable set stale to false.

        Default: - see defaults in `StaleOptions`

        Parameters:
        staleOptions - Auto-close stale issues and pull requests. This parameter is required.
        Returns:
        this
      • vscode

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder vscode​(Boolean vscode)
        (experimental) Enable VSCode integration.

        Enabled by default for root projects. Disabled for non-root projects.

        Default: true

        Parameters:
        vscode - Enable VSCode integration. This parameter is required.
        Returns:
        this
      • allowLibraryDependencies

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder allowLibraryDependencies​(Boolean allowLibraryDependencies)
        (experimental) Allow the project to include `peerDependencies` and `bundledDependencies`.

        This is normally only allowed for libraries. For apps, there's no meaning for specifying these.

        Default: true

        Parameters:
        allowLibraryDependencies - Allow the project to include `peerDependencies` and `bundledDependencies`. This parameter is required.
        Returns:
        this
      • authorEmail

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder authorEmail​(String authorEmail)
        (experimental) Author's e-mail.

        Parameters:
        authorEmail - Author's e-mail. This parameter is required.
        Returns:
        this
      • authorName

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder authorName​(String authorName)
        (experimental) Author's name.

        Parameters:
        authorName - Author's name. This parameter is required.
        Returns:
        this
      • authorOrganization

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder authorOrganization​(Boolean authorOrganization)
        (experimental) Author's Organization.

        Parameters:
        authorOrganization - Author's Organization. This parameter is required.
        Returns:
        this
      • authorUrl

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder authorUrl​(String authorUrl)
        (experimental) Author's URL / Website.

        Parameters:
        authorUrl - Author's URL / Website. This parameter is required.
        Returns:
        this
      • autoDetectBin

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder autoDetectBin​(Boolean autoDetectBin)
        (experimental) Automatically add all executables under the `bin` directory to your `package.json` file under the `bin` section.

        Default: true

        Parameters:
        autoDetectBin - Automatically add all executables under the `bin` directory to your `package.json` file under the `bin` section. This parameter is required.
        Returns:
        this
      • bin

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder bin​(Map<String,​String> bin)
        (experimental) Binary programs vended with your module.

        You can use this option to add/customize how binaries are represented in your package.json, but unless autoDetectBin is false, every executable file under bin will automatically be added to this section.

        Parameters:
        bin - Binary programs vended with your module. This parameter is required.
        Returns:
        this
      • bugsEmail

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder bugsEmail​(String bugsEmail)
        (experimental) The email address to which issues should be reported.

        Parameters:
        bugsEmail - The email address to which issues should be reported. This parameter is required.
        Returns:
        this
      • bugsUrl

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder bugsUrl​(String bugsUrl)
        (experimental) The url to your project's issue tracker.

        Parameters:
        bugsUrl - The url to your project's issue tracker. This parameter is required.
        Returns:
        this
      • bundledDeps

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder bundledDeps​(List<String> bundledDeps)
        (experimental) List of dependencies to bundle into this module.

        These modules will be added both to the dependencies section and bundledDependencies section of your package.json.

        The recommendation is to only specify the module name here (e.g. express). This will behave similar to yarn add or npm install in the sense that it will add the module as a dependency to your package.json file with the latest version (^). You can specify semver requirements in the same syntax passed to npm i or yarn add (e.g. express@^2) and this will be what you package.json will eventually include.

        Parameters:
        bundledDeps - List of dependencies to bundle into this module. This parameter is required.
        Returns:
        this
      • codeArtifactOptions

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder codeArtifactOptions​(io.github.cdklabs.projen.javascript.CodeArtifactOptions codeArtifactOptions)
        (experimental) Options for publishing npm package to AWS CodeArtifact.

        Default: - undefined

        Parameters:
        codeArtifactOptions - Options for publishing npm package to AWS CodeArtifact. This parameter is required.
        Returns:
        this
      • deps

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder deps​(List<String> deps)
        (experimental) Runtime dependencies of this module.

        The recommendation is to only specify the module name here (e.g. express). This will behave similar to yarn add or npm install in the sense that it will add the module as a dependency to your package.json file with the latest version (^). You can specify semver requirements in the same syntax passed to npm i or yarn add (e.g. express@^2) and this will be what you package.json will eventually include.

        Default: []

        Example:

         [ 'express', 'lodash', 'foo@^2' ]
         

        Parameters:
        deps - Runtime dependencies of this module. This parameter is required.
        Returns:
        this
      • description

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder description​(String description)
        (experimental) The description is just a string that helps people understand the purpose of the package.

        It can be used when searching for packages in a package manager as well. See https://classic.yarnpkg.com/en/docs/package-json/#toc-description

        Parameters:
        description - The description is just a string that helps people understand the purpose of the package. This parameter is required.
        Returns:
        this
      • devDeps

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder devDeps​(List<String> devDeps)
        (experimental) Build dependencies for this module.

        These dependencies will only be available in your build environment but will not be fetched when this module is consumed.

        The recommendation is to only specify the module name here (e.g. express). This will behave similar to yarn add or npm install in the sense that it will add the module as a dependency to your package.json file with the latest version (^). You can specify semver requirements in the same syntax passed to npm i or yarn add (e.g. express@^2) and this will be what you package.json will eventually include.

        Default: []

        Example:

         [ 'typescript', '@types/express' ]
         

        Parameters:
        devDeps - Build dependencies for this module. This parameter is required.
        Returns:
        this
      • entrypoint

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder entrypoint​(String entrypoint)
        (experimental) Module entrypoint (`main` in `package.json`).

        Set to an empty string to not include main in your package.json

        Default: "lib/index.js"

        Parameters:
        entrypoint - Module entrypoint (`main` in `package.json`). This parameter is required.
        Returns:
        this
      • homepage

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder homepage​(String homepage)
        (experimental) Package's Homepage / Website.

        Parameters:
        homepage - Package's Homepage / Website. This parameter is required.
        Returns:
        this
      • keywords

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder keywords​(List<String> keywords)
        (experimental) Keywords to include in `package.json`.

        Parameters:
        keywords - Keywords to include in `package.json`. This parameter is required.
        Returns:
        this
      • license

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder license​(String license)
        (experimental) License's SPDX identifier.

        See https://github.com/projen/projen/tree/main/license-text for a list of supported licenses. Use the licensed option if you want to no license to be specified.

        Default: "Apache-2.0"

        Parameters:
        license - License's SPDX identifier. This parameter is required.
        Returns:
        this
      • licensed

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder licensed​(Boolean licensed)
        (experimental) Indicates if a license should be added.

        Default: true

        Parameters:
        licensed - Indicates if a license should be added. This parameter is required.
        Returns:
        this
      • maxNodeVersion

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder maxNodeVersion​(String maxNodeVersion)
        (experimental) Minimum node.js version to require via `engines` (inclusive).

        Default: - no max

        Parameters:
        maxNodeVersion - Minimum node.js version to require via `engines` (inclusive). This parameter is required.
        Returns:
        this
      • minNodeVersion

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder minNodeVersion​(String minNodeVersion)
        (experimental) Minimum Node.js version to require via package.json `engines` (inclusive).

        Default: - no "engines" specified

        Parameters:
        minNodeVersion - Minimum Node.js version to require via package.json `engines` (inclusive). This parameter is required.
        Returns:
        this
      • npmAccess

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder npmAccess​(io.github.cdklabs.projen.javascript.NpmAccess npmAccess)
        (experimental) Access level of the npm package.

        Default: - for scoped packages (e.g. `foo@bar`), the default is `NpmAccess.RESTRICTED`, for non-scoped packages, the default is `NpmAccess.PUBLIC`.

        Parameters:
        npmAccess - Access level of the npm package. This parameter is required.
        Returns:
        this
      • npmRegistry

        @Stability(Deprecated)
        @Deprecated
        public PDKPipelineTsProject.Builder npmRegistry​(String npmRegistry)
        Deprecated.
        use `npmRegistryUrl` instead
        (deprecated) The host name of the npm registry to publish to.

        Cannot be set together with npmRegistryUrl.

        Parameters:
        npmRegistry - The host name of the npm registry to publish to. This parameter is required.
        Returns:
        this
      • npmRegistryUrl

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder npmRegistryUrl​(String npmRegistryUrl)
        (experimental) The base URL of the npm package registry.

        Must be a URL (e.g. start with "https://" or "http://")

        Default: "https://registry.npmjs.org"

        Parameters:
        npmRegistryUrl - The base URL of the npm package registry. This parameter is required.
        Returns:
        this
      • npmTokenSecret

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder npmTokenSecret​(String npmTokenSecret)
        (experimental) GitHub secret which contains the NPM token to use when publishing packages.

        Default: "NPM_TOKEN"

        Parameters:
        npmTokenSecret - GitHub secret which contains the NPM token to use when publishing packages. This parameter is required.
        Returns:
        this
      • packageManager

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder packageManager​(io.github.cdklabs.projen.javascript.NodePackageManager packageManager)
        (experimental) The Node Package Manager used to execute scripts.

        Default: NodePackageManager.YARN

        Parameters:
        packageManager - The Node Package Manager used to execute scripts. This parameter is required.
        Returns:
        this
      • packageName

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder packageName​(String packageName)
        (experimental) The "name" in package.json.

        Default: - defaults to project name

        Parameters:
        packageName - The "name" in package.json. This parameter is required.
        Returns:
        this
      • peerDependencyOptions

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder peerDependencyOptions​(io.github.cdklabs.projen.javascript.PeerDependencyOptions peerDependencyOptions)
        (experimental) Options for `peerDeps`.

        Parameters:
        peerDependencyOptions - Options for `peerDeps`. This parameter is required.
        Returns:
        this
      • peerDeps

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder peerDeps​(List<String> peerDeps)
        (experimental) Peer dependencies for this module.

        Dependencies listed here are required to be installed (and satisfied) by the consumer of this library. Using peer dependencies allows you to ensure that only a single module of a certain library exists in the node_modules tree of your consumers.

        Note that prior to npm@7, peer dependencies are not automatically installed, which means that adding peer dependencies to a library will be a breaking change for your customers.

        Unless peerDependencyOptions.pinnedDevDependency is disabled (it is enabled by default), projen will automatically add a dev dependency with a pinned version for each peer dependency. This will ensure that you build & test your module against the lowest peer version required.

        Default: []

        Parameters:
        peerDeps - Peer dependencies for this module. This parameter is required.
        Returns:
        this
      • repository

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder repository​(String repository)
        (experimental) The repository is the location where the actual code for your package lives.

        See https://classic.yarnpkg.com/en/docs/package-json/#toc-repository

        Parameters:
        repository - The repository is the location where the actual code for your package lives. This parameter is required.
        Returns:
        this
      • repositoryDirectory

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder repositoryDirectory​(String repositoryDirectory)
        (experimental) If the package.json for your package is not in the root directory (for example if it is part of a monorepo), you can specify the directory in which it lives.

        Parameters:
        repositoryDirectory - If the package.json for your package is not in the root directory (for example if it is part of a monorepo), you can specify the directory in which it lives. This parameter is required.
        Returns:
        this
      • scripts

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder scripts​(Map<String,​String> scripts)
        (experimental) npm scripts to include.

        If a script has the same name as a standard script, the standard script will be overwritten.

        Default: {}

        Parameters:
        scripts - npm scripts to include. This parameter is required.
        Returns:
        this
      • stability

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder stability​(String stability)
        (experimental) Package's Stability.

        Parameters:
        stability - Package's Stability. This parameter is required.
        Returns:
        this
      • jsiiReleaseVersion

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder jsiiReleaseVersion​(String jsiiReleaseVersion)
        (experimental) Version requirement of `publib` which is used to publish modules to npm.

        Default: "latest"

        Parameters:
        jsiiReleaseVersion - Version requirement of `publib` which is used to publish modules to npm. This parameter is required.
        Returns:
        this
      • majorVersion

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder majorVersion​(Number majorVersion)
        (experimental) Major version to release from the default branch.

        If this is specified, we bump the latest version of this major version line. If not specified, we bump the global latest version.

        Default: - Major version is not enforced.

        Parameters:
        majorVersion - Major version to release from the default branch. This parameter is required.
        Returns:
        this
      • npmDistTag

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder npmDistTag​(String npmDistTag)
        (experimental) The npmDistTag to use when publishing from the default branch.

        To set the npm dist-tag for release branches, set the npmDistTag property for each branch.

        Default: "latest"

        Parameters:
        npmDistTag - The npmDistTag to use when publishing from the default branch. This parameter is required.
        Returns:
        this
      • postBuildSteps

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder postBuildSteps​(List<? extends io.github.cdklabs.projen.github.workflows.JobStep> postBuildSteps)
        (experimental) Steps to execute after build as part of the release workflow.

        Default: []

        Parameters:
        postBuildSteps - Steps to execute after build as part of the release workflow. This parameter is required.
        Returns:
        this
      • prerelease

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder prerelease​(String prerelease)
        (experimental) Bump versions from the default branch as pre-releases (e.g. "beta", "alpha", "pre").

        Default: - normal semantic versions

        Parameters:
        prerelease - Bump versions from the default branch as pre-releases (e.g. "beta", "alpha", "pre"). This parameter is required.
        Returns:
        this
      • publishDryRun

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder publishDryRun​(Boolean publishDryRun)
        (experimental) Instead of actually publishing to package managers, just print the publishing command.

        Default: false

        Parameters:
        publishDryRun - Instead of actually publishing to package managers, just print the publishing command. This parameter is required.
        Returns:
        this
      • publishTasks

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder publishTasks​(Boolean publishTasks)
        (experimental) Define publishing tasks that can be executed manually as well as workflows.

        Normally, publishing only happens within automated workflows. Enable this in order to create a publishing task for each publishing activity.

        Default: false

        Parameters:
        publishTasks - Define publishing tasks that can be executed manually as well as workflows. This parameter is required.
        Returns:
        this
      • releaseBranches

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder releaseBranches​(Map<String,​? extends io.github.cdklabs.projen.release.BranchOptions> releaseBranches)
        (experimental) Defines additional release branches.

        A workflow will be created for each release branch which will publish releases from commits in this branch. Each release branch must be assigned a major version number which is used to enforce that versions published from that branch always use that major version. If multiple branches are used, the majorVersion field must also be provided for the default branch.

        Default: - no additional branches are used for release. you can use `addBranch()` to add additional branches.

        Parameters:
        releaseBranches - Defines additional release branches. This parameter is required.
        Returns:
        this
      • releaseEveryCommit

        @Stability(Deprecated)
        @Deprecated
        public PDKPipelineTsProject.Builder releaseEveryCommit​(Boolean releaseEveryCommit)
        Deprecated.
        Use `releaseTrigger: ReleaseTrigger.continuous()` instead
        (deprecated) Automatically release new versions every commit to one of branches in `releaseBranches`.

        Default: true

        Parameters:
        releaseEveryCommit - Automatically release new versions every commit to one of branches in `releaseBranches`. This parameter is required.
        Returns:
        this
      • releaseFailureIssue

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder releaseFailureIssue​(Boolean releaseFailureIssue)
        (experimental) Create a github issue on every failed publishing task.

        Default: false

        Parameters:
        releaseFailureIssue - Create a github issue on every failed publishing task. This parameter is required.
        Returns:
        this
      • releaseFailureIssueLabel

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder releaseFailureIssueLabel​(String releaseFailureIssueLabel)
        (experimental) The label to apply to issues indicating publish failures.

        Only applies if releaseFailureIssue is true.

        Default: "failed-release"

        Parameters:
        releaseFailureIssueLabel - The label to apply to issues indicating publish failures. This parameter is required.
        Returns:
        this
      • releaseSchedule

        @Stability(Deprecated)
        @Deprecated
        public PDKPipelineTsProject.Builder releaseSchedule​(String releaseSchedule)
        Deprecated.
        Use `releaseTrigger: ReleaseTrigger.scheduled()` instead
        (deprecated) CRON schedule to trigger new releases.

        Default: - no scheduled releases

        Parameters:
        releaseSchedule - CRON schedule to trigger new releases. This parameter is required.
        Returns:
        this
      • releaseTagPrefix

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder releaseTagPrefix​(String releaseTagPrefix)
        (experimental) Automatically add the given prefix to release tags. Useful if you are releasing on multiple branches with overlapping version numbers.

        Note: this prefix is used to detect the latest tagged version when bumping, so if you change this on a project with an existing version history, you may need to manually tag your latest release with the new prefix.

        Default: - no prefix

        Parameters:
        releaseTagPrefix - Automatically add the given prefix to release tags. Useful if you are releasing on multiple branches with overlapping version numbers. This parameter is required.
        Returns:
        this
      • releaseTrigger

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder releaseTrigger​(io.github.cdklabs.projen.release.ReleaseTrigger releaseTrigger)
        (experimental) The release trigger to use.

        Default: - Continuous releases (`ReleaseTrigger.continuous()`)

        Parameters:
        releaseTrigger - The release trigger to use. This parameter is required.
        Returns:
        this
      • releaseWorkflowName

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder releaseWorkflowName​(String releaseWorkflowName)
        (experimental) The name of the default release workflow.

        Default: "Release"

        Parameters:
        releaseWorkflowName - The name of the default release workflow. This parameter is required.
        Returns:
        this
      • releaseWorkflowSetupSteps

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder releaseWorkflowSetupSteps​(List<? extends io.github.cdklabs.projen.github.workflows.JobStep> releaseWorkflowSetupSteps)
        (experimental) A set of workflow steps to execute in order to setup the workflow container.

        Parameters:
        releaseWorkflowSetupSteps - A set of workflow steps to execute in order to setup the workflow container. This parameter is required.
        Returns:
        this
      • versionrcOptions

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder versionrcOptions​(Map<String,​? extends Object> versionrcOptions)
        (experimental) Custom configuration used when creating changelog with standard-version package.

        Given values either append to default configuration or overwrite values in it.

        Default: - standard configuration applicable for GitHub repositories

        Parameters:
        versionrcOptions - Custom configuration used when creating changelog with standard-version package. This parameter is required.
        Returns:
        this
      • workflowContainerImage

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder workflowContainerImage​(String workflowContainerImage)
        (experimental) Container image to use for GitHub workflows.

        Default: - default image

        Parameters:
        workflowContainerImage - Container image to use for GitHub workflows. This parameter is required.
        Returns:
        this
      • workflowRunsOn

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder workflowRunsOn​(List<String> workflowRunsOn)
        (experimental) Github Runner selection labels.

        Default: ["ubuntu-latest"]

        Parameters:
        workflowRunsOn - Github Runner selection labels. This parameter is required.
        Returns:
        this
      • defaultReleaseBranch

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder defaultReleaseBranch​(String defaultReleaseBranch)
        (experimental) The name of the main release branch.

        Default: "main"

        Parameters:
        defaultReleaseBranch - The name of the main release branch. This parameter is required.
        Returns:
        this
      • artifactsDirectory

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder artifactsDirectory​(String artifactsDirectory)
        (experimental) A directory which will contain build artifacts.

        Default: "dist"

        Parameters:
        artifactsDirectory - A directory which will contain build artifacts. This parameter is required.
        Returns:
        this
      • autoApproveProjenUpgrades

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder autoApproveProjenUpgrades​(Boolean autoApproveProjenUpgrades)
        (experimental) Automatically approve projen upgrade PRs, allowing them to be merged by mergify (if configued).

        Throw if set to true but autoApproveOptions are not defined.

        Default: false

        Parameters:
        autoApproveProjenUpgrades - Automatically approve projen upgrade PRs, allowing them to be merged by mergify (if configued). This parameter is required.
        Returns:
        this
      • autoApproveUpgrades

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder autoApproveUpgrades​(Boolean autoApproveUpgrades)
        (experimental) Automatically approve deps upgrade PRs, allowing them to be merged by mergify (if configued).

        Throw if set to true but autoApproveOptions are not defined.

        Default: - true

        Parameters:
        autoApproveUpgrades - Automatically approve deps upgrade PRs, allowing them to be merged by mergify (if configued). This parameter is required.
        Returns:
        this
      • buildWorkflow

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder buildWorkflow​(Boolean buildWorkflow)
        (experimental) Define a GitHub workflow for building PRs.

        Default: - true if not a subproject

        Parameters:
        buildWorkflow - Define a GitHub workflow for building PRs. This parameter is required.
        Returns:
        this
      • buildWorkflowTriggers

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder buildWorkflowTriggers​(io.github.cdklabs.projen.github.workflows.Triggers buildWorkflowTriggers)
        (experimental) Build workflow triggers.

        Default: "{ pullRequest: {}, workflowDispatch: {} }"

        Parameters:
        buildWorkflowTriggers - Build workflow triggers. This parameter is required.
        Returns:
        this
      • bundlerOptions

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder bundlerOptions​(io.github.cdklabs.projen.javascript.BundlerOptions bundlerOptions)
        (experimental) Options for `Bundler`.

        Parameters:
        bundlerOptions - Options for `Bundler`. This parameter is required.
        Returns:
        this
      • codeCov

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder codeCov​(Boolean codeCov)
        (experimental) Define a GitHub workflow step for sending code coverage metrics to https://codecov.io/ Uses codecov/codecov-action@v1 A secret is required for private repos. Configured with @codeCovTokenSecret.

        Default: false

        Parameters:
        codeCov - Define a GitHub workflow step for sending code coverage metrics to https://codecov.io/ Uses codecov/codecov-action@v1 A secret is required for private repos. Configured with @codeCovTokenSecret. This parameter is required.
        Returns:
        this
      • codeCovTokenSecret

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder codeCovTokenSecret​(String codeCovTokenSecret)
        (experimental) Define the secret name for a specified https://codecov.io/ token A secret is required to send coverage for private repositories.

        Default: - if this option is not specified, only public repositories are supported

        Parameters:
        codeCovTokenSecret - Define the secret name for a specified https://codecov.io/ token A secret is required to send coverage for private repositories. This parameter is required.
        Returns:
        this
      • copyrightOwner

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder copyrightOwner​(String copyrightOwner)
        (experimental) License copyright owner.

        Default: - defaults to the value of authorName or "" if `authorName` is undefined.

        Parameters:
        copyrightOwner - License copyright owner. This parameter is required.
        Returns:
        this
      • copyrightPeriod

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder copyrightPeriod​(String copyrightPeriod)
        (experimental) The copyright years to put in the LICENSE file.

        Default: - current year

        Parameters:
        copyrightPeriod - The copyright years to put in the LICENSE file. This parameter is required.
        Returns:
        this
      • dependabot

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder dependabot​(Boolean dependabot)
        (experimental) Use dependabot to handle dependency upgrades.

        Cannot be used in conjunction with depsUpgrade.

        Default: false

        Parameters:
        dependabot - Use dependabot to handle dependency upgrades. This parameter is required.
        Returns:
        this
      • dependabotOptions

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder dependabotOptions​(io.github.cdklabs.projen.github.DependabotOptions dependabotOptions)
        (experimental) Options for dependabot.

        Default: - default options

        Parameters:
        dependabotOptions - Options for dependabot. This parameter is required.
        Returns:
        this
      • depsUpgrade

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder depsUpgrade​(Boolean depsUpgrade)
        (experimental) Use github workflows to handle dependency upgrades.

        Cannot be used in conjunction with dependabot.

        Default: true

        Parameters:
        depsUpgrade - Use github workflows to handle dependency upgrades. This parameter is required.
        Returns:
        this
      • depsUpgradeOptions

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder depsUpgradeOptions​(io.github.cdklabs.projen.javascript.UpgradeDependenciesOptions depsUpgradeOptions)
        (experimental) Options for depsUpgrade.

        Default: - default options

        Parameters:
        depsUpgradeOptions - Options for depsUpgrade. This parameter is required.
        Returns:
        this
      • gitignore

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder gitignore​(List<String> gitignore)
        (experimental) Additional entries to .gitignore.

        Parameters:
        gitignore - Additional entries to .gitignore. This parameter is required.
        Returns:
        this
      • jest

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder jest​(Boolean jest)
        (experimental) Setup jest unit tests.

        Default: true

        Parameters:
        jest - Setup jest unit tests. This parameter is required.
        Returns:
        this
      • jestOptions

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder jestOptions​(io.github.cdklabs.projen.javascript.JestOptions jestOptions)
        (experimental) Jest options.

        Default: - default options

        Parameters:
        jestOptions - Jest options. This parameter is required.
        Returns:
        this
      • mutableBuild

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder mutableBuild​(Boolean mutableBuild)
        (experimental) Automatically update files modified during builds to pull-request branches.

        This means that any files synthesized by projen or e.g. test snapshots will always be up-to-date before a PR is merged.

        Implies that PR builds do not have anti-tamper checks.

        Default: true

        Parameters:
        mutableBuild - Automatically update files modified during builds to pull-request branches. This parameter is required.
        Returns:
        this
      • npmignore

        @Stability(Deprecated)
        @Deprecated
        public PDKPipelineTsProject.Builder npmignore​(List<String> npmignore)
        Deprecated.
        - use `project.addPackageIgnore`
        (deprecated) Additional entries to .npmignore.

        Parameters:
        npmignore - Additional entries to .npmignore. This parameter is required.
        Returns:
        this
      • npmignoreEnabled

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder npmignoreEnabled​(Boolean npmignoreEnabled)
        (experimental) Defines an .npmignore file. Normally this is only needed for libraries that are packaged as tarballs.

        Default: true

        Parameters:
        npmignoreEnabled - Defines an .npmignore file. Normally this is only needed for libraries that are packaged as tarballs. This parameter is required.
        Returns:
        this
      • packageValue

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder packageValue​(Boolean packageValue)
        (experimental) Defines a `package` task that will produce an npm tarball under the artifacts directory (e.g. `dist`).

        Default: true

        Parameters:
        packageValue - Defines a `package` task that will produce an npm tarball under the artifacts directory (e.g. `dist`). This parameter is required.
        Returns:
        this
      • prettier

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder prettier​(Boolean prettier)
        (experimental) Setup prettier.

        Default: false

        Parameters:
        prettier - Setup prettier. This parameter is required.
        Returns:
        this
      • prettierOptions

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder prettierOptions​(io.github.cdklabs.projen.javascript.PrettierOptions prettierOptions)
        (experimental) Prettier options.

        Default: - default options

        Parameters:
        prettierOptions - Prettier options. This parameter is required.
        Returns:
        this
      • projenDevDependency

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder projenDevDependency​(Boolean projenDevDependency)
        (experimental) Indicates of "projen" should be installed as a devDependency.

        Default: true

        Parameters:
        projenDevDependency - Indicates of "projen" should be installed as a devDependency. This parameter is required.
        Returns:
        this
      • projenrcJs

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder projenrcJs​(Boolean projenrcJs)
        (experimental) Generate (once) .projenrc.js (in JavaScript). Set to `false` in order to disable .projenrc.js generation.

        Default: - true if projenrcJson is false

        Parameters:
        projenrcJs - Generate (once) .projenrc.js (in JavaScript). Set to `false` in order to disable .projenrc.js generation. This parameter is required.
        Returns:
        this
      • projenrcJsOptions

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder projenrcJsOptions​(io.github.cdklabs.projen.javascript.ProjenrcOptions projenrcJsOptions)
        (experimental) Options for .projenrc.js.

        Default: - default options

        Parameters:
        projenrcJsOptions - Options for .projenrc.js. This parameter is required.
        Returns:
        this
      • projenUpgradeAutoMerge

        @Stability(Deprecated)
        @Deprecated
        public PDKPipelineTsProject.Builder projenUpgradeAutoMerge​(Boolean projenUpgradeAutoMerge)
        Deprecated.
        use `autoApproveProjenUpgrades`.
        (deprecated) Automatically approve projen upgrade PRs, allowing them to be merged by mergify (if configued).

        Throw if set to true but autoApproveOptions are not defined.

        Default: false

        Parameters:
        projenUpgradeAutoMerge - Automatically approve projen upgrade PRs, allowing them to be merged by mergify (if configued). This parameter is required.
        Returns:
        this
      • projenUpgradeSchedule

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder projenUpgradeSchedule​(List<String> projenUpgradeSchedule)
        (experimental) Customize the projenUpgrade schedule in cron expression.

        Default: [ "0 6 * * *" ]

        Parameters:
        projenUpgradeSchedule - Customize the projenUpgrade schedule in cron expression. This parameter is required.
        Returns:
        this
      • projenUpgradeSecret

        @Stability(Deprecated)
        @Deprecated
        public PDKPipelineTsProject.Builder projenUpgradeSecret​(String projenUpgradeSecret)
        Deprecated.
        use `githubTokenSecret` instead.
        (deprecated) Periodically submits a pull request for projen upgrades (executes `yarn projen:upgrade`).

        This setting is a GitHub secret name which contains a GitHub Access Token with repo and workflow permissions.

        This token is used to submit the upgrade pull request, which will likely include workflow updates.

        To create a personal access token see https://github.com/settings/tokens

        Default: - no automatic projen upgrade pull requests

        Parameters:
        projenUpgradeSecret - Periodically submits a pull request for projen upgrades (executes `yarn projen:upgrade`). This parameter is required.
        Returns:
        this
      • projenVersion

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder projenVersion​(String projenVersion)
        (experimental) Version of projen to install.

        Default: - Defaults to the latest version.

        Parameters:
        projenVersion - Version of projen to install. This parameter is required.
        Returns:
        this
      • pullRequestTemplate

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder pullRequestTemplate​(Boolean pullRequestTemplate)
        (experimental) Include a GitHub pull request template.

        Default: true

        Parameters:
        pullRequestTemplate - Include a GitHub pull request template. This parameter is required.
        Returns:
        this
      • pullRequestTemplateContents

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder pullRequestTemplateContents​(List<String> pullRequestTemplateContents)
        (experimental) The contents of the pull request template.

        Default: - default content

        Parameters:
        pullRequestTemplateContents - The contents of the pull request template. This parameter is required.
        Returns:
        this
      • release

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder release​(Boolean release)
        (experimental) Add release management to this project.

        Default: - true (false for subprojects)

        Parameters:
        release - Add release management to this project. This parameter is required.
        Returns:
        this
      • releaseToNpm

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder releaseToNpm​(Boolean releaseToNpm)
        (experimental) Automatically release to npm when new versions are introduced.

        Default: false

        Parameters:
        releaseToNpm - Automatically release to npm when new versions are introduced. This parameter is required.
        Returns:
        this
      • releaseWorkflow

        @Stability(Deprecated)
        @Deprecated
        public PDKPipelineTsProject.Builder releaseWorkflow​(Boolean releaseWorkflow)
        Deprecated.
        see `release`.
        (deprecated) DEPRECATED: renamed to `release`.

        Default: - true if not a subproject

        Parameters:
        releaseWorkflow - DEPRECATED: renamed to `release`. This parameter is required.
        Returns:
        this
      • workflowBootstrapSteps

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder workflowBootstrapSteps​(List<? extends Object> workflowBootstrapSteps)
        (experimental) Workflow steps to use in order to bootstrap this repo.

        Default: "yarn install --frozen-lockfile && yarn projen"

        Parameters:
        workflowBootstrapSteps - Workflow steps to use in order to bootstrap this repo. This parameter is required.
        Returns:
        this
      • workflowGitIdentity

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder workflowGitIdentity​(io.github.cdklabs.projen.github.GitIdentity workflowGitIdentity)
        (experimental) The git identity to use in workflows.

        Default: - GitHub Actions

        Parameters:
        workflowGitIdentity - The git identity to use in workflows. This parameter is required.
        Returns:
        this
      • workflowNodeVersion

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder workflowNodeVersion​(String workflowNodeVersion)
        (experimental) The node version to use in GitHub workflows.

        Default: - same as `minNodeVersion`

        Parameters:
        workflowNodeVersion - The node version to use in GitHub workflows. This parameter is required.
        Returns:
        this
      • disableTsconfig

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder disableTsconfig​(Boolean disableTsconfig)
        (experimental) Do not generate a `tsconfig.json` file (used by jsii projects since tsconfig.json is generated by the jsii compiler).

        Default: false

        Parameters:
        disableTsconfig - Do not generate a `tsconfig.json` file (used by jsii projects since tsconfig.json is generated by the jsii compiler). This parameter is required.
        Returns:
        this
      • docgen

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder docgen​(Boolean docgen)
        (experimental) Docgen by Typedoc.

        Default: false

        Parameters:
        docgen - Docgen by Typedoc. This parameter is required.
        Returns:
        this
      • docsDirectory

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder docsDirectory​(String docsDirectory)
        (experimental) Docs directory.

        Default: "docs"

        Parameters:
        docsDirectory - Docs directory. This parameter is required.
        Returns:
        this
      • entrypointTypes

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder entrypointTypes​(String entrypointTypes)
        (experimental) The .d.ts file that includes the type declarations for this module.

        Default: - .d.ts file derived from the project's entrypoint (usually lib/index.d.ts)

        Parameters:
        entrypointTypes - The .d.ts file that includes the type declarations for this module. This parameter is required.
        Returns:
        this
      • eslint

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder eslint​(Boolean eslint)
        (experimental) Setup eslint.

        Default: true

        Parameters:
        eslint - Setup eslint. This parameter is required.
        Returns:
        this
      • eslintOptions

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder eslintOptions​(io.github.cdklabs.projen.javascript.EslintOptions eslintOptions)
        (experimental) Eslint options.

        Default: - opinionated default options

        Parameters:
        eslintOptions - Eslint options. This parameter is required.
        Returns:
        this
      • libdir

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder libdir​(String libdir)
        (experimental) Typescript artifacts output directory.

        Default: "lib"

        Parameters:
        libdir - Typescript artifacts output directory. This parameter is required.
        Returns:
        this
      • projenrcTs

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder projenrcTs​(Boolean projenrcTs)
        (experimental) Use TypeScript for your projenrc file (`.projenrc.ts`).

        Default: false

        Parameters:
        projenrcTs - Use TypeScript for your projenrc file (`.projenrc.ts`). This parameter is required.
        Returns:
        this
      • projenrcTsOptions

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder projenrcTsOptions​(io.github.cdklabs.projen.typescript.ProjenrcOptions projenrcTsOptions)
        (experimental) Options for .projenrc.ts.

        Parameters:
        projenrcTsOptions - Options for .projenrc.ts. This parameter is required.
        Returns:
        this
      • sampleCode

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder sampleCode​(Boolean sampleCode)
        (experimental) Generate one-time sample in `src/` and `test/` if there are no files there.

        Default: true

        Parameters:
        sampleCode - Generate one-time sample in `src/` and `test/` if there are no files there. This parameter is required.
        Returns:
        this
      • srcdir

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder srcdir​(String srcdir)
        (experimental) Typescript sources directory.

        Default: "src"

        Parameters:
        srcdir - Typescript sources directory. This parameter is required.
        Returns:
        this
      • testdir

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder testdir​(String testdir)
        (experimental) Jest tests directory. Tests files should be named `xxx.test.ts`.

        If this directory is under srcdir (e.g. src/test, src/__tests__), then tests are going to be compiled into lib/ and executed as javascript. If the test directory is outside of src, then we configure jest to compile the code in-memory.

        Default: "test"

        Parameters:
        testdir - Jest tests directory. Tests files should be named `xxx.test.ts`. This parameter is required.
        Returns:
        this
      • tsconfig

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder tsconfig​(io.github.cdklabs.projen.javascript.TypescriptConfigOptions tsconfig)
        (experimental) Custom TSConfig.

        Default: - default options

        Parameters:
        tsconfig - Custom TSConfig. This parameter is required.
        Returns:
        this
      • tsconfigDev

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder tsconfigDev​(io.github.cdklabs.projen.javascript.TypescriptConfigOptions tsconfigDev)
        (experimental) Custom tsconfig options for the development tsconfig.json file (used for testing).

        Default: - use the production tsconfig options

        Parameters:
        tsconfigDev - Custom tsconfig options for the development tsconfig.json file (used for testing). This parameter is required.
        Returns:
        this
      • tsconfigDevFile

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder tsconfigDevFile​(String tsconfigDevFile)
        (experimental) The name of the development tsconfig.json file.

        Default: "tsconfig.dev.json"

        Parameters:
        tsconfigDevFile - The name of the development tsconfig.json file. This parameter is required.
        Returns:
        this
      • typescriptVersion

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder typescriptVersion​(String typescriptVersion)
        (experimental) TypeScript version to use.

        NOTE: Typescript is not semantically versioned and should remain on the same minor, so we recommend using a ~ dependency (e.g. ~1.2.3).

        Default: "latest"

        Parameters:
        typescriptVersion - TypeScript version to use. This parameter is required.
        Returns:
        this
      • buildCommand

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder buildCommand​(String buildCommand)
        (experimental) A command to execute before synthesis.

        This command will be called when running cdk synth or when cdk watch identifies a change in your source code before redeployment.

        Default: - no build command

        Parameters:
        buildCommand - A command to execute before synthesis. This parameter is required.
        Returns:
        this
      • cdkout

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder cdkout​(String cdkout)
        (experimental) cdk.out directory.

        Default: "cdk.out"

        Parameters:
        cdkout - cdk.out directory. This parameter is required.
        Returns:
        this
      • context

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder context​(Map<String,​? extends Object> context)
        (experimental) Additional context to include in `cdk.json`.

        Default: - no additional context

        Parameters:
        context - Additional context to include in `cdk.json`. This parameter is required.
        Returns:
        this
      • featureFlags

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder featureFlags​(Boolean featureFlags)
        (experimental) Include all feature flags in cdk.json.

        Default: true

        Parameters:
        featureFlags - Include all feature flags in cdk.json. This parameter is required.
        Returns:
        this
      • requireApproval

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder requireApproval​(io.github.cdklabs.projen.awscdk.ApprovalLevel requireApproval)
        (experimental) To protect you against unintended changes that affect your security posture, the AWS CDK Toolkit prompts you to approve security-related changes before deploying them.

        Default: ApprovalLevel.BROADENING

        Parameters:
        requireApproval - To protect you against unintended changes that affect your security posture, the AWS CDK Toolkit prompts you to approve security-related changes before deploying them. This parameter is required.
        Returns:
        this
      • watchExcludes

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder watchExcludes​(List<String> watchExcludes)
        (experimental) Glob patterns to exclude from `cdk watch`.

        Default: []

        Parameters:
        watchExcludes - Glob patterns to exclude from `cdk watch`. This parameter is required.
        Returns:
        this
      • watchIncludes

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder watchIncludes​(List<String> watchIncludes)
        (experimental) Glob patterns to include in `cdk watch`.

        Default: []

        Parameters:
        watchIncludes - Glob patterns to include in `cdk watch`. This parameter is required.
        Returns:
        this
      • cdkVersion

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder cdkVersion​(String cdkVersion)
        (experimental) Minimum version of the AWS CDK to depend on.

        Default: "2.1.0"

        Parameters:
        cdkVersion - Minimum version of the AWS CDK to depend on. This parameter is required.
        Returns:
        this
      • cdkAssert

        @Stability(Deprecated)
        @Deprecated
        public PDKPipelineTsProject.Builder cdkAssert​(Boolean cdkAssert)
        Deprecated.
        The
        (deprecated) Warning: NodeJS only.

        Install the @aws-cdk/assert library?

        Default: - will be included by default for AWS CDK >= 1.0.0 < 2.0.0

        Parameters:
        cdkAssert - Warning: NodeJS only. This parameter is required.
        Returns:
        this
      • cdkAssertions

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder cdkAssertions​(Boolean cdkAssertions)
        (experimental) Install the assertions library?

        Only needed for CDK 1.x. If using CDK 2.x then assertions is already included in 'aws-cdk-lib'

        Default: - will be included by default for AWS CDK >= 1.111.0 < 2.0.0

        Parameters:
        cdkAssertions - Install the assertions library?. This parameter is required.
        Returns:
        this
      • cdkDependencies

        @Stability(Deprecated)
        @Deprecated
        public PDKPipelineTsProject.Builder cdkDependencies​(List<String> cdkDependencies)
        Deprecated.
        For CDK 2.x use "deps" instead. (or "peerDeps" if you're building a library)
        (deprecated) Which AWS CDKv1 modules this project requires.

        Parameters:
        cdkDependencies - Which AWS CDKv1 modules this project requires. This parameter is required.
        Returns:
        this
      • cdkDependenciesAsDeps

        @Stability(Deprecated)
        @Deprecated
        public PDKPipelineTsProject.Builder cdkDependenciesAsDeps​(Boolean cdkDependenciesAsDeps)
        Deprecated.
        Not supported in CDK v2.
        (deprecated) If this is enabled (default), all modules declared in `cdkDependencies` will be also added as normal `dependencies` (as well as `peerDependencies`).

        This is to ensure that downstream consumers actually have your CDK dependencies installed when using npm < 7 or yarn, where peer dependencies are not automatically installed. If this is disabled, cdkDependencies will be added to devDependencies to ensure they are present during development.

        Note: this setting only applies to construct library projects

        Default: true

        Parameters:
        cdkDependenciesAsDeps - If this is enabled (default), all modules declared in `cdkDependencies` will be also added as normal `dependencies` (as well as `peerDependencies`). This parameter is required.
        Returns:
        this
      • cdkTestDependencies

        @Stability(Deprecated)
        @Deprecated
        public PDKPipelineTsProject.Builder cdkTestDependencies​(List<String> cdkTestDependencies)
        Deprecated.
        For CDK 2.x use 'devDeps' (in node.js projects) or 'testDeps' (in java projects) instead
        (deprecated) AWS CDK modules required for testing.

        Parameters:
        cdkTestDependencies - AWS CDK modules required for testing. This parameter is required.
        Returns:
        this
      • cdkVersionPinning

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder cdkVersionPinning​(Boolean cdkVersionPinning)
        (experimental) Use pinned version instead of caret version for CDK.

        You can use this to prevent mixed versions for your CDK dependencies and to prevent auto-updates. If you use experimental features this will let you define the moment you include breaking changes.

        Parameters:
        cdkVersionPinning - Use pinned version instead of caret version for CDK. This parameter is required.
        Returns:
        this
      • constructsVersion

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder constructsVersion​(String constructsVersion)
        (experimental) Minimum version of the `constructs` library to depend on.

        Default: - for CDK 1.x the default is "3.2.27", for CDK 2.x the default is "10.0.5".

        Parameters:
        constructsVersion - Minimum version of the `constructs` library to depend on. This parameter is required.
        Returns:
        this
      • appEntrypoint

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder appEntrypoint​(String appEntrypoint)
        (experimental) The CDK app's entrypoint (relative to the source directory, which is "src" by default).

        Default: "main.ts"

        Parameters:
        appEntrypoint - The CDK app's entrypoint (relative to the source directory, which is "src" by default). This parameter is required.
        Returns:
        this
      • integrationTestAutoDiscover

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder integrationTestAutoDiscover​(Boolean integrationTestAutoDiscover)
        (experimental) Automatically discovers and creates integration tests for each `.integ.ts` file in under your test directory.

        Default: true

        Parameters:
        integrationTestAutoDiscover - Automatically discovers and creates integration tests for each `.integ.ts` file in under your test directory. This parameter is required.
        Returns:
        this
      • lambdaAutoDiscover

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder lambdaAutoDiscover​(Boolean lambdaAutoDiscover)
        (experimental) Automatically adds an `awscdk.LambdaFunction` for each `.lambda.ts` handler in your source tree. If this is disabled, you can manually add an `awscdk.AutoDiscover` component to your project.

        Default: true

        Parameters:
        lambdaAutoDiscover - Automatically adds an `awscdk.LambdaFunction` for each `.lambda.ts` handler in your source tree. If this is disabled, you can manually add an `awscdk.AutoDiscover` component to your project. This parameter is required.
        Returns:
        this
      • lambdaOptions

        @Stability(Experimental)
        public PDKPipelineTsProject.Builder lambdaOptions​(io.github.cdklabs.projen.awscdk.LambdaFunctionCommonOptions lambdaOptions)
        (experimental) Common options for all AWS Lambda functions.

        Default: - default options

        Parameters:
        lambdaOptions - Common options for all AWS Lambda functions. This parameter is required.
        Returns:
        this