using learun.iapplication;
using Microsoft.AspNetCore.Mvc;
using System.Threading.Tasks;
namespace EC.Web.Areas.LR_SystemModule.Controllers
{
///
/// 版 本 EasyCode EC管理后台
/// Copyright (c) 2019-present EC管理有限公司
/// 创建人:tobin
/// 日 期:2019.10.22
/// 描 述:数据库连接控制器
///
[Area("LR_SystemModule")]
public class DatabaseLinkController : MvcControllerBase
{
private readonly DatabaseLinkIBLL _databaseLinkIBLL;
public DatabaseLinkController(DatabaseLinkIBLL databaseLinkIBLL)
{
_databaseLinkIBLL = databaseLinkIBLL;
}
#region 获取视图
///
/// 管理页面
///
///
[HttpGet]
public IActionResult Index()
{
return View();
}
///
/// 表单页面
///
///
[HttpGet]
public IActionResult Form()
{
return View();
}
#endregion 获取视图
#region 获取数据
///
/// 获取数据列表
///
/// 关键字
///
[HttpGet]
[AjaxOnly]
public async Task GetList(string keyword)
{
var data = await _databaseLinkIBLL.GetListByNoConnection(keyword);
return Success(data);
}
///
/// 获取树形数据
///
///
[HttpGet]
[AjaxOnly]
public async Task GetTreeList()
{
var data = await _databaseLinkIBLL.GetTreeList();
return Success(data);
}
#endregion 获取数据
#region 提交数据
///
/// 保存表单数据
///
/// 主键
/// 实体
///
[HttpPost]
[AjaxOnly]
public async Task SaveForm(string keyValue, DatabaseLinkEntity entity)
{
bool res = await _databaseLinkIBLL.SaveEntity(keyValue, entity);
if (res)
{
return SuccessInfo("保存成功!");
}
else
{
return Fail("保存失败,连接串信息有误!");
}
}
///
/// 删除表单数据
///
/// 主键
///
[HttpPost]
[AjaxOnly]
public async Task DeleteForm(string keyValue)
{
await _databaseLinkIBLL.Delete(keyValue);
return SuccessInfo("删除成功!");
}
#endregion 提交数据
#region 扩展方法
///
/// 测试连接串是否正确
///
/// 连接串
/// 数据库类型
/// 主键
///
[HttpPost]
[AjaxOnly]
public async Task TestConnection(string connection, string dbType, string keyValue)
{
var res = await _databaseLinkIBLL.TestConnection(connection, dbType, keyValue);
if (res == "success")
{
return SuccessInfo("连接成功!");
}
else
{
return Fail(res);
}
}
#endregion 扩展方法
}
}