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

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

package software.amazon.awscdk.services.gamelift.alpha;

/**
 * (experimental) Custom prioritization settings for use by a game session queue when placing new game sessions with available game servers.
 * 

* When defined, this configuration replaces the default FleetIQ prioritization process, which is as follows: *

*

    *
  • If player latency data is included in a game session request, destinations and locations are prioritized first based on lowest average latency (1), then on lowest hosting cost (2), then on destination list order (3), and finally on location (alphabetical) (4). * This approach ensures that the queue's top priority is to place game sessions where average player latency is lowest, and--if latency is the same--where the hosting cost is less, etc.
  • *
  • If player latency data is not included, destinations and locations are prioritized first on destination list order (1), and then on location (alphabetical) (2). * This approach ensures that the queue's top priority is to place game sessions on the first destination fleet listed. If that fleet has multiple locations, the game session is placed on the first location (when listed alphabetically).
  • *
*

* Changing the priority order will affect how game sessions are placed. *

* Example: *

*

 * BuildFleet fleet;
 * Topic topic;
 * GameSessionQueue.Builder.create(this, "MyGameSessionQueue")
 *         .gameSessionQueueName("test-gameSessionQueue")
 *         .customEventData("test-event-data")
 *         .allowedLocations(List.of("eu-west-1", "eu-west-2"))
 *         .destinations(List.of(fleet))
 *         .notificationTarget(topic)
 *         .playerLatencyPolicies(List.of(PlayerLatencyPolicy.builder()
 *                 .maximumIndividualPlayerLatency(Duration.millis(100))
 *                 .policyDuration(Duration.seconds(300))
 *                 .build()))
 *         .priorityConfiguration(PriorityConfiguration.builder()
 *                 .locationOrder(List.of("eu-west-1", "eu-west-2"))
 *                 .priorityOrder(List.of(PriorityType.LATENCY, PriorityType.COST, PriorityType.DESTINATION, PriorityType.LOCATION))
 *                 .build())
 *         .timeout(Duration.seconds(300))
 *         .build();
 * 
*/ @javax.annotation.Generated(value = "jsii-pacmak/1.104.0 (build e79254c)", date = "2024-12-14T13:31:20.045Z") @software.amazon.jsii.Jsii(module = software.amazon.awscdk.services.gamelift.alpha.$Module.class, fqn = "@aws-cdk/aws-gamelift-alpha.PriorityConfiguration") @software.amazon.jsii.Jsii.Proxy(PriorityConfiguration.Jsii$Proxy.class) @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public interface PriorityConfiguration extends software.amazon.jsii.JsiiSerializable { /** * (experimental) The prioritization order to use for fleet locations, when the PriorityOrder property includes LOCATION. *

* Locations are identified by AWS Region codes such as `us-west-2. *

* Each location can only be listed once. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) @org.jetbrains.annotations.NotNull java.util.List getLocationOrder(); /** * (experimental) The recommended sequence to use when prioritizing where to place new game sessions. *

* Each type can only be listed once. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) @org.jetbrains.annotations.NotNull java.util.List getPriorityOrder(); /** * @return a {@link Builder} of {@link PriorityConfiguration} */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) static Builder builder() { return new Builder(); } /** * A builder for {@link PriorityConfiguration} */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public static final class Builder implements software.amazon.jsii.Builder { java.util.List locationOrder; java.util.List priorityOrder; /** * Sets the value of {@link PriorityConfiguration#getLocationOrder} * @param locationOrder The prioritization order to use for fleet locations, when the PriorityOrder property includes LOCATION. This parameter is required. * Locations are identified by AWS Region codes such as `us-west-2. *

* Each location can only be listed once. * @return {@code this} */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public Builder locationOrder(java.util.List locationOrder) { this.locationOrder = locationOrder; return this; } /** * Sets the value of {@link PriorityConfiguration#getPriorityOrder} * @param priorityOrder The recommended sequence to use when prioritizing where to place new game sessions. This parameter is required. * Each type can only be listed once. * @return {@code this} */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) @SuppressWarnings("unchecked") public Builder priorityOrder(java.util.List priorityOrder) { this.priorityOrder = (java.util.List)priorityOrder; return this; } /** * Builds the configured instance. * @return a new instance of {@link PriorityConfiguration} * @throws NullPointerException if any required attribute was not provided */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) @Override public PriorityConfiguration build() { return new Jsii$Proxy(this); } } /** * An implementation for {@link PriorityConfiguration} */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) @software.amazon.jsii.Internal final class Jsii$Proxy extends software.amazon.jsii.JsiiObject implements PriorityConfiguration { private final java.util.List locationOrder; private final java.util.List priorityOrder; /** * Constructor that initializes the object based on values retrieved from the JsiiObject. * @param objRef Reference to the JSII managed object. */ protected Jsii$Proxy(final software.amazon.jsii.JsiiObjectRef objRef) { super(objRef); this.locationOrder = software.amazon.jsii.Kernel.get(this, "locationOrder", software.amazon.jsii.NativeType.listOf(software.amazon.jsii.NativeType.forClass(java.lang.String.class))); this.priorityOrder = software.amazon.jsii.Kernel.get(this, "priorityOrder", software.amazon.jsii.NativeType.listOf(software.amazon.jsii.NativeType.forClass(software.amazon.awscdk.services.gamelift.alpha.PriorityType.class))); } /** * Constructor that initializes the object based on literal property values passed by the {@link Builder}. */ @SuppressWarnings("unchecked") protected Jsii$Proxy(final Builder builder) { super(software.amazon.jsii.JsiiObject.InitializationMode.JSII); this.locationOrder = java.util.Objects.requireNonNull(builder.locationOrder, "locationOrder is required"); this.priorityOrder = (java.util.List)java.util.Objects.requireNonNull(builder.priorityOrder, "priorityOrder is required"); } @Override public final java.util.List getLocationOrder() { return this.locationOrder; } @Override public final java.util.List getPriorityOrder() { return this.priorityOrder; } @Override @software.amazon.jsii.Internal public com.fasterxml.jackson.databind.JsonNode $jsii$toJson() { final com.fasterxml.jackson.databind.ObjectMapper om = software.amazon.jsii.JsiiObjectMapper.INSTANCE; final com.fasterxml.jackson.databind.node.ObjectNode data = com.fasterxml.jackson.databind.node.JsonNodeFactory.instance.objectNode(); data.set("locationOrder", om.valueToTree(this.getLocationOrder())); data.set("priorityOrder", om.valueToTree(this.getPriorityOrder())); final com.fasterxml.jackson.databind.node.ObjectNode struct = com.fasterxml.jackson.databind.node.JsonNodeFactory.instance.objectNode(); struct.set("fqn", om.valueToTree("@aws-cdk/aws-gamelift-alpha.PriorityConfiguration")); struct.set("data", data); final com.fasterxml.jackson.databind.node.ObjectNode obj = com.fasterxml.jackson.databind.node.JsonNodeFactory.instance.objectNode(); obj.set("$jsii.struct", struct); return obj; } @Override public final boolean equals(final Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; PriorityConfiguration.Jsii$Proxy that = (PriorityConfiguration.Jsii$Proxy) o; if (!locationOrder.equals(that.locationOrder)) return false; return this.priorityOrder.equals(that.priorityOrder); } @Override public final int hashCode() { int result = this.locationOrder.hashCode(); result = 31 * result + (this.priorityOrder.hashCode()); return result; } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy