feat(apiv2): v2 json models
This commit is contained in:
		@@ -82,7 +82,7 @@ namespace PluralKit.Core
 | 
			
		||||
 | 
			
		||||
#nullable disable
 | 
			
		||||
 | 
			
		||||
        public static MemberPatch FromJSON(JObject o)
 | 
			
		||||
        public static MemberPatch FromJSON(JObject o, APIVersion v = APIVersion.V1)
 | 
			
		||||
        {
 | 
			
		||||
            var patch = new MemberPatch();
 | 
			
		||||
 | 
			
		||||
@@ -108,38 +108,82 @@ namespace PluralKit.Core
 | 
			
		||||
            if (o.ContainsKey("description")) patch.Description = o.Value<string>("description").NullIfEmpty();
 | 
			
		||||
            if (o.ContainsKey("keep_proxy")) patch.KeepProxy = o.Value<bool>("keep_proxy");
 | 
			
		||||
 | 
			
		||||
            // legacy: used in old export files and APIv1
 | 
			
		||||
            if (o.ContainsKey("prefix") || o.ContainsKey("suffix") && !o.ContainsKey("proxy_tags"))
 | 
			
		||||
                patch.ProxyTags = new[] { new ProxyTag(o.Value<string>("prefix"), o.Value<string>("suffix")) };
 | 
			
		||||
            else if (o.ContainsKey("proxy_tags"))
 | 
			
		||||
                patch.ProxyTags = o.Value<JArray>("proxy_tags")
 | 
			
		||||
                    .OfType<JObject>().Select(o => new ProxyTag(o.Value<string>("prefix"), o.Value<string>("suffix")))
 | 
			
		||||
                    .Where(p => p.Valid)
 | 
			
		||||
                    .ToArray();
 | 
			
		||||
 | 
			
		||||
            if (o.ContainsKey("privacy")) //TODO: Deprecate this completely in api v2
 | 
			
		||||
            switch (v)
 | 
			
		||||
            {
 | 
			
		||||
                var plevel = o.ParsePrivacy("privacy");
 | 
			
		||||
                case APIVersion.V1:
 | 
			
		||||
                    {
 | 
			
		||||
                        // legacy: used in old export files and APIv1
 | 
			
		||||
                        if (o.ContainsKey("prefix") || o.ContainsKey("suffix") && !o.ContainsKey("proxy_tags"))
 | 
			
		||||
                            patch.ProxyTags = new[] { new ProxyTag(o.Value<string>("prefix"), o.Value<string>("suffix")) };
 | 
			
		||||
                        else if (o.ContainsKey("proxy_tags"))
 | 
			
		||||
                            patch.ProxyTags = o.Value<JArray>("proxy_tags")
 | 
			
		||||
                                .OfType<JObject>().Select(o => new ProxyTag(o.Value<string>("prefix"), o.Value<string>("suffix")))
 | 
			
		||||
                                .Where(p => p.Valid)
 | 
			
		||||
                                .ToArray();
 | 
			
		||||
 | 
			
		||||
                patch.Visibility = plevel;
 | 
			
		||||
                patch.NamePrivacy = plevel;
 | 
			
		||||
                patch.AvatarPrivacy = plevel;
 | 
			
		||||
                patch.DescriptionPrivacy = plevel;
 | 
			
		||||
                patch.BirthdayPrivacy = plevel;
 | 
			
		||||
                patch.PronounPrivacy = plevel;
 | 
			
		||||
                // member.ColorPrivacy = plevel;
 | 
			
		||||
                patch.MetadataPrivacy = plevel;
 | 
			
		||||
            }
 | 
			
		||||
            else
 | 
			
		||||
            {
 | 
			
		||||
                if (o.ContainsKey("visibility")) patch.Visibility = o.ParsePrivacy("visibility");
 | 
			
		||||
                if (o.ContainsKey("name_privacy")) patch.NamePrivacy = o.ParsePrivacy("name_privacy");
 | 
			
		||||
                if (o.ContainsKey("description_privacy")) patch.DescriptionPrivacy = o.ParsePrivacy("description_privacy");
 | 
			
		||||
                if (o.ContainsKey("avatar_privacy")) patch.AvatarPrivacy = o.ParsePrivacy("avatar_privacy");
 | 
			
		||||
                if (o.ContainsKey("birthday_privacy")) patch.BirthdayPrivacy = o.ParsePrivacy("birthday_privacy");
 | 
			
		||||
                if (o.ContainsKey("pronoun_privacy")) patch.PronounPrivacy = o.ParsePrivacy("pronoun_privacy");
 | 
			
		||||
                // if (o.ContainsKey("color_privacy")) member.ColorPrivacy = o.ParsePrivacy("member");
 | 
			
		||||
                if (o.ContainsKey("metadata_privacy")) patch.MetadataPrivacy = o.ParsePrivacy("metadata_privacy");
 | 
			
		||||
                        if (o.ContainsKey("privacy"))
 | 
			
		||||
                        {
 | 
			
		||||
                            var plevel = o.ParsePrivacy("privacy");
 | 
			
		||||
 | 
			
		||||
                            patch.Visibility = plevel;
 | 
			
		||||
                            patch.NamePrivacy = plevel;
 | 
			
		||||
                            patch.AvatarPrivacy = plevel;
 | 
			
		||||
                            patch.DescriptionPrivacy = plevel;
 | 
			
		||||
                            patch.BirthdayPrivacy = plevel;
 | 
			
		||||
                            patch.PronounPrivacy = plevel;
 | 
			
		||||
                            // member.ColorPrivacy = plevel;
 | 
			
		||||
                            patch.MetadataPrivacy = plevel;
 | 
			
		||||
                        }
 | 
			
		||||
                        else
 | 
			
		||||
                        {
 | 
			
		||||
                            if (o.ContainsKey("visibility")) patch.Visibility = o.ParsePrivacy("visibility");
 | 
			
		||||
                            if (o.ContainsKey("name_privacy")) patch.NamePrivacy = o.ParsePrivacy("name_privacy");
 | 
			
		||||
                            if (o.ContainsKey("description_privacy")) patch.DescriptionPrivacy = o.ParsePrivacy("description_privacy");
 | 
			
		||||
                            if (o.ContainsKey("avatar_privacy")) patch.AvatarPrivacy = o.ParsePrivacy("avatar_privacy");
 | 
			
		||||
                            if (o.ContainsKey("birthday_privacy")) patch.BirthdayPrivacy = o.ParsePrivacy("birthday_privacy");
 | 
			
		||||
                            if (o.ContainsKey("pronoun_privacy")) patch.PronounPrivacy = o.ParsePrivacy("pronoun_privacy");
 | 
			
		||||
                            // if (o.ContainsKey("color_privacy")) member.ColorPrivacy = o.ParsePrivacy("member");
 | 
			
		||||
                            if (o.ContainsKey("metadata_privacy")) patch.MetadataPrivacy = o.ParsePrivacy("metadata_privacy");
 | 
			
		||||
                        }
 | 
			
		||||
                        break;
 | 
			
		||||
                    }
 | 
			
		||||
                case APIVersion.V2:
 | 
			
		||||
                    {
 | 
			
		||||
 | 
			
		||||
                        if (o.ContainsKey("proxy_tags"))
 | 
			
		||||
                            patch.ProxyTags = o.Value<JArray>("proxy_tags")
 | 
			
		||||
                                .OfType<JObject>().Select(o => new ProxyTag(o.Value<string>("prefix"), o.Value<string>("suffix")))
 | 
			
		||||
                                .Where(p => p.Valid)
 | 
			
		||||
                                .ToArray();
 | 
			
		||||
 | 
			
		||||
                        if (o.ContainsKey("privacy") && o["privacy"].Type != JTokenType.Null)
 | 
			
		||||
                        {
 | 
			
		||||
                            var privacy = o.Value<JObject>("privacy");
 | 
			
		||||
 | 
			
		||||
                            if (privacy.ContainsKey("visibility"))
 | 
			
		||||
                                patch.Visibility = privacy.ParsePrivacy("visibility");
 | 
			
		||||
 | 
			
		||||
                            if (privacy.ContainsKey("name_privacy"))
 | 
			
		||||
                                patch.NamePrivacy = privacy.ParsePrivacy("name_privacy");
 | 
			
		||||
 | 
			
		||||
                            if (privacy.ContainsKey("description_privacy"))
 | 
			
		||||
                                patch.DescriptionPrivacy = privacy.ParsePrivacy("description_privacy");
 | 
			
		||||
 | 
			
		||||
                            if (privacy.ContainsKey("avatar_privacy"))
 | 
			
		||||
                                patch.AvatarPrivacy = privacy.ParsePrivacy("avatar_privacy");
 | 
			
		||||
 | 
			
		||||
                            if (privacy.ContainsKey("birthday_privacy"))
 | 
			
		||||
                                patch.BirthdayPrivacy = privacy.ParsePrivacy("birthday_privacy");
 | 
			
		||||
 | 
			
		||||
                            if (privacy.ContainsKey("pronoun_privacy"))
 | 
			
		||||
                                patch.PronounPrivacy = privacy.ParsePrivacy("pronoun_privacy");
 | 
			
		||||
 | 
			
		||||
                            if (privacy.ContainsKey("metadata_privacy"))
 | 
			
		||||
                                patch.MetadataPrivacy = privacy.ParsePrivacy("metadata_privacy");
 | 
			
		||||
                        }
 | 
			
		||||
 | 
			
		||||
                        break;
 | 
			
		||||
                    }
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            return patch;
 | 
			
		||||
 
 | 
			
		||||
@@ -72,7 +72,9 @@ namespace PluralKit.Core
 | 
			
		||||
                throw new ValidationError("avatar_url");
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        public static SystemPatch FromJSON(JObject o)
 | 
			
		||||
#nullable disable
 | 
			
		||||
 | 
			
		||||
        public static SystemPatch FromJSON(JObject o, APIVersion v = APIVersion.V1)
 | 
			
		||||
        {
 | 
			
		||||
            var patch = new SystemPatch();
 | 
			
		||||
            if (o.ContainsKey("name")) patch.Name = o.Value<string>("name").NullIfEmpty();
 | 
			
		||||
@@ -81,16 +83,44 @@ namespace PluralKit.Core
 | 
			
		||||
            if (o.ContainsKey("avatar_url")) patch.AvatarUrl = o.Value<string>("avatar_url").NullIfEmpty();
 | 
			
		||||
            if (o.ContainsKey("banner")) patch.BannerImage = o.Value<string>("banner").NullIfEmpty();
 | 
			
		||||
            if (o.ContainsKey("color")) patch.Color = o.Value<string>("color").NullIfEmpty();
 | 
			
		||||
            if (o.ContainsKey("timezone")) patch.UiTz = o.Value<string>("tz") ?? "UTC";
 | 
			
		||||
            if (o.ContainsKey("timezone")) patch.UiTz = o.Value<string>("timezone") ?? "UTC";
 | 
			
		||||
 | 
			
		||||
            // legacy: APIv1 uses "tz" instead of "timezone"
 | 
			
		||||
            // todo: remove in APIv2
 | 
			
		||||
            if (o.ContainsKey("tz")) patch.UiTz = o.Value<string>("tz") ?? "UTC";
 | 
			
		||||
            switch (v)
 | 
			
		||||
            {
 | 
			
		||||
                case APIVersion.V1:
 | 
			
		||||
                    {
 | 
			
		||||
                        if (o.ContainsKey("tz")) patch.UiTz = o.Value<string>("tz") ?? "UTC";
 | 
			
		||||
 | 
			
		||||
                        if (o.ContainsKey("description_privacy")) patch.DescriptionPrivacy = o.ParsePrivacy("description_privacy");
 | 
			
		||||
                        if (o.ContainsKey("member_list_privacy")) patch.MemberListPrivacy = o.ParsePrivacy("member_list_privacy");
 | 
			
		||||
                        if (o.ContainsKey("front_privacy")) patch.FrontPrivacy = o.ParsePrivacy("front_privacy");
 | 
			
		||||
                        if (o.ContainsKey("front_history_privacy")) patch.FrontHistoryPrivacy = o.ParsePrivacy("front_history_privacy");
 | 
			
		||||
 | 
			
		||||
                        break;
 | 
			
		||||
                    }
 | 
			
		||||
                case APIVersion.V2:
 | 
			
		||||
                    {
 | 
			
		||||
                        if (o.ContainsKey("privacy") && o["privacy"].Type != JTokenType.Null)
 | 
			
		||||
                        {
 | 
			
		||||
                            var privacy = o.Value<JObject>("privacy");
 | 
			
		||||
 | 
			
		||||
                            if (privacy.ContainsKey("description_privacy"))
 | 
			
		||||
                                patch.DescriptionPrivacy = privacy.ParsePrivacy("description_privacy");
 | 
			
		||||
 | 
			
		||||
                            if (privacy.ContainsKey("member_list_privacy"))
 | 
			
		||||
                                patch.DescriptionPrivacy = privacy.ParsePrivacy("member_list_privacy");
 | 
			
		||||
 | 
			
		||||
                            if (privacy.ContainsKey("front_privacy"))
 | 
			
		||||
                                patch.DescriptionPrivacy = privacy.ParsePrivacy("front_privacy");
 | 
			
		||||
 | 
			
		||||
                            if (privacy.ContainsKey("front_history_privacy"))
 | 
			
		||||
                                patch.DescriptionPrivacy = privacy.ParsePrivacy("front_history_privacy");
 | 
			
		||||
                        }
 | 
			
		||||
 | 
			
		||||
                        break;
 | 
			
		||||
                    }
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            if (o.ContainsKey("description_privacy")) patch.DescriptionPrivacy = o.ParsePrivacy("description_privacy");
 | 
			
		||||
            if (o.ContainsKey("member_list_privacy")) patch.MemberListPrivacy = o.ParsePrivacy("member_list_privacy");
 | 
			
		||||
            if (o.ContainsKey("front_privacy")) patch.FrontPrivacy = o.ParsePrivacy("front_privacy");
 | 
			
		||||
            if (o.ContainsKey("front_history_privacy")) patch.FrontHistoryPrivacy = o.ParsePrivacy("front_history_privacy");
 | 
			
		||||
            return patch;
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user