123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207 |
- using MediaBrowser.Common.Net;
- using MediaBrowser.IsoMounter;
- using MediaBrowser.Model.Logging;
- using MediaBrowser.Server.Mono.Networking;
- using MediaBrowser.Server.Startup.Common;
- using Mono.Unix.Native;
- using System;
- using System.Collections.Generic;
- using System.Reflection;
- using System.Text.RegularExpressions;
- namespace MediaBrowser.Server.Mono.Native
- {
- public abstract class BaseMonoApp : INativeApp
- {
- protected StartupOptions StartupOptions { get; private set; }
- protected BaseMonoApp(StartupOptions startupOptions)
- {
- StartupOptions = startupOptions;
- }
- /// <summary>
- /// Shutdowns this instance.
- /// </summary>
- public abstract void Shutdown();
- /// <summary>
- /// Restarts this instance.
- /// </summary>
- public virtual void Restart(StartupOptions startupOptions)
- {
- throw new NotImplementedException();
- }
- /// <summary>
- /// Determines whether this instance [can self restart].
- /// </summary>
- /// <returns><c>true</c> if this instance [can self restart]; otherwise, <c>false</c>.</returns>
- public virtual bool CanSelfRestart
- {
- get
- {
- return false;
- }
- }
- /// <summary>
- /// Gets a value indicating whether this instance can self update.
- /// </summary>
- /// <value><c>true</c> if this instance can self update; otherwise, <c>false</c>.</value>
- public bool CanSelfUpdate
- {
- get
- {
- return false;
- }
- }
- public bool SupportsAutoRunAtStartup
- {
- get { return false; }
- }
- public void PreventSystemStandby()
- {
- }
- public List<Assembly> GetAssembliesWithParts()
- {
- var list = new List<Assembly>();
- if (Environment.OperatingSystem == Startup.Common.OperatingSystem.Linux)
- {
- list.AddRange(GetLinuxAssemblies());
- }
- list.Add(GetType().Assembly);
- return list;
- }
- private IEnumerable<Assembly> GetLinuxAssemblies()
- {
- var list = new List<Assembly>();
- list.Add(typeof(LinuxIsoManager).Assembly);
- return list;
- }
- public void AuthorizeServer(int udpPort, int httpServerPort, int httpsPort, string tempDirectory)
- {
- }
- private NativeEnvironment _nativeEnvironment;
- public NativeEnvironment Environment
- {
- get { return _nativeEnvironment ?? (_nativeEnvironment = GetEnvironmentInfo()); }
- }
- public bool SupportsRunningAsService
- {
- get
- {
- return false;
- }
- }
- public bool IsRunningAsService
- {
- get
- {
- return false;
- }
- }
- public bool SupportsLibraryMonitor
- {
- get
- {
- return Environment.OperatingSystem != Startup.Common.OperatingSystem.Osx;
- }
- }
- public void ConfigureAutoRun(bool autorun)
- {
- }
- public INetworkManager CreateNetworkManager(ILogger logger)
- {
- return new NetworkManager(logger);
- }
- private NativeEnvironment GetEnvironmentInfo()
- {
- var info = new NativeEnvironment
- {
- OperatingSystem = Startup.Common.OperatingSystem.Linux
- };
- var uname = GetUnixName();
- var sysName = uname.sysname ?? string.Empty;
- if (string.Equals(sysName, "Darwin", StringComparison.OrdinalIgnoreCase))
- {
- info.OperatingSystem = Startup.Common.OperatingSystem.Osx;
- }
- else if (string.Equals(sysName, "Linux", StringComparison.OrdinalIgnoreCase))
- {
- info.OperatingSystem = Startup.Common.OperatingSystem.Linux;
- }
- else if (string.Equals(sysName, "BSD", StringComparison.OrdinalIgnoreCase))
- {
- info.OperatingSystem = Startup.Common.OperatingSystem.Bsd;
- }
- var archX86 = new Regex("(i|I)[3-6]86");
- if (archX86.IsMatch(uname.machine))
- {
- info.SystemArchitecture = Architecture.X86;
- }
- else if (string.Equals(uname.machine, "x86_64", StringComparison.OrdinalIgnoreCase))
- {
- info.SystemArchitecture = Architecture.X86_X64;
- }
- else if (uname.machine.StartsWith("arm", StringComparison.OrdinalIgnoreCase))
- {
- info.SystemArchitecture = Architecture.Arm;
- }
- info.OperatingSystemVersionString = string.IsNullOrWhiteSpace(sysName) ?
- System.Environment.OSVersion.VersionString :
- sysName;
- return info;
- }
- private Uname _unixName;
- private Uname GetUnixName()
- {
- if (_unixName == null)
- {
- var uname = new Uname();
- Utsname utsname;
- var callResult = Syscall.uname(out utsname);
- if (callResult == 0)
- {
- uname.sysname = utsname.sysname;
- uname.machine = utsname.machine;
- }
- _unixName = uname;
- }
- return _unixName;
- }
- public class Uname
- {
- public string sysname = string.Empty;
- public string machine = string.Empty;
- }
- }
- }
|