using System; using System.Collections.Generic; using UMC.Data; using UMC.Web; using UMC.Web.UI; namespace UMC.Proxy { [Mapping("Proxy", "LogConf", Auth = WebAuthType.Admin, Desc = "服务器日志")] public class SiteLogConfActivity : WebActivity { public override void ProcessActivity(WebRequest request, WebResponse response) { var assConf = Reflection.Configuration("assembly"); var provider = assConf["Log"] ?? Data.Provider.Create("Log", "none"); var model = this.AsyncDialog("Id", akey => { // var form = request.SendValues ?? new WebMeta(); // if (form.ContainsKey("limit") == false) // { // this.Context.Send(new UISectionBuilder(request.Model, request.Command) // .RefreshEvent($"{request.Model}.{request.Command}") // .Builder(), true); // } var ui = UISection.Create(new UITitle("日志组件")); switch (provider.Type) { case "csv": ui.AddCell("日志类型", "文本格式", new UIClick("CHANGE").Send(request.Model, request.Command)); var fui = ui.NewSection(); var fields = provider["field"]; var fs = new List(new string[] { "Address", "Site", "Path", "Username", "Duration", "Time", "Status", "UserAgent", "Account", "Referrer", "Attachment", "Server" }); if (String.IsNullOrEmpty(fields) == false) { foreach (var c in fields.Split(',')) { var k = c.Trim(); if (String.IsNullOrEmpty(k) == false) { if (fs.Exists(r => String.Equals(r, k)) == false) { fs.Add(k); } } } } foreach (var k in fs) { switch (k) { case "Address": fui.AddCell(k, "客户端IP"); break; case "Site": fui.AddCell(k, "应用名称"); break; case "Path": fui.AddCell(k, "请求路径"); break; case "Username": fui.AddCell(k, "所属账户"); break; case "Duration": fui.AddCell(k, "请求耗时"); break; case "Time": fui.AddCell(k, "发生时间"); break; case "Status": fui.AddCell(k, "响应状态"); break; case "UserAgent": fui.AddCell(k, "终端设备"); break; case "Account": fui.AddCell(k, "应用账户"); break; case "Referrer": fui.AddCell(k, "所在页面"); break; case "Attachment": fui.AddCell(k, "下载文件"); break; case "Server": fui.AddCell(k, "服务器名"); break; default: fui.AddCell(k, new UIClick(k).Send(request.Model, request.Command)); break; } } break; case "json": ui.AddCell("日志类型", "Json格式", new UIClick("CHANGE").Send(request.Model, request.Command)); ui.NewSection().AddCell("发送网址", provider["url"]).AddCell("发送方式", provider["method"]); break; default: ui.AddCell("日志类型", "未启用", new UIClick("CHANGE").Send(request.Model, request.Command)); UIDesc desc = new UIDesc("日志记录未启用"); desc.Desc("{icon}\n{desc}").Put("icon", "\uf24a"); desc.Style.Align(1).Color(0xaaa).Padding(20, 20).BgColor(0xfff).Size(12).Name("icon", new UIStyle().Font("wdk").Size(60)); ui.NewSection().Add(desc); break; } ui.UIFootBar = new UIFootBar() { IsFixed = true }; ui.UIFootBar.AddText(new UIEventText("新增字段").Click(new UIClick("ADD").Send(request.Model, request.Command)), new UIEventText("重新加载").Click(new UIClick("LoadConf").Send(request.Model, request.Command)).Style(new UIStyle().BgColor())); // response.Redirect(ui); ui.SendTo(this.Context, true, $"{request.Model}.{request.Command}"); // return this.DialogValue("none"); }); switch (model) { case "JSON": var Domains = this.AsyncDialog("JSON", r => { var fm = new UIFormDialog() { Title = "JSON日志格式" }; fm.AddText("发送网址", "url", provider["url"]); fm.AddRadio("发送方式", "method").Put("POST", "POST", provider["method"] == "POST").Put("PUT", "PUT", provider["method"] == "PUT"); fm.Submit("确认", $"{request.Model}.{request.Command}"); return fm; }); var provider2 = Data.Provider.Create("Log", "json"); provider2.Attributes.Add(provider.Attributes); provider2.Attributes["method"] = Domains["method"]; provider2.Attributes["url"] = new Uri(Domains["url"]).AbsoluteUri; assConf.Add(provider2); UMC.Data.Reflection.Configuration("assembly", assConf); this.Context.Send($"{request.Model}.{request.Command}", true); break; case "ADD": if (String.Equals(provider.Type, "csv") == false) { this.Prompt("不是文本格式不支持添加字段"); } var aField = this.AsyncDialog("Field", r => { var fm = new UIFormDialog() { Title = "新增文本日志字段" }; fm.AddText("字段", "field", provider["url"]); fm.Submit("确认", $"{request.Model}.{request.Command}"); return fm; })["field"]; { var fields = provider["field"]; var fs = new List(); if (String.IsNullOrEmpty(fields) == false) { foreach (var c in fields.Split(',')) { var k = c.Trim(); if (String.IsNullOrEmpty(k) == false) { if (fs.Exists(r => String.Equals(r, k)) == false) { fs.Add(k); } } } } fs.Add(aField); provider.Attributes["field"] = String.Join(",", fs.ToArray()); assConf.Add(provider); UMC.Data.Reflection.Configuration("assembly", assConf); this.Context.Send($"{request.Model}.{request.Command}", true); } break; case "CHANGE": var changeType = this.AsyncDialog("Change", r => { var uis = new UISheetDialog(); switch (provider.Type) { case "json": uis.Put("文本格式", "csv").Put("关闭日志", "none"); break; case "csv": uis.Put(new UIClick("JSON") { Text = "JSON格式" }.Send(request.Model, request.Command)).Put("关闭日志", "none"); break; default: case "none": uis.Put(new UIClick("JSON") { Text = "JSON格式" }.Send(request.Model, request.Command)).Put("文本格式", "csv"); break; } return uis; }); var provider3 = Data.Provider.Create("Log", changeType); provider3.Attributes.Add(provider.Attributes); assConf.Add(provider3); UMC.Data.Reflection.Configuration("assembly", assConf); this.Context.Send($"{request.Model}.{request.Command}", true); break; default: { var fields = provider["field"]; var fs = new List(); if (String.IsNullOrEmpty(fields) == false) { foreach (var c in fields.Split(',')) { var k = c.Trim(); if (String.IsNullOrEmpty(k) == false) { if (fs.Exists(r => String.Equals(r, k)) == false) { fs.Add(k); } } } } fs.Remove(model); provider.Attributes["field"] = String.Join(",", fs.ToArray()); assConf.Add(provider);//["Log"] = provider; UMC.Data.Reflection.Configuration("assembly", assConf); this.Context.Send($"{request.Model}.{request.Command}", true); } break; case "LoadConf": UMC.Proxy.LogSetting.Instance().LoadConf(); this.Prompt("已经从新加载日志组件参数"); break; } } } }