合并最新
This commit is contained in:
@@ -0,0 +1,402 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Net;
|
||||
using System.Net.Http;
|
||||
using System.Web.Http;
|
||||
using BLL;
|
||||
using WebAPI.Filter;
|
||||
|
||||
namespace WebAPI.Controllers
|
||||
{
|
||||
/// <summary>
|
||||
///
|
||||
/// </summary>
|
||||
public class DoorServerController : ApiController
|
||||
{
|
||||
#region 获取部门、人员、出入记录最大ID
|
||||
/// <summary>
|
||||
/// 获取部门、人员、出入记录最大ID
|
||||
/// </summary>
|
||||
/// <param name="projectId"></param>
|
||||
/// <returns></returns>
|
||||
public string getMaxID(string projectId)
|
||||
{
|
||||
int DepartmentID = 0, ID=0;
|
||||
long EmployID = 0, ValidEventID=0;
|
||||
var getD = Funs.DB.T_d_department.Where(x=> x.ProjectId == projectId).Select(x => x.DepartmentID);
|
||||
if (getD.Count()>0)
|
||||
{
|
||||
DepartmentID = getD.Max();
|
||||
}
|
||||
var getE= Funs.DB.T_d_employinfo.Where(x => x.ProjectId == projectId).Select(x => x.EmployID);
|
||||
if (getE.Count() > 0)
|
||||
{
|
||||
EmployID = getE.Max();
|
||||
}
|
||||
var getI = Funs.DB.T_d_facerecord.Where(x => x.ProjectId == projectId).Select(x => x.ID);
|
||||
if (getI.Count() > 0)
|
||||
{
|
||||
ID = getI.Max();
|
||||
}
|
||||
var getV = Funs.DB.T_d_validcardevent.Where(x => x.ProjectId == projectId).Select(x => x.ValidEventID);
|
||||
if (getV.Count() > 0)
|
||||
{
|
||||
ValidEventID = getV.Max();
|
||||
}
|
||||
return ("$" + DepartmentID.ToString()+"$"+ EmployID.ToString()+"$"+ID.ToString() + "$" + ValidEventID.ToString() + "$");
|
||||
}
|
||||
#endregion
|
||||
|
||||
#region 保存部门信息
|
||||
/// <summary>
|
||||
/// 保存部门信息
|
||||
/// </summary>
|
||||
/// <param name="department">部门信息</param>
|
||||
/// <returns></returns>
|
||||
[HttpPost]
|
||||
public Model.ResponeData SaveDepartment([FromBody] Model.t_d_departmentItem department)
|
||||
{
|
||||
var responeData = new Model.ResponeData();
|
||||
try
|
||||
{
|
||||
using (Model.SGGLDB db = new Model.SGGLDB(Funs.ConnString))
|
||||
{
|
||||
if (department != null)
|
||||
{
|
||||
var getDep = db.T_d_department.FirstOrDefault(x => x.DepartmentID == department.DepartmentID && x.ProjectId ==department.ProjectId);
|
||||
if (getDep == null)
|
||||
{
|
||||
Model.T_d_department newDep = new Model.T_d_department()
|
||||
{
|
||||
NewID = SQLHelper.GetNewID(),
|
||||
ProjectId = department.ProjectId,
|
||||
DepartmentID = department.DepartmentID,
|
||||
DepartmentName = department.DepartmentName,
|
||||
ParentID = department.ParentID,
|
||||
IsDel = department.IsDel,
|
||||
IsDown = department.IsDown,
|
||||
ParentDepartmentName = department.ParentDepartmentName,
|
||||
IsEnable = department.IsEnable,
|
||||
};
|
||||
db.T_d_department.InsertOnSubmit(newDep);
|
||||
db.SubmitChanges();
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
responeData.code = 2;
|
||||
responeData.message = "信息有误!";
|
||||
}
|
||||
}
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
responeData.code = 0;
|
||||
responeData.message = ex.Message;
|
||||
}
|
||||
|
||||
return responeData;
|
||||
}
|
||||
#endregion
|
||||
|
||||
#region 保存人员信息
|
||||
/// <summary>
|
||||
/// 保存人员信息
|
||||
/// </summary>
|
||||
/// <param name="employinfo">人员信息</param>
|
||||
/// <returns></returns>
|
||||
[HttpPost]
|
||||
public Model.ResponeData SaveEmployinfo([FromBody] Model.t_d_employinfoItem employinfo)
|
||||
{
|
||||
var responeData = new Model.ResponeData();
|
||||
try
|
||||
{
|
||||
using (Model.SGGLDB db = new Model.SGGLDB(Funs.ConnString))
|
||||
{
|
||||
if (employinfo != null)
|
||||
{
|
||||
var getEm = db.T_d_employinfo.FirstOrDefault(x => x.EmployID == employinfo.EmployID && x.ProjectId ==employinfo.ProjectId);
|
||||
if (getEm == null)
|
||||
{
|
||||
Model.T_d_employinfo newEmploy = new Model.T_d_employinfo()
|
||||
{
|
||||
NewID = SQLHelper.GetNewID(),
|
||||
ProjectId = employinfo.ProjectId,
|
||||
EmployID = employinfo.EmployID,
|
||||
WxEmployID = employinfo.WxEmployID,
|
||||
EmployNO = employinfo.EmployNO,
|
||||
EmployName = employinfo.EmployName,
|
||||
CardNO = employinfo.CardNO,
|
||||
GroupID = employinfo.GroupID,
|
||||
IsAttend = employinfo.IsAttend,
|
||||
IsDoor = employinfo.IsDoor,
|
||||
BeginDateTime = employinfo.BeginDateTime,
|
||||
EndDateTime = employinfo.EndDateTime,
|
||||
InPassWord = employinfo.InPassWord,
|
||||
DepartmentName = employinfo.DepartmentName,
|
||||
Mailbox = employinfo.Mailbox,
|
||||
Mobilephone = employinfo.Mobilephone,
|
||||
WeiXinNO = employinfo.WeiXinNO,
|
||||
PostName = employinfo.PostName,
|
||||
Gender = employinfo.Gender,
|
||||
IsDown = employinfo.IsDown,
|
||||
IsWxDown = employinfo.IsWxDown,
|
||||
IDCardNo = employinfo.IDCardNo,
|
||||
PlayCardNumber = employinfo.PlayCardNumber,
|
||||
PlayCardSum = employinfo.PlayCardSum,
|
||||
UpdataCloud = employinfo.UpdataCloud,
|
||||
Birthday = employinfo.Birthday,
|
||||
Police = employinfo.Police,
|
||||
Nation = employinfo.Nation,
|
||||
Address = employinfo.Address,
|
||||
UpdateState = employinfo.UpdateState,
|
||||
UpdateDateTime = employinfo.UpdateDateTime,
|
||||
IsSubmarineBack = employinfo.IsSubmarineBack,
|
||||
OnSiteState = employinfo.OnSiteState,
|
||||
TimeNumber = employinfo.TimeNumber,
|
||||
CardTimeRecord = employinfo.CardTimeRecord,
|
||||
ReservedFieldsOne = employinfo.ReservedFieldsOne,
|
||||
ReservedFieldsTwo = employinfo.ReservedFieldsTwo,
|
||||
ReservedFieldsThree = employinfo.ReservedFieldsThree,
|
||||
ReservedFieldsFour = employinfo.ReservedFieldsFour,
|
||||
ReservedFieldsFive = employinfo.ReservedFieldsFive,
|
||||
};
|
||||
|
||||
#region 获取部门
|
||||
var getDep = Funs.DB.T_d_department.FirstOrDefault(x => x.ProjectId == newEmploy.ProjectId && x.DepartmentID == newEmploy.GroupID);
|
||||
if (getDep != null)
|
||||
{
|
||||
if (getDep.ParentID == 0)
|
||||
{
|
||||
newEmploy.InstallationId = getDep.DepartmentID;
|
||||
}
|
||||
else
|
||||
{
|
||||
var getDep0 =BLL.DoorServerService.GetSupDep(newEmploy.ProjectId, getDep.ParentID, 0);
|
||||
if (getDep0 != null)
|
||||
{
|
||||
newEmploy.UnitId = newEmploy.GroupID;
|
||||
newEmploy.InstallationId = getDep0.DepartmentID;
|
||||
var getUnit = BLL.DoorServerService.GetSupDep(newEmploy.ProjectId, getDep.DepartmentID, newEmploy.InstallationId ?? 0);
|
||||
if (getUnit != null)
|
||||
{
|
||||
newEmploy.UnitId = getUnit.DepartmentID;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
#endregion
|
||||
|
||||
db.T_d_employinfo.InsertOnSubmit(newEmploy);
|
||||
db.SubmitChanges();
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
responeData.code = 2;
|
||||
responeData.message = "信息有误!";
|
||||
}
|
||||
}
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
responeData.code = 0;
|
||||
responeData.message = ex.Message;
|
||||
}
|
||||
|
||||
return responeData;
|
||||
}
|
||||
#endregion
|
||||
|
||||
#region 保存人脸识别出入记录信息
|
||||
/// <summary>
|
||||
/// 保存出入记录信息
|
||||
/// </summary>
|
||||
/// <param name="facerecord">出入记录信息</param>
|
||||
/// <returns></returns>
|
||||
[HttpPost]
|
||||
public Model.ResponeData SaveFacerecord([FromBody] Model.t_d_facerecordItem facerecord)
|
||||
{
|
||||
var responeData = new Model.ResponeData();
|
||||
try
|
||||
{
|
||||
using (Model.SGGLDB db = new Model.SGGLDB(Funs.ConnString))
|
||||
{
|
||||
if (facerecord != null)
|
||||
{
|
||||
var getFacerecord = db.T_d_facerecord.FirstOrDefault(x => x.ID == facerecord.ID && x.ProjectId == facerecord.ProjectId);
|
||||
if (getFacerecord == null)
|
||||
{
|
||||
Model.T_d_facerecord newFacerecord = new Model.T_d_facerecord()
|
||||
{
|
||||
NewID = SQLHelper.GetNewID(),
|
||||
ProjectId = facerecord.ProjectId,
|
||||
ID = facerecord.ID,
|
||||
EmployName = facerecord.EmployName,
|
||||
DepartmentID = facerecord.DepartmentID,
|
||||
DepartName = facerecord.DepartName,
|
||||
AreaID = facerecord.AreaID,
|
||||
AreaName = facerecord.AreaName,
|
||||
EmployNO = facerecord.EmployNO,
|
||||
CardID = facerecord.CardID,
|
||||
RoleID = facerecord.RoleID,
|
||||
DateTimeRecord = facerecord.DateTimeRecord,
|
||||
RecordDes = facerecord.RecordDes,
|
||||
FaceIP = facerecord.FaceIP,
|
||||
InOrOut = facerecord.InOrOut,
|
||||
Des1 = facerecord.Des1,
|
||||
Des2 = facerecord.Des2,
|
||||
Des3 = facerecord.Des3,
|
||||
Des4 = facerecord.Des4,
|
||||
};
|
||||
|
||||
db.T_d_facerecord.InsertOnSubmit(newFacerecord);
|
||||
db.SubmitChanges();
|
||||
if (facerecord.DateTimeRecord.HasValue)
|
||||
{
|
||||
Model.SitePerson_PersonInOut newInOut = new Model.SitePerson_PersonInOut
|
||||
{
|
||||
ProjectId = facerecord.ProjectId,
|
||||
IdentityCard = facerecord.EmployNO,
|
||||
IsIn = facerecord.InOrOut == "进门" ? true : false,
|
||||
ChangeTime = facerecord.DateTimeRecord.Value,
|
||||
InOutWay = Const.InOutWay_1,
|
||||
};
|
||||
|
||||
PersonInOutService.AddPersonInOut(newInOut);
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
responeData.code = 2;
|
||||
responeData.message = "信息有误!";
|
||||
}
|
||||
}
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
responeData.code = 0;
|
||||
responeData.message = ex.Message;
|
||||
}
|
||||
|
||||
return responeData;
|
||||
}
|
||||
#endregion
|
||||
|
||||
#region 保存刷卡出入记录信息
|
||||
/// <summary>
|
||||
/// 保存出入记录信息
|
||||
/// </summary>
|
||||
/// <param name="validcardevent">出入记录信息</param>
|
||||
/// <returns></returns>
|
||||
[HttpPost]
|
||||
public Model.ResponeData SaveValidcardevent([FromBody] Model.t_d_validcardeventItem validcardevent)
|
||||
{
|
||||
var responeData = new Model.ResponeData();
|
||||
try
|
||||
{
|
||||
using (Model.SGGLDB db = new Model.SGGLDB(Funs.ConnString))
|
||||
{
|
||||
if (validcardevent != null)
|
||||
{
|
||||
var getValidcardevent = db.T_d_facerecord.FirstOrDefault(x => x.ID == validcardevent.ValidEventID && x.ProjectId == validcardevent.ProjectId);
|
||||
if (getValidcardevent == null)
|
||||
{
|
||||
Model.T_d_validcardevent newValidcardevent = new Model.T_d_validcardevent()
|
||||
{
|
||||
NewID = SQLHelper.GetNewID(),
|
||||
ProjectId = validcardevent.ProjectId,
|
||||
ValidEventID = validcardevent.ValidEventID,
|
||||
RecordDateTime = validcardevent.RecordDateTime,
|
||||
CardNO = validcardevent.CardNO,
|
||||
ConsumerID = validcardevent.ConsumerID,
|
||||
InOrOut = validcardevent.InOrOut,
|
||||
ControllerID = validcardevent.ControllerID,
|
||||
ReaderNO = validcardevent.ReaderNO,
|
||||
RecordFlashLoc = validcardevent.RecordFlashLoc,
|
||||
RecordAll = validcardevent.RecordAll,
|
||||
JPGPath = validcardevent.JPGPath,
|
||||
IsDown = validcardevent.IsDown,
|
||||
EquipmentSN = validcardevent.EquipmentSN,
|
||||
ConsumerNO = validcardevent.ConsumerNO,
|
||||
EmployNO = validcardevent.EmployNO,
|
||||
EmployName = validcardevent.EmployName,
|
||||
CardType = validcardevent.CardType,
|
||||
Card = validcardevent.Card,
|
||||
DepartmentID = validcardevent.DepartmentID,
|
||||
DepartmentName = validcardevent.DepartmentName,
|
||||
ControllerSN = validcardevent.ControllerSN,
|
||||
DoorID = validcardevent.DoorID,
|
||||
DoorName = validcardevent.DoorName,
|
||||
ReaderName = validcardevent.ReaderName,
|
||||
AreaID = validcardevent.AreaID,
|
||||
AreaName = validcardevent.AreaName,
|
||||
WorkType = validcardevent.WorkType,
|
||||
Positions = validcardevent.Positions,
|
||||
IDCardNo = validcardevent.IDCardNo,
|
||||
};
|
||||
|
||||
db.T_d_validcardevent.InsertOnSubmit(newValidcardevent);
|
||||
db.SubmitChanges();
|
||||
|
||||
if (validcardevent.RecordDateTime.HasValue)
|
||||
{
|
||||
Model.SitePerson_PersonInOut newInOut = new Model.SitePerson_PersonInOut
|
||||
{
|
||||
ProjectId = validcardevent.ProjectId,
|
||||
IdentityCard = validcardevent.EmployNO,
|
||||
IsIn = validcardevent.InOrOut == 1 ? true : false,
|
||||
ChangeTime = validcardevent.RecordDateTime.Value,
|
||||
InOutWay = Const.InOutWay_1,
|
||||
};
|
||||
|
||||
PersonInOutService.AddPersonInOut(newInOut);
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
responeData.code = 2;
|
||||
responeData.message = "信息有误!";
|
||||
}
|
||||
}
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
responeData.code = 0;
|
||||
responeData.message = ex.Message;
|
||||
}
|
||||
|
||||
return responeData;
|
||||
}
|
||||
#endregion
|
||||
|
||||
#region 获取门禁人员考勤统计
|
||||
/// <summary>
|
||||
/// 获取人员信息出入场记录
|
||||
/// </summary>
|
||||
/// <param name="projectId"></param>
|
||||
/// <param name="startDate"></param>
|
||||
/// <param name="endDate"></param>
|
||||
/// <returns></returns>
|
||||
public Model.ResponeData getInOutstatistics(string projectId, DateTime startDate, DateTime endDate)
|
||||
{
|
||||
var responeData = new Model.ResponeData();
|
||||
try
|
||||
{
|
||||
string unitId = null;
|
||||
string postId = null;
|
||||
responeData.data = Funs.DB.spInOutManHoursReport(projectId, unitId, postId, startDate, endDate).ToList(); ;
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
responeData.code = 0;
|
||||
responeData.message = ex.Message;
|
||||
}
|
||||
return responeData;
|
||||
}
|
||||
#endregion
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,502 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Configuration;
|
||||
using System.IO;
|
||||
using System.Linq;
|
||||
using System.Net;
|
||||
using System.Net.Http;
|
||||
using System.Web.Http;
|
||||
using BLL;
|
||||
using WebAPI.Filter;
|
||||
|
||||
namespace WebAPI.Controllers
|
||||
{
|
||||
/// <summary>
|
||||
///
|
||||
/// </summary>
|
||||
public class DoorServiceController : ApiController
|
||||
{
|
||||
#region 项目出入记录接口
|
||||
/// <summary>
|
||||
/// 保存出入记录信息
|
||||
/// </summary>
|
||||
/// <param name="records">出入记录信息</param>
|
||||
/// <returns></returns>
|
||||
[HttpPost]
|
||||
public Model.ResponeData postPersonInOuts([FromBody] Model.attendanceItems records)
|
||||
{
|
||||
var responeData = new Model.ResponeData();
|
||||
try
|
||||
{
|
||||
if (records != null && records.records.Count() > 0)
|
||||
{
|
||||
List<Model.attendanceItem> attendanceItems = records.records;
|
||||
var getprojectCode = attendanceItems.FirstOrDefault(x => x.ProjectCode != null || x.ProjectId != null);
|
||||
if (getprojectCode != null)
|
||||
{
|
||||
string projectId = getprojectCode.ProjectId;
|
||||
if (string.IsNullOrEmpty(projectId))
|
||||
{
|
||||
var getProject = ProjectService.GetProjectByProjectCode(getprojectCode.ProjectCode);
|
||||
if (getProject != null)
|
||||
{
|
||||
projectId = getProject.ProjectId;
|
||||
}
|
||||
}
|
||||
if (!string.IsNullOrEmpty(projectId))
|
||||
{
|
||||
using (Model.SGGLDB db = new Model.SGGLDB(Funs.ConnString))
|
||||
{
|
||||
int maxId = 0;
|
||||
var getmax = db.T_d_facerecord.Where(x => x.ProjectId == projectId && x.RoleID == "白名单").Select(x => x.ID);
|
||||
if (getmax.Count() > 0)
|
||||
{
|
||||
maxId = getmax.Max();
|
||||
}
|
||||
foreach (var item in attendanceItems)
|
||||
{
|
||||
maxId = maxId + 1;
|
||||
string name = string.Empty;
|
||||
string cardNo = string.Empty;
|
||||
var getPerson = db.SitePerson_Person.FirstOrDefault(x => x.IdentityCard == item.idCardNumber);
|
||||
if (getPerson != null)
|
||||
{
|
||||
name = getPerson.PersonName;
|
||||
cardNo = getPerson.CardNo;
|
||||
}
|
||||
|
||||
Model.T_d_facerecord newFacerecord = new Model.T_d_facerecord()
|
||||
{
|
||||
NewID = SQLHelper.GetNewID(),
|
||||
ProjectId = projectId,
|
||||
ID = maxId,
|
||||
EmployName = name,
|
||||
EmployNO = item.idCardNumber,
|
||||
RoleID = "白名单",
|
||||
DateTimeRecord = Funs.GetNewDateTime(item.attendanceTime),
|
||||
RecordDes = "白名单:允许通行",
|
||||
InOrOut = (item.attendanceType == 1 ? "进门" : "出门"),
|
||||
};
|
||||
|
||||
db.T_d_facerecord.InsertOnSubmit(newFacerecord);
|
||||
db.SubmitChanges();
|
||||
///// 根据出入记录 写入考勤记录
|
||||
Model.t_d_facerecordItem facerecord = new Model.t_d_facerecordItem
|
||||
{
|
||||
ID = maxId,
|
||||
EmployName = name,
|
||||
IDCardNo = item.idCardNumber,
|
||||
EmployNO = item.idCardNumber,
|
||||
ProjectId = projectId,
|
||||
RoleID = "白名单",
|
||||
DateTimeRecord = Funs.GetNewDateTime(item.attendanceTime),
|
||||
RecordDes = "白名单:允许通行",
|
||||
InOrOut = (item.attendanceType == 1 ? "进门" : "出门"),
|
||||
};
|
||||
|
||||
if (facerecord.DateTimeRecord.HasValue)
|
||||
{
|
||||
int isIn = 0;
|
||||
if (facerecord.InOrOut == "进门")
|
||||
{
|
||||
isIn = 1;
|
||||
}
|
||||
APIPersonService.getPersonInOut(facerecord.ProjectId, facerecord.EmployNO, isIn, facerecord.DateTimeRecord.Value);
|
||||
}
|
||||
}
|
||||
responeData.message = "插入成功!";
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
responeData.code = 0;
|
||||
responeData.message = "项目号异常!";
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
responeData.code = 0;
|
||||
responeData.message = "项目号为空!";
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
responeData.code = 0;
|
||||
responeData.message = "数据为空!";
|
||||
}
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
responeData.code = 0;
|
||||
responeData.message = ex.Message;
|
||||
}
|
||||
|
||||
return responeData;
|
||||
}
|
||||
#endregion
|
||||
|
||||
#region 项目出入人员信息
|
||||
/// <summary>
|
||||
/// 保存人员信息
|
||||
/// </summary>
|
||||
/// <param name="person">人员信息</param>
|
||||
/// <returns></returns>
|
||||
[HttpPost]
|
||||
public Model.ResponeData postPersons([FromBody] Model.PersonItem person)
|
||||
{
|
||||
var responeData = new Model.ResponeData();
|
||||
try
|
||||
{
|
||||
if (person != null)
|
||||
{
|
||||
using (Model.SGGLDB db = new Model.SGGLDB(Funs.ConnString))
|
||||
{
|
||||
var getProject = ProjectService.GetProjectByProjectCode(person.ProjectCode);
|
||||
if (getProject != null)
|
||||
{
|
||||
var getUnit = UnitService.getUnitByCollCropCodeUnitName(person.CollCropCode, person.UnitName);
|
||||
if (getUnit != null)
|
||||
{
|
||||
Model.SitePerson_Person newPerson = new Model.SitePerson_Person
|
||||
{
|
||||
PersonId = SQLHelper.GetNewID(),
|
||||
ProjectId = getProject.ProjectId,
|
||||
UnitId = getUnit.UnitId,
|
||||
PersonName = person.PersonName,
|
||||
IdentityCard = person.IdentityCard,
|
||||
IdcardType = "SHENFEN_ZHENGJIAN",
|
||||
IdcardAddress = person.IdcardAddress,
|
||||
IdcardForever = "N",
|
||||
IdcardStartDate = Funs.GetNewDateTime(person.IdcardStartDate),
|
||||
IdcardEndDate = Funs.GetNewDateTime(person.IdcardEndDate),
|
||||
Sex = (person.Sex == "女" || person.Sex == "2") ? "2" : "1",
|
||||
Address = person.Address,
|
||||
OutResult = person.OutResult,
|
||||
Birthday = person.Birthday,
|
||||
Telephone = person.Telephone,
|
||||
IsUsed = (person.IsUsed == false ? false : true),
|
||||
InTime = Funs.GetNewDateTimeOrNow(person.InTime),
|
||||
Password = BLL.PersonService.GetPersonPassWord(person.IdentityCard),
|
||||
Isprint = "0",
|
||||
};
|
||||
if (!string.IsNullOrEmpty(person.TeamGroupName) && !string.IsNullOrEmpty(newPerson.UnitId))
|
||||
{
|
||||
var getTeamGroup = TeamGroupService.getTeamGroupByTeamGroupName(getProject.ProjectId, newPerson.UnitId, person.TeamGroupName);
|
||||
if (getTeamGroup != null)
|
||||
{
|
||||
newPerson.TeamGroupId = getTeamGroup.TeamGroupId;
|
||||
}
|
||||
else
|
||||
{
|
||||
Model.ProjectData_TeamGroup newTeamGroup = new Model.ProjectData_TeamGroup
|
||||
{
|
||||
TeamGroupId = SQLHelper.GetNewID(),
|
||||
ProjectId = getProject.ProjectId,
|
||||
UnitId = newPerson.UnitId,
|
||||
TeamGroupName = person.TeamGroupName,
|
||||
Remark = "来源:门禁对接数据",
|
||||
TeamTypeId = "CANJIAN_TEAM",
|
||||
EntryTime = System.DateTime.Now,
|
||||
RealNamePushTime = null,
|
||||
};
|
||||
db.ProjectData_TeamGroup.InsertOnSubmit(newTeamGroup);
|
||||
db.SubmitChanges();
|
||||
newPerson.TeamGroupId = newTeamGroup.TeamGroupId;
|
||||
}
|
||||
}
|
||||
var getWorkArea = UnitWorkService.GetUnitWorkByUnitWorkName(getProject.ProjectId, person.WorkAreaName);
|
||||
if (getWorkArea != null)
|
||||
{
|
||||
newPerson.WorkAreaId = getWorkArea.UnitWorkId;
|
||||
}
|
||||
var getWorkPost = WorkPostService.GetWorkPostByName(person.WorkPostName);
|
||||
if (getWorkPost != null)
|
||||
{
|
||||
newPerson.WorkPostId = getWorkPost.WorkPostId;
|
||||
}
|
||||
var getHsseMan = ProjectService.getHSSEManager(getProject.ProjectId);
|
||||
if (getHsseMan != null)
|
||||
{
|
||||
newPerson.AuditorId = getHsseMan.UserId;
|
||||
newPerson.AuditorDate = DateTime.Now;
|
||||
}
|
||||
newPerson.OutTime = Funs.GetNewDateTime(person.OutTime);
|
||||
if (person.headImage != null)
|
||||
{
|
||||
var image = Convert.FromBase64String(person.headImage);
|
||||
newPerson.HeadImage = image;
|
||||
string rootPath = ConfigurationManager.AppSettings["localRoot"];
|
||||
string path = "FileUpLoad/PersonBaseInfo/" + DateTime.Now.ToString("yyyy-MM") + "/";
|
||||
string fileUrl = (rootPath + path).Replace('/', '\\');
|
||||
string flieName = Funs.GetNewFileName() + "~" + person.PersonName + ".jpg";
|
||||
if (!Directory.Exists(fileUrl))
|
||||
{
|
||||
Directory.CreateDirectory(fileUrl);
|
||||
}
|
||||
newPerson.PhotoUrl = path + flieName;
|
||||
File.WriteAllBytes((fileUrl + flieName), image);
|
||||
//AttachFileService.Base64ToImage(person.headImage, path, person.PersonName);
|
||||
}
|
||||
|
||||
var getPerson = db.SitePerson_Person.FirstOrDefault(e => e.ProjectId == getProject.ProjectId && e.IdentityCard == person.IdentityCard);
|
||||
if (getPerson == null)
|
||||
{
|
||||
PersonService.AddPerson(newPerson);
|
||||
responeData.message = "新增人员成功!";
|
||||
}
|
||||
else
|
||||
{
|
||||
if (!string.IsNullOrEmpty(person.OutTime))
|
||||
{
|
||||
var outTime = Funs.GetNewDateTimeOrNow(person.OutTime);
|
||||
PersonService.PersonOut(getPerson.PersonId, outTime);
|
||||
responeData.message = "更新出场时间";
|
||||
}
|
||||
else
|
||||
{
|
||||
getPerson.PersonName = newPerson.PersonName;
|
||||
getPerson.IdcardAddress = newPerson.IdcardAddress;
|
||||
getPerson.IdcardStartDate = newPerson.IdcardStartDate;
|
||||
getPerson.IdcardEndDate = newPerson.IdcardEndDate;
|
||||
getPerson.Sex = newPerson.Sex;
|
||||
getPerson.Address = newPerson.Address;
|
||||
getPerson.OutResult = newPerson.OutResult;
|
||||
getPerson.Birthday = newPerson.Birthday;
|
||||
getPerson.Telephone = newPerson.Telephone;
|
||||
getPerson.IsUsed = true;
|
||||
getPerson.InTime = newPerson.InTime;
|
||||
if (!string.IsNullOrEmpty(newPerson.TeamGroupId))
|
||||
{
|
||||
getPerson.TeamGroupId = newPerson.TeamGroupId;
|
||||
}
|
||||
if (!string.IsNullOrEmpty(newPerson.WorkPostId))
|
||||
{
|
||||
getPerson.WorkPostId = newPerson.WorkPostId;
|
||||
}
|
||||
if (!string.IsNullOrEmpty(newPerson.PhotoUrl))
|
||||
{
|
||||
getPerson.PhotoUrl = newPerson.PhotoUrl;
|
||||
}
|
||||
db.SubmitChanges();
|
||||
responeData.message = getPerson.PersonName+ ":信息更新成功!";
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
responeData.code = 0;
|
||||
responeData.message = "单位:" + person.UnitName + "施工平台不存在!";
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
responeData.code = 0;
|
||||
responeData.message = "项目号:" + person.ProjectCode + "施工平台不存在!";
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
responeData.code = 0;
|
||||
responeData.message = "数据为空!";
|
||||
}
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
responeData.code = 0;
|
||||
responeData.message = ex.Message;
|
||||
}
|
||||
|
||||
return responeData;
|
||||
}
|
||||
#endregion
|
||||
|
||||
#region 获取在岗人员 -照片不空
|
||||
/// <summary>
|
||||
/// 获取在岗人员
|
||||
/// </summary>
|
||||
/// <param name="projectCode"></param>
|
||||
/// <returns></returns>
|
||||
public Model.ResponeData getPersons(string projectCode)
|
||||
{
|
||||
var responeData = new Model.ResponeData();
|
||||
try
|
||||
{
|
||||
var getProject = Funs.DB.Base_Project.FirstOrDefault(e => e.ProjectCode == projectCode);
|
||||
if (getProject != null)
|
||||
{
|
||||
responeData.data = from x in Funs.DB.SitePerson_Person
|
||||
join y in Funs.DB.Base_Unit on x.UnitId equals y.UnitId
|
||||
join T in Funs.DB.ProjectData_TeamGroup on x.TeamGroupId equals T.TeamGroupId
|
||||
join w in Funs.DB.Base_WorkPost on x.WorkPostId equals w.WorkPostId
|
||||
where x.ProjectId == getProject.ProjectId && !x.ExchangeTime.HasValue
|
||||
&& (!x.OutTime.HasValue || x.OutTime > DateTime.Now)
|
||||
&& x.InTime.HasValue && x.InTime < DateTime.Now
|
||||
&& x.IsUsed == true
|
||||
&& x.PhotoUrl != null
|
||||
select new
|
||||
{
|
||||
x.PersonId,
|
||||
x.PersonName,
|
||||
x.CardNo,
|
||||
x.IdentityCard,
|
||||
x.UnitId,
|
||||
y.UnitCode,
|
||||
y.UnitName,
|
||||
y.ShortUnitName,
|
||||
T.TeamGroupName,
|
||||
x.Sex,
|
||||
w.WorkPostName,
|
||||
x.Telephone,
|
||||
x.Address,
|
||||
x.InTime,
|
||||
x.AuditorDate,
|
||||
x.ExchangeTime,
|
||||
x.ExchangeTime2,
|
||||
x.PhotoUrl,
|
||||
};
|
||||
}
|
||||
else
|
||||
{
|
||||
responeData.code = 0;
|
||||
responeData.message = "数据为空!";
|
||||
}
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
responeData.code = 0;
|
||||
responeData.message = ex.Message;
|
||||
ErrLogInfo.WriteLog(ex, "WX接口-获取人员下发门禁", "DoorServiceController.getPersons");
|
||||
}
|
||||
return responeData;
|
||||
}
|
||||
#endregion
|
||||
|
||||
#region 更新人员数据交换时间
|
||||
/// <summary>
|
||||
/// 更新人员数据交换时间
|
||||
/// </summary>
|
||||
/// <param name="projectCode"></param>
|
||||
/// <param name="idCard"></param>
|
||||
/// <param name="type"></param>
|
||||
/// <returns></returns>
|
||||
public Model.ResponeData getUpdatePersonExchangeTime(string projectCode, string idCard, string type)
|
||||
{
|
||||
var responeData = new Model.ResponeData();
|
||||
try
|
||||
{
|
||||
using (Model.SGGLDB db = new Model.SGGLDB(Funs.ConnString))
|
||||
{
|
||||
var getProject = db.Base_Project.FirstOrDefault(e => e.ProjectCode == projectCode);
|
||||
if (getProject != null)
|
||||
{
|
||||
var getPerson = db.SitePerson_Person.FirstOrDefault(e => e.ProjectId == getProject.ProjectId && e.IdentityCard == idCard);
|
||||
if (getPerson != null && !string.IsNullOrEmpty(type))
|
||||
{
|
||||
if (type == "1")
|
||||
{
|
||||
getPerson.ExchangeTime2 = DateTime.Now;
|
||||
if (!getPerson.ExchangeTime.HasValue)
|
||||
{
|
||||
getPerson.ExchangeTime = DateTime.Now;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
getPerson.ExchangeTime = DateTime.Now;
|
||||
}
|
||||
db.SubmitChanges();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
responeData.code = 0;
|
||||
responeData.message = ex.Message;
|
||||
ErrLogInfo.WriteLog(ex, "WX接口-更新人员数据交换时间", "PersonController.getUpdatePersonExchangeTime");
|
||||
}
|
||||
return responeData;
|
||||
}
|
||||
#endregion
|
||||
|
||||
#region 获取离场人员
|
||||
/// <summary>
|
||||
/// 获取离场人员
|
||||
/// </summary>
|
||||
/// <param name="projectCode"></param>
|
||||
/// <returns></returns>
|
||||
public Model.ResponeData getOutWorkPersons(string projectCode)
|
||||
{
|
||||
var responeData = new Model.ResponeData();
|
||||
try
|
||||
{
|
||||
using (Model.SGGLDB db = new Model.SGGLDB(Funs.ConnString))
|
||||
{
|
||||
var getProject = db.Base_Project.FirstOrDefault(e => e.ProjectCode == projectCode);
|
||||
if (getProject != null)
|
||||
{
|
||||
responeData.data = (from x in db.SitePerson_Person
|
||||
where x.ProjectId == getProject.ProjectId
|
||||
&& x.OutTime.HasValue
|
||||
&& !x.ExchangeTime2.HasValue && x.ExchangeTime.HasValue
|
||||
select new
|
||||
{
|
||||
x.PersonId,
|
||||
x.PersonName,
|
||||
x.CardNo,
|
||||
x.IdentityCard,
|
||||
OutTime = x.OutTime == null ? DateTime.Now.AddYears(10) : x.OutTime,
|
||||
}).Take(200).ToList();
|
||||
}
|
||||
}
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
responeData.code = 0;
|
||||
responeData.message = ex.Message;
|
||||
}
|
||||
return responeData;
|
||||
}
|
||||
#endregion
|
||||
|
||||
#region 插入人员出入场记录
|
||||
/// <summary>
|
||||
/// 获取人员出入场记录
|
||||
/// </summary>
|
||||
/// <param name="projectCode"></param>
|
||||
/// <param name="idCard"></param>
|
||||
/// <param name="isIn"></param>
|
||||
/// <param name="changeTime"></param>
|
||||
/// <returns></returns>
|
||||
public Model.ResponeData getPersonInOut(string projectCode, string idCard, int isIn, DateTime changeTime)
|
||||
{
|
||||
var responeData = new Model.ResponeData();
|
||||
try
|
||||
{
|
||||
var getProject = ProjectService.GetProjectByProjectCode(projectCode);
|
||||
if (getProject != null)
|
||||
{
|
||||
Model.SitePerson_PersonInOut newInOut = new Model.SitePerson_PersonInOut
|
||||
{
|
||||
ProjectId = getProject.ProjectId,
|
||||
IdentityCard = idCard,
|
||||
IsIn = isIn == 1 ? true : false,
|
||||
ChangeTime = changeTime,
|
||||
InOutWay = Const.InOutWay_1,
|
||||
};
|
||||
|
||||
PersonInOutService.AddPersonInOut(newInOut);
|
||||
}
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
responeData.code = 0;
|
||||
responeData.message = ex.Message;
|
||||
ErrLogInfo.WriteLog(ex, "WX接口-插入人员出入场记录", "PersonController.getPersonInOut");
|
||||
}
|
||||
return responeData;
|
||||
}
|
||||
#endregion
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user