You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
CrowdControl/Assets/PlayFabSDK/Data/PlayFabDataModels.cs

405 lines
14 KiB
C#

#if !DISABLE_PLAYFABENTITY_API
using System;
using System.Collections.Generic;
using PlayFab.SharedModels;
namespace PlayFab.DataModels
{
/// <summary>
/// Aborts the pending upload of the requested files.
/// </summary>
[Serializable]
public class AbortFileUploadsRequest : PlayFabRequestCommon
{
/// <summary>
/// The optional custom tags associated with the request (e.g. build number, external trace identifiers, etc.).
/// </summary>
public Dictionary<string,string> CustomTags;
/// <summary>
/// The entity to perform this action on.
/// </summary>
public EntityKey Entity;
/// <summary>
/// Names of the files to have their pending uploads aborted.
/// </summary>
public List<string> FileNames;
/// <summary>
/// The expected version of the profile, if set and doesn't match the current version of the profile the operation will not
/// be performed.
/// </summary>
public int? ProfileVersion;
}
[Serializable]
public class AbortFileUploadsResponse : PlayFabResultCommon
{
/// <summary>
/// The entity id and type.
/// </summary>
public EntityKey Entity;
/// <summary>
/// The current version of the profile, can be used for concurrency control during updates.
/// </summary>
public int ProfileVersion;
}
/// <summary>
/// Deletes the requested files from the entity's profile.
/// </summary>
[Serializable]
public class DeleteFilesRequest : PlayFabRequestCommon
{
/// <summary>
/// The optional custom tags associated with the request (e.g. build number, external trace identifiers, etc.).
/// </summary>
public Dictionary<string,string> CustomTags;
/// <summary>
/// The entity to perform this action on.
/// </summary>
public EntityKey Entity;
/// <summary>
/// Names of the files to be deleted.
/// </summary>
public List<string> FileNames;
/// <summary>
/// The expected version of the profile, if set and doesn't match the current version of the profile the operation will not
/// be performed.
/// </summary>
public int? ProfileVersion;
}
[Serializable]
public class DeleteFilesResponse : PlayFabResultCommon
{
/// <summary>
/// The entity id and type.
/// </summary>
public EntityKey Entity;
/// <summary>
/// The current version of the profile, can be used for concurrency control during updates.
/// </summary>
public int ProfileVersion;
}
/// <summary>
/// Combined entity type and ID structure which uniquely identifies a single entity.
/// </summary>
[Serializable]
public class EntityKey : PlayFabBaseModel
{
/// <summary>
/// Unique ID of the entity.
/// </summary>
public string Id;
/// <summary>
/// Entity type. See https://docs.microsoft.com/gaming/playfab/features/data/entities/available-built-in-entity-types
/// </summary>
public string Type;
}
/// <summary>
/// Finalizes the upload of the requested files. Verifies that the files have been successfully uploaded and moves the file
/// pointers from pending to live.
/// </summary>
[Serializable]
public class FinalizeFileUploadsRequest : PlayFabRequestCommon
{
/// <summary>
/// The optional custom tags associated with the request (e.g. build number, external trace identifiers, etc.).
/// </summary>
public Dictionary<string,string> CustomTags;
/// <summary>
/// The entity to perform this action on.
/// </summary>
public EntityKey Entity;
/// <summary>
/// Names of the files to be finalized. Restricted to a-Z, 0-9, '(', ')', '_', '-' and '.'
/// </summary>
public List<string> FileNames;
/// <summary>
/// The current version of the profile, can be used for concurrency control during updates.
/// </summary>
public int ProfileVersion;
}
[Serializable]
public class FinalizeFileUploadsResponse : PlayFabResultCommon
{
/// <summary>
/// The entity id and type.
/// </summary>
public EntityKey Entity;
/// <summary>
/// Collection of metadata for the entity's files
/// </summary>
public Dictionary<string,GetFileMetadata> Metadata;
/// <summary>
/// The current version of the profile, can be used for concurrency control during updates.
/// </summary>
public int ProfileVersion;
}
[Serializable]
public class GetFileMetadata : PlayFabBaseModel
{
/// <summary>
/// Checksum value for the file, can be used to check if the file on the server has changed.
/// </summary>
public string Checksum;
/// <summary>
/// Download URL where the file can be retrieved
/// </summary>
public string DownloadUrl;
/// <summary>
/// Name of the file
/// </summary>
public string FileName;
/// <summary>
/// Last UTC time the file was modified
/// </summary>
public DateTime LastModified;
/// <summary>
/// Storage service's reported byte count
/// </summary>
public int Size;
}
/// <summary>
/// Returns URLs that may be used to download the files for a profile for a limited length of time. Only returns files that
/// have been successfully uploaded, files that are still pending will either return the old value, if it exists, or
/// nothing.
/// </summary>
[Serializable]
public class GetFilesRequest : PlayFabRequestCommon
{
/// <summary>
/// The optional custom tags associated with the request (e.g. build number, external trace identifiers, etc.).
/// </summary>
public Dictionary<string,string> CustomTags;
/// <summary>
/// The entity to perform this action on.
/// </summary>
public EntityKey Entity;
}
[Serializable]
public class GetFilesResponse : PlayFabResultCommon
{
/// <summary>
/// The entity id and type.
/// </summary>
public EntityKey Entity;
/// <summary>
/// Collection of metadata for the entity's files
/// </summary>
public Dictionary<string,GetFileMetadata> Metadata;
/// <summary>
/// The current version of the profile, can be used for concurrency control during updates.
/// </summary>
public int ProfileVersion;
}
/// <summary>
/// Gets JSON objects from an entity profile and returns it.
/// </summary>
[Serializable]
public class GetObjectsRequest : PlayFabRequestCommon
{
/// <summary>
/// The optional custom tags associated with the request (e.g. build number, external trace identifiers, etc.).
/// </summary>
public Dictionary<string,string> CustomTags;
/// <summary>
/// The entity to perform this action on.
/// </summary>
public EntityKey Entity;
/// <summary>
/// Determines whether the object will be returned as an escaped JSON string or as a un-escaped JSON object. Default is JSON
/// object.
/// </summary>
public bool? EscapeObject;
}
[Serializable]
public class GetObjectsResponse : PlayFabResultCommon
{
/// <summary>
/// The entity id and type.
/// </summary>
public EntityKey Entity;
/// <summary>
/// Requested objects that the calling entity has access to
/// </summary>
public Dictionary<string,ObjectResult> Objects;
/// <summary>
/// The current version of the profile, can be used for concurrency control during updates.
/// </summary>
public int ProfileVersion;
}
[Serializable]
public class InitiateFileUploadMetadata : PlayFabBaseModel
{
/// <summary>
/// Name of the file.
/// </summary>
public string FileName;
/// <summary>
/// Location the data should be sent to via an HTTP PUT operation.
/// </summary>
public string UploadUrl;
}
/// <summary>
/// Returns URLs that may be used to upload the files for a profile 5 minutes. After using the upload calls
/// FinalizeFileUploads must be called to move the file status from pending to live.
/// </summary>
[Serializable]
public class InitiateFileUploadsRequest : PlayFabRequestCommon
{
/// <summary>
/// The optional custom tags associated with the request (e.g. build number, external trace identifiers, etc.).
/// </summary>
public Dictionary<string,string> CustomTags;
/// <summary>
/// The entity to perform this action on.
/// </summary>
public EntityKey Entity;
/// <summary>
/// Names of the files to be set. Restricted to a-Z, 0-9, '(', ')', '_', '-' and '.'
/// </summary>
public List<string> FileNames;
/// <summary>
/// The expected version of the profile, if set and doesn't match the current version of the profile the operation will not
/// be performed.
/// </summary>
public int? ProfileVersion;
}
[Serializable]
public class InitiateFileUploadsResponse : PlayFabResultCommon
{
/// <summary>
/// The entity id and type.
/// </summary>
public EntityKey Entity;
/// <summary>
/// The current version of the profile, can be used for concurrency control during updates.
/// </summary>
public int ProfileVersion;
/// <summary>
/// Collection of file names and upload urls
/// </summary>
public List<InitiateFileUploadMetadata> UploadDetails;
}
[Serializable]
public class ObjectResult : PlayFabBaseModel
{
/// <summary>
/// Un-escaped JSON object, if EscapeObject false or default.
/// </summary>
public object DataObject;
/// <summary>
/// Escaped string JSON body of the object, if EscapeObject is true.
/// </summary>
public string EscapedDataObject;
/// <summary>
/// Name of the object. Restricted to a-Z, 0-9, '(', ')', '_', '-' and '.'
/// </summary>
public string ObjectName;
}
public enum OperationTypes
{
Created,
Updated,
Deleted,
None
}
[Serializable]
public class SetObject : PlayFabBaseModel
{
/// <summary>
/// Body of the object to be saved. If empty and DeleteObject is true object will be deleted if it exists, or no operation
/// will occur if it does not exist. Only one of Object or EscapedDataObject fields may be used.
/// </summary>
public object DataObject;
/// <summary>
/// Flag to indicate that this object should be deleted. Both DataObject and EscapedDataObject must not be set as well.
/// </summary>
public bool? DeleteObject;
/// <summary>
/// Body of the object to be saved as an escaped JSON string. If empty and DeleteObject is true object will be deleted if it
/// exists, or no operation will occur if it does not exist. Only one of DataObject or EscapedDataObject fields may be used.
/// </summary>
public string EscapedDataObject;
/// <summary>
/// Name of object. Restricted to a-Z, 0-9, '(', ')', '_', '-' and '.'.
/// </summary>
public string ObjectName;
}
[Serializable]
public class SetObjectInfo : PlayFabBaseModel
{
/// <summary>
/// Name of the object
/// </summary>
public string ObjectName;
/// <summary>
/// Optional reason to explain why the operation was the result that it was.
/// </summary>
public string OperationReason;
/// <summary>
/// Indicates which operation was completed, either Created, Updated, Deleted or None.
/// </summary>
public OperationTypes? SetResult;
}
/// <summary>
/// Sets JSON objects on the requested entity profile. May include a version number to be used to perform optimistic
/// concurrency operations during update. If the current version differs from the version in the request the request will be
/// ignored. If no version is set on the request then the value will always be updated if the values differ. Using the
/// version value does not guarantee a write though, ConcurrentEditError may still occur if multiple clients are attempting
/// to update the same profile.
/// </summary>
[Serializable]
public class SetObjectsRequest : PlayFabRequestCommon
{
/// <summary>
/// The optional custom tags associated with the request (e.g. build number, external trace identifiers, etc.).
/// </summary>
public Dictionary<string,string> CustomTags;
/// <summary>
/// The entity to perform this action on.
/// </summary>
public EntityKey Entity;
/// <summary>
/// Optional field used for concurrency control. By specifying the previously returned value of ProfileVersion from
/// GetProfile API, you can ensure that the object set will only be performed if the profile has not been updated by any
/// other clients since the version you last loaded.
/// </summary>
public int? ExpectedProfileVersion;
/// <summary>
/// Collection of objects to set on the profile.
/// </summary>
public List<SetObject> Objects;
}
[Serializable]
public class SetObjectsResponse : PlayFabResultCommon
{
/// <summary>
/// New version of the entity profile.
/// </summary>
public int ProfileVersion;
/// <summary>
/// New version of the entity profile.
/// </summary>
public List<SetObjectInfo> SetResults;
}
}
#endif