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

software.amazon.awscdk.services.gamelift.alpha.StandaloneMatchmakingConfiguration Maven / Gradle / Ivy

There is a newer version: 2.170.0-alpha.0
Show newest version
package software.amazon.awscdk.services.gamelift.alpha;

/**
 * (experimental) A FlexMatch matchmaker process does the work of building a game match.
 * 

* It manages the pool of matchmaking requests received, forms teams for a match, processes and selects players to find the best possible player groups, and initiates the process of placing and starting a game session for the match. * This topic describes the key aspects of a matchmaker and how to configure one customized for your game. *

* Example: *

*

 * MatchmakingRuleSet ruleSet;
 * StandaloneMatchmakingConfiguration.Builder.create(this, "StandaloneMatchmaking")
 *         .matchmakingConfigurationName("test-standalone-config-name")
 *         .ruleSet(ruleSet)
 *         .build();
 * 
*

* @see https://docs.aws.amazon.com/gamelift/latest/flexmatchguide/match-configuration.html */ @javax.annotation.Generated(value = "jsii-pacmak/1.102.0 (build e354887)", date = "2024-08-23T05:56:25.561Z") @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) @software.amazon.jsii.Jsii(module = software.amazon.awscdk.services.gamelift.alpha.$Module.class, fqn = "@aws-cdk/aws-gamelift-alpha.StandaloneMatchmakingConfiguration") public class StandaloneMatchmakingConfiguration extends software.amazon.awscdk.services.gamelift.alpha.MatchmakingConfigurationBase { protected StandaloneMatchmakingConfiguration(final software.amazon.jsii.JsiiObjectRef objRef) { super(objRef); } protected StandaloneMatchmakingConfiguration(final software.amazon.jsii.JsiiObject.InitializationMode initializationMode) { super(initializationMode); } /** * @param scope This parameter is required. * @param id This parameter is required. * @param props This parameter is required. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public StandaloneMatchmakingConfiguration(final @org.jetbrains.annotations.NotNull software.constructs.Construct scope, final @org.jetbrains.annotations.NotNull java.lang.String id, final @org.jetbrains.annotations.NotNull software.amazon.awscdk.services.gamelift.alpha.StandaloneMatchmakingConfigurationProps 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"), java.util.Objects.requireNonNull(props, "props is required") }); } /** * (experimental) Import an existing matchmaking configuration from its ARN. *

* @param scope This parameter is required. * @param id This parameter is required. * @param matchmakingConfigurationArn This parameter is required. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public static @org.jetbrains.annotations.NotNull software.amazon.awscdk.services.gamelift.alpha.IMatchmakingConfiguration fromStandaloneMatchmakingConfigurationArn(final @org.jetbrains.annotations.NotNull software.constructs.Construct scope, final @org.jetbrains.annotations.NotNull java.lang.String id, final @org.jetbrains.annotations.NotNull java.lang.String matchmakingConfigurationArn) { return software.amazon.jsii.JsiiObject.jsiiStaticCall(software.amazon.awscdk.services.gamelift.alpha.StandaloneMatchmakingConfiguration.class, "fromStandaloneMatchmakingConfigurationArn", software.amazon.jsii.NativeType.forClass(software.amazon.awscdk.services.gamelift.alpha.IMatchmakingConfiguration.class), new Object[] { java.util.Objects.requireNonNull(scope, "scope is required"), java.util.Objects.requireNonNull(id, "id is required"), java.util.Objects.requireNonNull(matchmakingConfigurationArn, "matchmakingConfigurationArn is required") }); } /** * (experimental) Import an existing matchmaking configuration from its name. *

* @param scope This parameter is required. * @param id This parameter is required. * @param matchmakingConfigurationName This parameter is required. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public static @org.jetbrains.annotations.NotNull software.amazon.awscdk.services.gamelift.alpha.IMatchmakingConfiguration fromStandaloneMatchmakingConfigurationName(final @org.jetbrains.annotations.NotNull software.constructs.Construct scope, final @org.jetbrains.annotations.NotNull java.lang.String id, final @org.jetbrains.annotations.NotNull java.lang.String matchmakingConfigurationName) { return software.amazon.jsii.JsiiObject.jsiiStaticCall(software.amazon.awscdk.services.gamelift.alpha.StandaloneMatchmakingConfiguration.class, "fromStandaloneMatchmakingConfigurationName", software.amazon.jsii.NativeType.forClass(software.amazon.awscdk.services.gamelift.alpha.IMatchmakingConfiguration.class), new Object[] { java.util.Objects.requireNonNull(scope, "scope is required"), java.util.Objects.requireNonNull(id, "id is required"), java.util.Objects.requireNonNull(matchmakingConfigurationName, "matchmakingConfigurationName is required") }); } /** * (experimental) The ARN of the matchmaking configuration. */ @Override @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public @org.jetbrains.annotations.NotNull java.lang.String getMatchmakingConfigurationArn() { return software.amazon.jsii.Kernel.get(this, "matchmakingConfigurationArn", software.amazon.jsii.NativeType.forClass(java.lang.String.class)); } /** * (experimental) The Identifier of the matchmaking configuration. */ @Override @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public @org.jetbrains.annotations.NotNull java.lang.String getMatchmakingConfigurationName() { return software.amazon.jsii.Kernel.get(this, "matchmakingConfigurationName", software.amazon.jsii.NativeType.forClass(java.lang.String.class)); } /** * (experimental) The notification target for matchmaking events. */ @Override @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public @org.jetbrains.annotations.Nullable software.amazon.awscdk.services.sns.ITopic getNotificationTarget() { return software.amazon.jsii.Kernel.get(this, "notificationTarget", software.amazon.jsii.NativeType.forClass(software.amazon.awscdk.services.sns.ITopic.class)); } /** * (experimental) A fluent builder for {@link software.amazon.awscdk.services.gamelift.alpha.StandaloneMatchmakingConfiguration}. */ @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 final software.amazon.awscdk.services.gamelift.alpha.StandaloneMatchmakingConfigurationProps.Builder props; private Builder(final software.constructs.Construct scope, final java.lang.String id) { this.scope = scope; this.id = id; this.props = new software.amazon.awscdk.services.gamelift.alpha.StandaloneMatchmakingConfigurationProps.Builder(); } /** * (experimental) A unique identifier for the matchmaking configuration. *

* This name is used to identify the configuration associated with a matchmaking request or ticket. *

* @return {@code this} * @param matchmakingConfigurationName A unique identifier for the matchmaking configuration. This parameter is required. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public Builder matchmakingConfigurationName(final java.lang.String matchmakingConfigurationName) { this.props.matchmakingConfigurationName(matchmakingConfigurationName); return this; } /** * (experimental) A matchmaking rule set to use with this configuration. *

* A matchmaking configuration can only use rule sets that are defined in the same Region. *

* @return {@code this} * @param ruleSet A matchmaking rule set to use with this configuration. This parameter is required. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public Builder ruleSet(final software.amazon.awscdk.services.gamelift.alpha.IMatchmakingRuleSet ruleSet) { this.props.ruleSet(ruleSet); return this; } /** * (experimental) The length of time (in seconds) to wait for players to accept a proposed match, if acceptance is required. *

* Default: 300 seconds *

* @return {@code this} * @param acceptanceTimeout The length of time (in seconds) to wait for players to accept a proposed match, if acceptance is required. This parameter is required. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public Builder acceptanceTimeout(final software.amazon.awscdk.Duration acceptanceTimeout) { this.props.acceptanceTimeout(acceptanceTimeout); return this; } /** * (experimental) Information to add to all events related to the matchmaking configuration. *

* Default: no custom data added to events *

* @return {@code this} * @param customEventData Information to add to all events related to the matchmaking configuration. This parameter is required. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public Builder customEventData(final java.lang.String customEventData) { this.props.customEventData(customEventData); return this; } /** * (experimental) A human-readable description of the matchmaking configuration. *

* Default: no description is provided *

* @return {@code this} * @param description A human-readable description of the matchmaking configuration. This parameter is required. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public Builder description(final java.lang.String description) { this.props.description(description); return this; } /** * (experimental) An SNS topic ARN that is set up to receive matchmaking notifications. *

* Default: no notification target *

* @return {@code this} * @see https://docs.aws.amazon.com/gamelift/latest/flexmatchguide/match-notification.html * @param notificationTarget An SNS topic ARN that is set up to receive matchmaking notifications. This parameter is required. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public Builder notificationTarget(final software.amazon.awscdk.services.sns.ITopic notificationTarget) { this.props.notificationTarget(notificationTarget); return this; } /** * (experimental) The maximum duration, that a matchmaking ticket can remain in process before timing out. *

* Requests that fail due to timing out can be resubmitted as needed. *

* Default: 300 seconds *

* @return {@code this} * @param requestTimeout The maximum duration, that a matchmaking ticket can remain in process before timing out. This parameter is required. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public Builder requestTimeout(final software.amazon.awscdk.Duration requestTimeout) { this.props.requestTimeout(requestTimeout); return this; } /** * (experimental) A flag that determines whether a match that was created with this configuration must be accepted by the matched players. *

* With this option enabled, matchmaking tickets use the status REQUIRES_ACCEPTANCE to indicate when a completed potential match is waiting for player acceptance. *

* Default: Acceptance is not required *

* @return {@code this} * @param requireAcceptance A flag that determines whether a match that was created with this configuration must be accepted by the matched players. This parameter is required. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public Builder requireAcceptance(final java.lang.Boolean requireAcceptance) { this.props.requireAcceptance(requireAcceptance); return this; } /** * @return a newly built instance of {@link software.amazon.awscdk.services.gamelift.alpha.StandaloneMatchmakingConfiguration}. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) @Override public software.amazon.awscdk.services.gamelift.alpha.StandaloneMatchmakingConfiguration build() { return new software.amazon.awscdk.services.gamelift.alpha.StandaloneMatchmakingConfiguration( this.scope, this.id, this.props.build() ); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy