169 lines
5.4 KiB
C#
169 lines
5.4 KiB
C#
using Common.DbExtends.Extends;
|
|
using Common.DbExtends.Others;
|
|
using Common.Models.Enums;
|
|
using Common.Models.UnqTables;
|
|
using Common.Requests.Lianmengs;
|
|
using Server.MyClass.Views;
|
|
using SqlSugar;
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using System.Text;
|
|
using System.Threading.Tasks;
|
|
using System.Web.Http;
|
|
|
|
namespace Server.Controllers.AccountManagement
|
|
{
|
|
public partial class LianmengController
|
|
{
|
|
#region 抖音代码
|
|
/// <summary>
|
|
/// 抖音- 查询
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
[HttpPost, ErrorFilter]
|
|
public WebResult GetDouyinMedias()
|
|
{
|
|
try
|
|
{
|
|
var pageSize = GetInt("PageSize", true);
|
|
var index = GetInt("PageIndex", true);
|
|
|
|
var LianmengId = GetInt("LianmengId");
|
|
|
|
var KeyWord = GetString("KeyWord");
|
|
|
|
var exp = Expressionable.Create<DyMedia>();
|
|
if (LianmengId > 0)
|
|
{
|
|
exp.And(f => f.LianmengId == LianmengId);
|
|
}
|
|
|
|
if (!string.IsNullOrEmpty(KeyWord))
|
|
{
|
|
exp.And(f => f.Pid.Contains(KeyWord) || f.AdzoneName.Contains(KeyWord) || f.Remark.Contains(KeyWord));
|
|
}
|
|
|
|
exp.And(f => f.IsDelete == false);
|
|
var tNumber = 0;
|
|
|
|
var DataList = Db.Queryable<DyMedia>()
|
|
.LeftJoin<Lianmeng>((f, r) => f.LianmengId == r.Id)
|
|
.Where(exp.ToExpression())
|
|
.Select((f, r) => new DyMediaShow
|
|
{
|
|
Id = f.Id,
|
|
LianmengId = f.LianmengId,
|
|
LianmengNick = r.Nickname,
|
|
Pid = f.Pid,
|
|
AdzoneName = f.AdzoneName,
|
|
MediaType = f.MediaType,
|
|
MediaName = f.MediaName,
|
|
Remark = f.Remark
|
|
|
|
})
|
|
.ToPageList(index, pageSize, ref tNumber);
|
|
|
|
//计算使用人数
|
|
foreach (var item in DataList)
|
|
{
|
|
item.UseCnt = Db.Queryable<Robot>().Count(p => p.TbMediaId1 == item.Id || p.TbMediaId2 == item.Id);
|
|
}
|
|
|
|
return PutData(new PageResult<DyMediaShow>(DataList, tNumber, pageSize, index));
|
|
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
return PutData(ex);
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// 抖音-新增
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
[HttpPost, ErrorFilter]
|
|
public WebResult AddDouyinMedia()
|
|
{
|
|
var LianmengId = GetInt("LianmengId", true);
|
|
var AdzoneName = GetString("AdzoneName", true);
|
|
var MediaName = GetString("MediaName", true);
|
|
var MediaType = GetEnum<DouyinMediaType>("MediaType", true);
|
|
var Remark = GetString("Remark", false);
|
|
var lm = Db.GetLianmeng(LianmengId);
|
|
DouyinRequest req = new DouyinRequest(lm);
|
|
var Pid = req.CreateDouyinPidAdzone(AdzoneName, MediaName, MediaType, true);
|
|
var media = new DyMedia()
|
|
{
|
|
AdzoneName = AdzoneName,
|
|
MediaName = MediaName,
|
|
IsDelete = false,
|
|
LianmengId = LianmengId,
|
|
MediaType = MediaType,
|
|
Pid = Pid,
|
|
Remark = Remark,
|
|
UpdateTime = 0
|
|
};
|
|
Db.Save(media);
|
|
return PutData(media);
|
|
}
|
|
|
|
/// <summary>
|
|
/// 抖音-修改推广位名称
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
[HttpPost, ErrorFilter]
|
|
public WebResult UpdDouyinAdzoneName()
|
|
{
|
|
var id = GetInt("MediaId", true);
|
|
var dyMedia = Db.GetDyMedia(id);
|
|
if (dyMedia == null) return PutData("编辑失败,未找到该推广位信息");
|
|
|
|
var dyLianmeng = Db.GetLianmeng(dyMedia.LianmengId);
|
|
if (dyLianmeng == null) return PutData("编辑失败,未找到该联盟信息");
|
|
|
|
|
|
var AdzoneName = GetString("AdzoneName", true);
|
|
|
|
DouyinRequest req = new DouyinRequest(dyLianmeng, dyMedia);
|
|
|
|
|
|
req.UpdateDouyinPidAdzone(dyMedia.Pid, AdzoneName, true);
|
|
|
|
dyMedia.AdzoneName = AdzoneName;
|
|
var remark = GetString("Remark");
|
|
if (!string.IsNullOrEmpty(remark))
|
|
dyMedia.Remark = remark;
|
|
Db.Save(dyMedia);
|
|
return PutSuccess;
|
|
|
|
}
|
|
|
|
/// <summary>
|
|
/// 抖音 - 删除推广位
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
public WebResult DelDouyinMedia()
|
|
{
|
|
var lianmengId = GetInt("LianmengId", true);
|
|
var dyPids = GetStringList("DyPids", true);
|
|
if (dyPids != null && dyPids.Count > 0)
|
|
{
|
|
//去抖音API执行真实删除
|
|
var dyLianmeng = Db.GetLianmeng(lianmengId);
|
|
if (dyLianmeng != null)
|
|
{
|
|
var req = new DouyinRequest(dyLianmeng);
|
|
req.DeleteDouyinPidAdzone(dyPids.ToArray(), false);
|
|
}
|
|
|
|
var rst =Db.Deleteable<DyMedia>().Where(f => dyPids.Contains(f.Pid) && f.LianmengId == lianmengId).ExecuteCommand();
|
|
DataCache.RemoveByPattern(@"cache_dymedia_[\d]+");
|
|
}
|
|
return PutSuccess;
|
|
}
|
|
#endregion
|
|
}
|
|
}
|