All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.cloudsnorkel.cdk.github.runners.LambdaRunner Maven / Gradle / Ivy

package com.cloudsnorkel.cdk.github.runners;

/**
 * @deprecated use {@link LambdaRunnerProvider }
 */
@javax.annotation.Generated(value = "jsii-pacmak/1.80.0 (build bce6a1d)", date = "2023-04-23T18:13:40.372Z")
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Deprecated)
@Deprecated
@software.amazon.jsii.Jsii(module = com.cloudsnorkel.cdk.github.runners.$Module.class, fqn = "@cloudsnorkel/cdk-github-runners.LambdaRunner")
public class LambdaRunner extends com.cloudsnorkel.cdk.github.runners.LambdaRunnerProvider {

    protected LambdaRunner(final software.amazon.jsii.JsiiObjectRef objRef) {
        super(objRef);
    }

    protected LambdaRunner(final software.amazon.jsii.JsiiObject.InitializationMode initializationMode) {
        super(initializationMode);
    }

    /**
     * @param scope This parameter is required.
     * @param id This parameter is required.
     * @param props
     */
    @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental)
    public LambdaRunner(final @org.jetbrains.annotations.NotNull software.constructs.Construct scope, final @org.jetbrains.annotations.NotNull java.lang.String id, final @org.jetbrains.annotations.Nullable com.cloudsnorkel.cdk.github.runners.LambdaRunnerProviderProps props) {
        super(software.amazon.jsii.JsiiObject.InitializationMode.JSII);
        software.amazon.jsii.JsiiEngine.getInstance().createNewObject(this, new Object[] { java.util.Objects.requireNonNull(scope, "scope is required"), java.util.Objects.requireNonNull(id, "id is required"), props });
    }

    /**
     * @param scope This parameter is required.
     * @param id This parameter is required.
     */
    @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental)
    public LambdaRunner(final @org.jetbrains.annotations.NotNull software.constructs.Construct scope, final @org.jetbrains.annotations.NotNull java.lang.String id) {
        super(software.amazon.jsii.JsiiObject.InitializationMode.JSII);
        software.amazon.jsii.JsiiEngine.getInstance().createNewObject(this, new Object[] { java.util.Objects.requireNonNull(scope, "scope is required"), java.util.Objects.requireNonNull(id, "id is required") });
    }

    /**
     * (experimental) A fluent builder for {@link com.cloudsnorkel.cdk.github.runners.LambdaRunner}.
     */
    @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental)
    public static final class Builder implements software.amazon.jsii.Builder {
        /**
         * @return a new instance of {@link Builder}.
         * @param scope This parameter is required.
         * @param id This parameter is required.
         */
        @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental)
        public static Builder create(final software.constructs.Construct scope, final java.lang.String id) {
            return new Builder(scope, id);
        }

        private final software.constructs.Construct scope;
        private final java.lang.String id;
        private com.cloudsnorkel.cdk.github.runners.LambdaRunnerProviderProps.Builder props;

        private Builder(final software.constructs.Construct scope, final java.lang.String id) {
            this.scope = scope;
            this.id = id;
        }

        /**
         * (experimental) The number of days log events are kept in CloudWatch Logs.
         * 

* When updating * this property, unsetting it doesn't remove the log retention policy. To * remove the retention policy, set the value to INFINITE. *

* Default: logs.RetentionDays.ONE_MONTH *

* @return {@code this} * @param logRetention The number of days log events are kept in CloudWatch Logs. This parameter is required. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public Builder logRetention(final software.amazon.awscdk.services.logs.RetentionDays logRetention) { this.props().logRetention(logRetention); return this; } /** * (experimental) Options to retry operation in case of failure like missing capacity, or API quota issues. *

* Default: retry 10 times up to about 45 minutes *

* @return {@code this} * @param retryOptions Options to retry operation in case of failure like missing capacity, or API quota issues. This parameter is required. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public Builder retryOptions(final com.cloudsnorkel.cdk.github.runners.ProviderRetryOptions retryOptions) { this.props().retryOptions(retryOptions); return this; } /** * (experimental) The size of the function’s /tmp directory in MiB. *

* Default: 10 GiB *

* @return {@code this} * @param ephemeralStorageSize The size of the function’s /tmp directory in MiB. This parameter is required. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public Builder ephemeralStorageSize(final software.amazon.awscdk.Size ephemeralStorageSize) { this.props().ephemeralStorageSize(ephemeralStorageSize); return this; } /** * (experimental) Runner image builder used to build Docker images containing GitHub Runner and all requirements. *

* The image builder must contain the {@link RunnerImageComponent.lambdaEntrypoint} component. *

* The image builder determines the OS and architecture of the runner. *

* Default: LambdaRunnerProvider.imageBuilder() *

* @return {@code this} * @param imageBuilder Runner image builder used to build Docker images containing GitHub Runner and all requirements. This parameter is required. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public Builder imageBuilder(final com.cloudsnorkel.cdk.github.runners.IRunnerImageBuilder imageBuilder) { this.props().imageBuilder(imageBuilder); return this; } /** * (deprecated) GitHub Actions label used for this provider. *

* Default: undefined *

* @return {@code this} * @deprecated use {@link labels } instead * @param label GitHub Actions label used for this provider. This parameter is required. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Deprecated) @Deprecated public Builder label(final java.lang.String label) { this.props().label(label); return this; } /** * (experimental) GitHub Actions labels used for this provider. *

* These labels are used to identify which provider should spawn a new on-demand runner. Every job sends a webhook with the labels it's looking for * based on runs-on. We match the labels from the webhook with the labels specified here. If all the labels specified here are present in the * job's labels, this provider will be chosen and spawn a new runner. *

* Default: ['lambda'] *

* @return {@code this} * @param labels GitHub Actions labels used for this provider. This parameter is required. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public Builder labels(final java.util.List labels) { this.props().labels(labels); return this; } /** * (experimental) The amount of memory, in MB, that is allocated to your Lambda function. *

* Lambda uses this value to proportionally allocate the amount of CPU * power. For more information, see Resource Model in the AWS Lambda * Developer Guide. *

* Default: 2048 *

* @return {@code this} * @param memorySize The amount of memory, in MB, that is allocated to your Lambda function. This parameter is required. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public Builder memorySize(final java.lang.Number memorySize) { this.props().memorySize(memorySize); return this; } /** * (deprecated) Security group to assign to this instance. *

* Default: public lambda with no security group *

* @return {@code this} * @deprecated use {@link securityGroups } * @param securityGroup Security group to assign to this instance. This parameter is required. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Deprecated) @Deprecated public Builder securityGroup(final software.amazon.awscdk.services.ec2.ISecurityGroup securityGroup) { this.props().securityGroup(securityGroup); return this; } /** * (experimental) Security groups to assign to this instance. *

* Default: public lambda with no security group *

* @return {@code this} * @param securityGroups Security groups to assign to this instance. This parameter is required. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public Builder securityGroups(final java.util.List securityGroups) { this.props().securityGroups(securityGroups); return this; } /** * (experimental) Where to place the network interfaces within the VPC. *

* Default: no subnet *

* @return {@code this} * @param subnetSelection Where to place the network interfaces within the VPC. This parameter is required. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public Builder subnetSelection(final software.amazon.awscdk.services.ec2.SubnetSelection subnetSelection) { this.props().subnetSelection(subnetSelection); return this; } /** * (experimental) The function execution time (in seconds) after which Lambda terminates the function. *

* Because the execution time affects cost, set this value * based on the function's expected execution time. *

* Default: Duration.minutes(15) *

* @return {@code this} * @param timeout The function execution time (in seconds) after which Lambda terminates the function. This parameter is required. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public Builder timeout(final software.amazon.awscdk.Duration timeout) { this.props().timeout(timeout); return this; } /** * (experimental) VPC to launch the runners in. *

* Default: no VPC *

* @return {@code this} * @param vpc VPC to launch the runners in. This parameter is required. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public Builder vpc(final software.amazon.awscdk.services.ec2.IVpc vpc) { this.props().vpc(vpc); return this; } /** * @returns a newly built instance of {@link com.cloudsnorkel.cdk.github.runners.LambdaRunner}. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) @Override public com.cloudsnorkel.cdk.github.runners.LambdaRunner build() { return new com.cloudsnorkel.cdk.github.runners.LambdaRunner( this.scope, this.id, this.props != null ? this.props.build() : null ); } private com.cloudsnorkel.cdk.github.runners.LambdaRunnerProviderProps.Builder props() { if (this.props == null) { this.props = new com.cloudsnorkel.cdk.github.runners.LambdaRunnerProviderProps.Builder(); } return this.props; } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy