123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101 |
- #nullable disable
- #pragma warning disable CS1591
- using System;
- using System.Linq;
- using System.Xml.Serialization;
- namespace MediaBrowser.Model.Dlna
- {
- public class ContainerProfile
- {
- [XmlAttribute("type")]
- public DlnaProfileType Type { get; set; }
- public ProfileCondition[] Conditions { get; set; }
- [XmlAttribute("container")]
- public string Container { get; set; }
- public ContainerProfile()
- {
- Conditions = Array.Empty<ProfileCondition>();
- }
- public string[] GetContainers()
- {
- return SplitValue(Container);
- }
- public static string[] SplitValue(string value)
- {
- if (string.IsNullOrEmpty(value))
- {
- return Array.Empty<string>();
- }
- return value.Split(new[] { ',' }, StringSplitOptions.RemoveEmptyEntries);
- }
- public bool ContainsContainer(string container)
- {
- var containers = GetContainers();
- return ContainsContainer(containers, container);
- }
- public static bool ContainsContainer(string profileContainers, string inputContainer)
- {
- var isNegativeList = false;
- if (profileContainers != null && profileContainers.StartsWith("-", StringComparison.Ordinal))
- {
- isNegativeList = true;
- profileContainers = profileContainers.Substring(1);
- }
- return ContainsContainer(SplitValue(profileContainers), isNegativeList, inputContainer);
- }
- public static bool ContainsContainer(string[] profileContainers, string inputContainer)
- {
- return ContainsContainer(profileContainers, false, inputContainer);
- }
- public static bool ContainsContainer(string[] profileContainers, bool isNegativeList, string inputContainer)
- {
- if (profileContainers.Length == 0)
- {
- return true;
- }
- if (isNegativeList)
- {
- var allInputContainers = SplitValue(inputContainer);
- foreach (var container in allInputContainers)
- {
- if (profileContainers.Contains(container, StringComparer.OrdinalIgnoreCase))
- {
- return false;
- }
- }
- return true;
- }
- else
- {
- var allInputContainers = SplitValue(inputContainer);
- foreach (var container in allInputContainers)
- {
- if (profileContainers.Contains(container, StringComparer.OrdinalIgnoreCase))
- {
- return true;
- }
- }
- return false;
- }
- }
- }
- }
|