Repository URL to install this package:
Version:
2025.3.18 ▾
|
/*
* Copyright 2016 Game Server Services, Inc. or its affiliates. All Rights
* Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License").
* You may not use this file except in compliance with the License.
* A copy of the License is located at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* or in the "license" file accompanying this file. This file is distributed
* on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
* express or implied. See the License for the specific language governing
* permissions and limitations under the License.
*/
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text.RegularExpressions;
using Gs2.Core.Model;
using Gs2.Util.LitJson;
#if UNITY_2017_1_OR_NEWER
using UnityEngine.Scripting;
#endif
namespace Gs2.Gs2Inventory.Model
{
#if UNITY_2017_1_OR_NEWER
[Preserve]
#endif
public partial class BigItem : IComparable
{
public string ItemId { set; get; }
public string UserId { set; get; }
public string ItemName { set; get; }
public string Count { set; get; }
public long? CreatedAt { set; get; }
public long? UpdatedAt { set; get; }
public long? Revision { set; get; }
public BigItem WithItemId(string itemId) {
this.ItemId = itemId;
return this;
}
public BigItem WithUserId(string userId) {
this.UserId = userId;
return this;
}
public BigItem WithItemName(string itemName) {
this.ItemName = itemName;
return this;
}
public BigItem WithCount(string count) {
this.Count = count;
return this;
}
public BigItem WithCreatedAt(long? createdAt) {
this.CreatedAt = createdAt;
return this;
}
public BigItem WithUpdatedAt(long? updatedAt) {
this.UpdatedAt = updatedAt;
return this;
}
public BigItem WithRevision(long? revision) {
this.Revision = revision;
return this;
}
private static System.Text.RegularExpressions.Regex _regionRegex = new System.Text.RegularExpressions.Regex(
@"grn:gs2:(?<region>.+):(?<ownerId>.+):inventory:(?<namespaceName>.+):user:(?<userId>.+):big:inventory:(?<inventoryName>.+):item:(?<itemName>.+)",
System.Text.RegularExpressions.RegexOptions.IgnoreCase
);
public static string GetRegionFromGrn(
string grn
)
{
var match = _regionRegex.Match(grn);
if (!match.Success || !match.Groups["region"].Success)
{
return null;
}
return match.Groups["region"].Value;
}
private static System.Text.RegularExpressions.Regex _ownerIdRegex = new System.Text.RegularExpressions.Regex(
@"grn:gs2:(?<region>.+):(?<ownerId>.+):inventory:(?<namespaceName>.+):user:(?<userId>.+):big:inventory:(?<inventoryName>.+):item:(?<itemName>.+)",
System.Text.RegularExpressions.RegexOptions.IgnoreCase
);
public static string GetOwnerIdFromGrn(
string grn
)
{
var match = _ownerIdRegex.Match(grn);
if (!match.Success || !match.Groups["ownerId"].Success)
{
return null;
}
return match.Groups["ownerId"].Value;
}
private static System.Text.RegularExpressions.Regex _namespaceNameRegex = new System.Text.RegularExpressions.Regex(
@"grn:gs2:(?<region>.+):(?<ownerId>.+):inventory:(?<namespaceName>.+):user:(?<userId>.+):big:inventory:(?<inventoryName>.+):item:(?<itemName>.+)",
System.Text.RegularExpressions.RegexOptions.IgnoreCase
);
public static string GetNamespaceNameFromGrn(
string grn
)
{
var match = _namespaceNameRegex.Match(grn);
if (!match.Success || !match.Groups["namespaceName"].Success)
{
return null;
}
return match.Groups["namespaceName"].Value;
}
private static System.Text.RegularExpressions.Regex _userIdRegex = new System.Text.RegularExpressions.Regex(
@"grn:gs2:(?<region>.+):(?<ownerId>.+):inventory:(?<namespaceName>.+):user:(?<userId>.+):big:inventory:(?<inventoryName>.+):item:(?<itemName>.+)",
System.Text.RegularExpressions.RegexOptions.IgnoreCase
);
public static string GetUserIdFromGrn(
string grn
)
{
var match = _userIdRegex.Match(grn);
if (!match.Success || !match.Groups["userId"].Success)
{
return null;
}
return match.Groups["userId"].Value;
}
private static System.Text.RegularExpressions.Regex _inventoryNameRegex = new System.Text.RegularExpressions.Regex(
@"grn:gs2:(?<region>.+):(?<ownerId>.+):inventory:(?<namespaceName>.+):user:(?<userId>.+):big:inventory:(?<inventoryName>.+):item:(?<itemName>.+)",
System.Text.RegularExpressions.RegexOptions.IgnoreCase
);
public static string GetInventoryNameFromGrn(
string grn
)
{
var match = _inventoryNameRegex.Match(grn);
if (!match.Success || !match.Groups["inventoryName"].Success)
{
return null;
}
return match.Groups["inventoryName"].Value;
}
private static System.Text.RegularExpressions.Regex _itemNameRegex = new System.Text.RegularExpressions.Regex(
@"grn:gs2:(?<region>.+):(?<ownerId>.+):inventory:(?<namespaceName>.+):user:(?<userId>.+):big:inventory:(?<inventoryName>.+):item:(?<itemName>.+)",
System.Text.RegularExpressions.RegexOptions.IgnoreCase
);
public static string GetItemNameFromGrn(
string grn
)
{
var match = _itemNameRegex.Match(grn);
if (!match.Success || !match.Groups["itemName"].Success)
{
return null;
}
return match.Groups["itemName"].Value;
}
#if UNITY_2017_1_OR_NEWER
[Preserve]
#endif
public static BigItem FromJson(JsonData data)
{
if (data == null) {
return null;
}
return new BigItem()
.WithItemId(!data.Keys.Contains("itemId") || data["itemId"] == null ? null : data["itemId"].ToString())
.WithUserId(!data.Keys.Contains("userId") || data["userId"] == null ? null : data["userId"].ToString())
.WithItemName(!data.Keys.Contains("itemName") || data["itemName"] == null ? null : data["itemName"].ToString())
.WithCount(!data.Keys.Contains("count") || data["count"] == null ? null : data["count"].ToString())
.WithCreatedAt(!data.Keys.Contains("createdAt") || data["createdAt"] == null ? null : (long?)(data["createdAt"].ToString().Contains(".") ? (long)double.Parse(data["createdAt"].ToString()) : long.Parse(data["createdAt"].ToString())))
.WithUpdatedAt(!data.Keys.Contains("updatedAt") || data["updatedAt"] == null ? null : (long?)(data["updatedAt"].ToString().Contains(".") ? (long)double.Parse(data["updatedAt"].ToString()) : long.Parse(data["updatedAt"].ToString())))
.WithRevision(!data.Keys.Contains("revision") || data["revision"] == null ? null : (long?)(data["revision"].ToString().Contains(".") ? (long)double.Parse(data["revision"].ToString()) : long.Parse(data["revision"].ToString())));
}
public JsonData ToJson()
{
return new JsonData {
["itemId"] = ItemId,
["userId"] = UserId,
["itemName"] = ItemName,
["count"] = Count,
["createdAt"] = CreatedAt,
["updatedAt"] = UpdatedAt,
["revision"] = Revision,
};
}
public void WriteJson(JsonWriter writer)
{
writer.WriteObjectStart();
if (ItemId != null) {
writer.WritePropertyName("itemId");
writer.Write(ItemId.ToString());
}
if (UserId != null) {
writer.WritePropertyName("userId");
writer.Write(UserId.ToString());
}
if (ItemName != null) {
writer.WritePropertyName("itemName");
writer.Write(ItemName.ToString());
}
if (Count != null) {
writer.WritePropertyName("count");
writer.Write(Count.ToString());
}
if (CreatedAt != null) {
writer.WritePropertyName("createdAt");
writer.Write((CreatedAt.ToString().Contains(".") ? (long)double.Parse(CreatedAt.ToString()) : long.Parse(CreatedAt.ToString())));
}
if (UpdatedAt != null) {
writer.WritePropertyName("updatedAt");
writer.Write((UpdatedAt.ToString().Contains(".") ? (long)double.Parse(UpdatedAt.ToString()) : long.Parse(UpdatedAt.ToString())));
}
if (Revision != null) {
writer.WritePropertyName("revision");
writer.Write((Revision.ToString().Contains(".") ? (long)double.Parse(Revision.ToString()) : long.Parse(Revision.ToString())));
}
writer.WriteObjectEnd();
}
public int CompareTo(object obj)
{
var other = obj as BigItem;
var diff = 0;
if (ItemId == null && ItemId == other.ItemId)
{
// null and null
}
else
{
diff += ItemId.CompareTo(other.ItemId);
}
if (UserId == null && UserId == other.UserId)
{
// null and null
}
else
{
diff += UserId.CompareTo(other.UserId);
}
if (ItemName == null && ItemName == other.ItemName)
{
// null and null
}
else
{
diff += ItemName.CompareTo(other.ItemName);
}
if (Count == null && Count == other.Count)
{
// null and null
}
else
{
diff += Count.CompareTo(other.Count);
}
if (CreatedAt == null && CreatedAt == other.CreatedAt)
{
// null and null
}
else
{
diff += (int)(CreatedAt - other.CreatedAt);
}
if (UpdatedAt == null && UpdatedAt == other.UpdatedAt)
{
// null and null
}
else
{
diff += (int)(UpdatedAt - other.UpdatedAt);
}
if (Revision == null && Revision == other.Revision)
{
// null and null
}
else
{
diff += (int)(Revision - other.Revision);
}
return diff;
}
public void Validate() {
{
if (ItemId.Length > 1024) {
throw new Gs2.Core.Exception.BadRequestException(new [] {
new RequestError("bigItem", "inventory.bigItem.itemId.error.tooLong"),
});
}
}
{
if (UserId.Length > 128) {
throw new Gs2.Core.Exception.BadRequestException(new [] {
new RequestError("bigItem", "inventory.bigItem.userId.error.tooLong"),
});
}
}
{
if (ItemName.Length > 128) {
throw new Gs2.Core.Exception.BadRequestException(new [] {
new RequestError("bigItem", "inventory.bigItem.itemName.error.tooLong"),
});
}
}
{
if (Count.Length > 1024) {
throw new Gs2.Core.Exception.BadRequestException(new [] {
new RequestError("bigItem", "inventory.bigItem.count.error.tooLong"),
});
}
}
{
if (CreatedAt < 0) {
throw new Gs2.Core.Exception.BadRequestException(new [] {
new RequestError("bigItem", "inventory.bigItem.createdAt.error.invalid"),
});
}
if (CreatedAt > 32503680000000) {
throw new Gs2.Core.Exception.BadRequestException(new [] {
new RequestError("bigItem", "inventory.bigItem.createdAt.error.invalid"),
});
}
}
{
if (UpdatedAt < 0) {
throw new Gs2.Core.Exception.BadRequestException(new [] {
new RequestError("bigItem", "inventory.bigItem.updatedAt.error.invalid"),
});
}
if (UpdatedAt > 32503680000000) {
throw new Gs2.Core.Exception.BadRequestException(new [] {
new RequestError("bigItem", "inventory.bigItem.updatedAt.error.invalid"),
});
}
}
{
if (Revision < 0) {
throw new Gs2.Core.Exception.BadRequestException(new [] {
new RequestError("bigItem", "inventory.bigItem.revision.error.invalid"),
});
}
if (Revision > 9223372036854775805) {
throw new Gs2.Core.Exception.BadRequestException(new [] {
new RequestError("bigItem", "inventory.bigItem.revision.error.invalid"),
});
}
}
}
public object Clone() {
return new BigItem {
ItemId = ItemId,
UserId = UserId,
ItemName = ItemName,
Count = Count,
CreatedAt = CreatedAt,
UpdatedAt = UpdatedAt,
Revision = Revision,
};
}
}
}