private void InstallModpack() { var modpackinfo = (ModpackInfo)TCAdmin.SDK.Misc.ObjectXml.XmlToObject(this.Arguments.Arguments, typeof(ModpackInfo)); var service = new TCAdmin.GameHosting.SDK.Objects.Service(modpackinfo.ServiceId); var original_status = service.Status; try { if (original_status.ServiceStatus == TCAdmin.Interfaces.Server.ServiceStatus.Running) { service.Stop("Modpack installation"); } var install_data = System.IO.Path.Combine(service.RootDirectory, String.Format("Modpack-{0}.data", modpackinfo.ModpackId)); if (System.IO.File.Exists(install_data)) { UninstallModpack(); } var server = new TCAdmin.GameHosting.SDK.Objects.Server(service.ServerId); var provider = new TCAdminCustomMods.Providers.MinecraftModpacksProvider(); MinecraftModpacksBrowser genericMod = (MinecraftModpacksBrowser)provider.GetMod(modpackinfo.ModpackId.ToString(), Providers.ModSearchType.Id); var filepath = "Shared/bin-extensions/MinecraftModpack-Install-Script.txt"; var script = string.Empty; var utility = service.GetScriptUtility(); utility.ScriptEngineManager.AddVariable("Script.WorkingDirectory", service.RootDirectory); utility.AddObject("ThisModpackInfo", modpackinfo); utility.AddObject("ThisApiInfo", genericMod); utility.AddObject("ThisTaskStep", this); if (System.IO.File.Exists(filepath)) { script = System.IO.File.ReadAllText(filepath); } else { script = PythonScripts.MinecraftModpack_Install_Script; } utility.ScriptEngineManager.SetScript("ipy", script, null); DeleteModpackCmdLines(service); var createdfiles = new List <string>(); using (var filewatcher = new System.IO.FileSystemWatcher(service.RootDirectory, "*")) { filewatcher.InternalBufferSize = 32768; filewatcher.IncludeSubdirectories = true; filewatcher.Created += (object sender, System.IO.FileSystemEventArgs e) => { createdfiles.Add(e.FullPath); }; filewatcher.EnableRaisingEvents = true; utility.ScriptEngineManager.Execute(); provider.PostInstallMod(service, genericMod); } createdfiles.Reverse(); using (var file = System.IO.File.OpenWrite(install_data)) { using (var writer = new System.IO.StreamWriter(file)) { var i = 0; foreach (var createdfile in createdfiles) { i += 1; if (i > 1) { writer.Write("\n"); } writer.Write(TCAdmin.SDK.Misc.Strings.ReplaceCaseInsensitive(createdfile, service.RootDirectory, string.Empty)); } } } //remove current version if it exists foreach (var installed in provider.GetInstalledPlugins(service)) { var packid = int.Parse(installed.Split(':')[0].Replace("MCMP", string.Empty)); if (packid == modpackinfo.ModpackId) { var verid = int.Parse(installed.Split(':')[1]); provider.RemoveInstalledPlugin(service, packid, verid); } } provider.AddInstalledPlugin(service, modpackinfo.ModpackId, modpackinfo.VersionId); //Repair permissions this.WriteLog("Setting file permissions..."); var usercfgfile = string.Format("Services/{0}/User.cfg", service.ServiceId); if (System.IO.File.Exists(usercfgfile)) { var usercfg = new TCAdmin.SDK.Database.XmlField(); usercfg.LoadFromFile(usercfgfile); switch (server.OperatingSystem) { case TCAdmin.SDK.Objects.OperatingSystem.Linux: TCAdmin.SDK.Misc.Linux.SetDirectoryOwner(service.RootDirectory, usercfg["Service.User"].ToString(), true); break; case TCAdmin.SDK.Objects.OperatingSystem.Windows: server.GameHostingUtilitiesService.ConfigureGameAccountPermissions(usercfg["Service.User"].ToString(), service.RootDirectory); break; default: throw new NotImplementedException(server.OperatingSystem.ToString()); } } service.Configure(); var responsedata = new TCAdmin.SDK.Database.XmlField(); responsedata.SetValue("Task.RedirectUrl", modpackinfo.RedirectUrl); responsedata.SetValue("Task.RedirectUrlMvc", modpackinfo.RedirectUrl); this.SetResponse(responsedata.ToString()); this.UpdateProgress(100); } finally { if (original_status.ServiceStatus == TCAdmin.Interfaces.Server.ServiceStatus.Running) { service.Start("Modpack installation"); } } }