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

net.accelbyte.sdk.api.challenge.operations.challenge_configuration.AdminCreateChallenge Maven / Gradle / Ivy

There is a newer version: 0.7.0
Show newest version
/*
 * Copyright (c) 2024 AccelByte Inc. All Rights Reserved
 * This is licensed software from AccelByte Inc, for limitations
 * and restrictions contact your company contract manager.
 *
 * Code generated. DO NOT EDIT.
 */

package net.accelbyte.sdk.api.challenge.operations.challenge_configuration;

import java.io.*;
import java.util.*;
import lombok.Builder;
import lombok.Getter;
import lombok.Setter;
import net.accelbyte.sdk.api.challenge.models.*;
import net.accelbyte.sdk.core.HttpResponseException;
import net.accelbyte.sdk.core.Operation;
import net.accelbyte.sdk.core.util.Helper;

/**
 * adminCreateChallenge
 *
 * 

* Required permission: ADMIN:NAMESPACE:{namespace}:CHALLENGE [CREATE] * *

Challenge is a collection of goals that can be completed by players. Challenge can have rules * that specify what and when goals will be available for players to be taken. * *

Request body: * *

* code: only lowercase letters, numbers, and the separator - are allowed; must start and end * with letter * name: name of the challenge * description: text describing about the challenge * (optional) * startDate: timestamp of when the challenge is started * endDate: timestamp of when * the challenge is ended (optional) * endAfter: describe number of period challenge will be retired * after (optional) To configure challenge that never end, leave the endDate and endAfter field * null/empty. * repeatAfter: describe number of period challenge's goals will be repeated after. * Leave it empty if you don't want to repeat the challenge. * rotation: describe how long goals in * a challenge will be available for players to progress before rotated with another goals. * (DAILY|WEEKLY|MONTHLY|NONE) * activeGoalsPerRotation: number of goals per rotation (currently * only applicable for RANDOMIZE assignment) * assignmentRule: describe how the goals will be * assigned and scheduled to users. (FIXED|RANDOMIZED|UNSCHEDULED) * goalsVisibility: describe * whether users can see all goals under challenge, or only active goal in one rotation period only. * (SHOWALL|PERIODONLY) * resetConfig: describe when rotation reset will happen (optional). * * resetTime: Reset time must follow hours:minutes in 24 hours format (e.g. 01:30, 23:15) and in UTC * timezone. Default to "00:00" * resetDay: Reset Day follows the ISO-8601 standard, from 1 (Monday) * to 7 (Sunday). Default to 1 in WEEKLY rotation. * resetDate: Reset Date must be a number 1 - 31. * Default to 1 in MONTHLY rotation. * randomizedPerRotation: * true: each goal will be randomly * assigned to multiple periods * false: a goal will only be assigned to one period */ @Getter @Setter public class AdminCreateChallenge extends Operation { /** generated field's value */ private String path = "/challenge/v1/admin/namespaces/{namespace}/challenges"; private String method = "POST"; private List consumes = Arrays.asList("application/json"); private List produces = Arrays.asList("application/json"); private String locationQuery = null; /** fields as input parameter */ private String namespace; private ModelCreateChallengeRequest body; /** * @param namespace required * @param body required */ @Builder // @deprecated 2022-08-29 - All args constructor may cause problems. Use builder instead. @Deprecated public AdminCreateChallenge( String customBasePath, String namespace, ModelCreateChallengeRequest body) { this.namespace = namespace; this.body = body; super.customBasePath = customBasePath != null ? customBasePath : ""; securities.add("Bearer"); } @Override public Map getPathParams() { Map pathParams = new HashMap<>(); if (this.namespace != null) { pathParams.put("namespace", this.namespace); } return pathParams; } @Override public ModelCreateChallengeRequest getBodyParams() { return this.body; } @Override public boolean isValid() { if (this.namespace == null) { return false; } return true; } public ModelChallengeResponse parseResponse(int code, String contentType, InputStream payload) throws HttpResponseException, IOException { if (code != 201) { final String json = Helper.convertInputStreamToString(payload); throw new HttpResponseException(code, json); } final String json = Helper.convertInputStreamToString(payload); return new ModelChallengeResponse().createFromJson(json); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy