1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889 |
- using MediaBrowser.Model.Extensions;
- using System;
- using System.Collections.Generic;
- using System.Linq;
- namespace MediaBrowser.Model.ApiClient
- {
- public class ServerCredentials
- {
- public List<ServerInfo> Servers { get; set; }
- public string ConnectUserId { get; set; }
- public string ConnectAccessToken { get; set; }
- public ServerCredentials()
- {
- Servers = new List<ServerInfo>();
- }
- public void AddOrUpdateServer(ServerInfo server)
- {
- if (server == null)
- {
- throw new ArgumentNullException("server");
- }
- var list = Servers.ToList();
- var index = FindIndex(list, server.Id);
- if (index != -1)
- {
- var existing = list[index];
- // Merge the data
- existing.DateLastAccessed = new[] { existing.DateLastAccessed, server.DateLastAccessed }.Max();
- if (!string.IsNullOrEmpty(server.AccessToken))
- {
- existing.AccessToken = server.AccessToken;
- existing.UserId = server.UserId;
- }
- if (!string.IsNullOrEmpty(server.ExchangeToken))
- {
- existing.ExchangeToken = server.ExchangeToken;
- }
- if (!string.IsNullOrEmpty(server.RemoteAddress))
- {
- existing.RemoteAddress = server.RemoteAddress;
- }
- if (!string.IsNullOrEmpty(server.LocalAddress))
- {
- existing.LocalAddress = server.LocalAddress;
- }
- if (!string.IsNullOrEmpty(server.Name))
- {
- existing.Name = server.Name;
- }
- if (server.WakeOnLanInfos != null && server.WakeOnLanInfos.Count > 0)
- {
- existing.WakeOnLanInfos = server.WakeOnLanInfos.ToList();
- }
- }
- else
- {
- list.Add(server);
- }
- Servers = list;
- }
- private int FindIndex(List<ServerInfo> servers, string id)
- {
- var index = 0;
- foreach (var server in servers)
- {
- if (StringHelper.Equals(id, server.Id))
- {
- return index;
- }
- index++;
- }
- return -1;
- }
- }
- }
|