You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
DS7/DSWeb/Areas/MvcShipping/DAL/BillCheckOut/BillCheckOutDAL.cs

436 lines
15 KiB
C#

using System;
using System.Data;
using System.Collections.Generic;
using System.Text;
using DSWeb.Common.DB;
using System.Linq;
using DSWeb.MvcShipping.Helper;
using DSWeb.Common.Helper;
using DSWeb.Areas.CommMng.Models;
using static DSWeb.Areas.CommMng.DAL.BasicDataRefDAL;
using DSWeb.EntityDA;
using Microsoft.Practices.EnterpriseLibrary.Data;
using DSWeb.Areas.CommMng.DAL;
using HcUtility.Comm;
using System.Web.Mvc;
using DSWeb.MvcShipping.DAL.DsSendmail;
using iTextSharp.text.pdf;
using iTextSharp.text;
using System.IO;
using sun.swing;
using DSWeb.Areas.Import.DAL.ReceiptDoc;
using DSWeb.Areas.SysMng.DAL.SysUser;
using Renci.SshNet.Common;
using DSWeb.MvcShipping.DAL.MsSeaeOrderDAL;
using System.Data.Entity.Migrations;
namespace DSWeb.MvcShipping.DAL.BillCheckOut
{
public class BillCheckOutDAL
{
public static List<BillCheckOut_md> GetDataList(int start, int limit, string sort, string strCondition,string userid,string username, string companyid, ref int count)
{
var rangstr = GetRangDAStr("index", userid, username, companyid);
var strSql = new StringBuilder();
strSql.Append(" select * from ");
strSql.Append(" BillCheckOut where 1=1 ");
var sortstring = DatasetSort.Getsortstring(sort);
PagedQuaryParam pp = new PagedQuaryParam();
pp.strSql = strSql.ToString();
pp.start = start;
pp.limit = limit;
pp.strCondition = strCondition;
pp.defaultsortstr = "CREATETIME desc";
pp.sortstring = sortstring;
pp.rangestr = rangstr;
var result = PagedQuaryStr(pp);
count = PagedCount(pp);
return SetData(result);
}
public static List<VW_BillCheckOut_Detail_md> GetBodyList(string LINKGID)
{
var cdc = new CommonDataContext();
var dataList = cdc.VW_BillCheckOut_Detail.Where(x=>x.LINKGID== LINKGID).ToList();
//var count = dataList.Count();
//var list = dataList.Skip(start).Take(limit).ToList();
return dataList;
}
public static string GetRangDAStr(string tb, string userid, string username, string companyid)
{
string str = "";
var strSql = new StringBuilder();
strSql.Append("SELECT ");
strSql.Append(" VISIBLERANGE,OPERATERANGE,AUTHORITYID,VSSQL ");
strSql.Append(" from VW_User_Authority ");
strSql.Append(" where [NAME]='modBillCheckOut' and USERID='" + userid + "' and ISDELETE=0");
string visiblerange = "4";
string operaterange = "4";
string AUTHORITYID = "";
string VSSQL = "";
Database db = DatabaseFactory.CreateDatabase();
using (IDataReader reader = db.ExecuteReader(CommandType.Text, strSql.ToString()))
{
while (reader.Read())
{
visiblerange = Convert.ToString(reader["VISIBLERANGE"]);
operaterange = Convert.ToString(reader["OPERATERANGE"]);
AUTHORITYID = Convert.ToString(reader["AUTHORITYID"]);
VSSQL = Convert.ToString(reader["VSSQL"]);
break;
}
reader.Close();
}
if (visiblerange == "4")
{
str = "1=2";
}
else if (visiblerange == "3")
{
str = " (INPUTBY='" + username + "' OR SENDER='" + username + "' OR CHECKOUTUSER='" + username + "' )";
}
else if (visiblerange == "2")
{
if (tb == "index")
{
var rangeDa = new RangeDA();
var deptid = rangeDa.GetDEPTGID(userid);
str = $" exists(select 1 from vw_user where deptgid='{deptid}' and SHOWNAME in(INPUTBY,SENDER,CHECKOUTUSER)) ";
}
else
{
str = " (UPPER(CORPID)='" + companyid + "' or SALECORPID='" + companyid + "') ";
}
}
else if (visiblerange == "5")
{
if (tb == "index")
{
var userstr = new StringBuilder();
userstr.Append(" select COMPANYID from user_authority_range_company where userid='" + userid + "' and AUTHORITYID='" + AUTHORITYID + "' and VISIBLERANGE=1");
Database userdb = DatabaseFactory.CreateDatabase();
using (IDataReader reader = userdb.ExecuteReader(CommandType.Text, userstr.ToString()))
{
str = "";
while (reader.Read())
{
if (str == "")
{
str = " (CORPID='" + Convert.ToString(reader["COMPANYID"]) + "' or SALECORPID='" + Convert.ToString(reader["COMPANYID"]) + "' ";
}
else
{
str = str + " or CORPID='" + Convert.ToString(reader["COMPANYID"]) + "' or SALECORPID='" + Convert.ToString(reader["COMPANYID"]) + "'";
};
}
str = str + ")";
reader.Close();
}
}
else
{
str = " (UPPER(CORPID)='" + companyid + "' or SALECORPID='" + companyid + "') ";
}
}
else if (visiblerange == "6")
{
if (tb == "index")
{
str = " EXISTS (select 1 from user_authority_range_op P left join [user] u on (u.GID=P.OPID) where (INPUTBY=U.SHOWNAME OR SENDER=U.SHOWNAME OR CHECKOUTUSER=U.SHOWNAME ) AND P.userid='" + userid + "' and P.AUTHORITYID='" + AUTHORITYID + "' and P.VISIBLERANGE=1) ";
}
else
{
str = " (UPPER(CORPID)='" + companyid + "' or SALECORPID='" + companyid + "') ";
}
}
else if (visiblerange == "1")
{
str = " (UPPER(B.Corpid)='" + companyid + "' or B.SALECORPID='" + companyid + "') ";
}
VSSQL = VSSQL.Trim();
if (!string.IsNullOrEmpty(VSSQL))
{
if (!string.IsNullOrEmpty(str))
{
str = str + " and (" + VSSQL + ") ";
}
else
{
str = " (" + VSSQL + ") ";
}
}
return str;
}
private static List<BillCheckOut_md> SetData(StringBuilder strSql, bool isNoForward = false)
{
var headList = new List<BillCheckOut_md>();
Database db = DatabaseFactory.CreateDatabase();
using (IDataReader reader = db.ExecuteReader(CommandType.Text, strSql.ToString()))
{
while (reader.Read())
{
BillCheckOut_md data = new BillCheckOut_md();
#region Set DB data to Object
data.GID = Convert.ToString(reader["GID"]);
data.CHECKOUTNO = Convert.ToString(reader["CHECKOUTNO"]);
data.CUSTOMERNAME = Convert.ToString(reader["CUSTOMERNAME"]);
data.CORPID = Convert.ToString(reader["CORPID"]);
data.SALECORPID = Convert.ToString(reader["SALECORPID"]);
data.INPUTBY = Convert.ToString(reader["INPUTBY"]);
if (reader["CREATETIME"] != DBNull.Value)
data.CREATETIME = Convert.ToDateTime(reader["CREATETIME"]);
data.MODIFIER = Convert.ToString(reader["MODIFIER"]);
if (reader["MODIFYTIME"] != DBNull.Value)
data.MODIFYTIME = Convert.ToDateTime(reader["MODIFYTIME"]);
//if (reader["SENDED"] != DBNull.Value)
// data.SENDED = Convert.ToBoolean(reader["SENDED"]);
data.SENDED =(bool) getValue(reader, "SENDED");
data.SENDER = Convert.ToString(reader["SENDER"]);
if (reader["SENDTIME"] != DBNull.Value)
data.SENDTIME = Convert.ToDateTime(reader["SENDTIME"]);
data.RECEIVER = Convert.ToString(reader["RECEIVER"]);
data.RECEIVEEMAIL = Convert.ToString(reader["RECEIVEEMAIL"]);
//if (reader["ISCHECKOUT"] != DBNull.Value)
// data.ISCHECKOUT = Convert.ToBoolean(reader["ISCHECKOUT"]);
data.ISCHECKOUT = (bool)getValue(reader, "ISCHECKOUT");
if (reader["CHECKOUTTIME"] != DBNull.Value)
data.CHECKOUTTIME = Convert.ToDateTime(reader["CHECKOUTTIME"]);
data.CHECKOUTUSER = Convert.ToString(reader["CHECKOUTUSER"]);
data.MAILPDFURL = Convert.ToString(reader["MAILPDFURL"]);
data.SIGNPDFURL = Convert.ToString(reader["SIGNPDFURL"]);
#endregion
headList.Add(data);
}
reader.Close();
}
return headList;
}
#region 通知签单
/// <summary>
/// 向客户发出签单条
/// </summary>
/// <param name="BSNOs"></param>
/// <returns></returns>
public static DBResult NoticeCustomerToCheckOut(string BSNOs,string path,string username)
{
var result = new DBResult();
var gidList= BSNOs.Split(',').ToList();
var cdc = new CommonDataContext();
var headList = cdc.BillCheckOut.Where(x => gidList.Contains(x.GID)).ToList();
foreach (var item in headList) {
var cansend = CanSend(item);
if (!cansend.Success) return cansend;
}
foreach (var item in headList)
{
var _r= DoSendMail(item,path);
if (_r.Success) {
item.SENDED = true;
item.SENDTIME = DateTime.Now;
item.SENDER = username;
}
}
cdc.SaveChanges();
return result;
}
public static DBResult SaveSignPdf(string GID, string Base64Str, string path, string username) {
var result = new DBResult();
try
{
var cdc = new CommonDataContext();
var head = cdc.BillCheckOut.FirstOrDefault(x => x.GID == GID);
byte[] bytes = Convert.FromBase64String(Base64Str);
string location = path+"/"+ head.CHECKOUTNO + "_Sign.pdf";
if (File.Exists(location))
{
File.Delete(location);
}
System.IO.FileStream stream = new FileStream(location, FileMode.CreateNew);
System.IO.BinaryWriter writer = new BinaryWriter(stream);
writer.Write(bytes, 0, bytes.Length);
writer.Close();
head.CHECKOUTUSER=username;
head.CHECKOUTTIME=DateTime.Now;
head.SIGNPDFURL = location;
cdc.BillCheckOut.AddOrUpdate(head);
cdc.SaveChanges();
result.OK();
}
catch (Exception e) {
result.SetErrorInfo(e.Message);
}
return result;
}
public static DBResult CanSend(BillCheckOut_md head) {
var result = new DBResult();
result.OK();
if (string.IsNullOrWhiteSpace(head.RECEIVEEMAIL)) {
result.SetErrorInfo("未指定收件人邮箱");
}
return result;
}
public static DBResult DoSendMail(BillCheckOut_md head, string path)
{
var result = new DBResult();
//1根据业务的明细 生成一个pdf
result=MakeCheckOutPdf( head, path);
if (!result.Success) return result;
var filename = result.Message;
//2作为附件发出
//result = SendCheckOutEmail(head);
return result;
}
public static DBResult MakeCheckOutPdf(BillCheckOut_md head, string path) {
var result = new DBResult();
//读取基本dpf 在其中增加内容
PDFHelper ph = new PDFHelper();
result = ph.MakePdf_BillCheckOut(head, path);
return result;
}
public static DBResult SendCheckOutEmail(BillCheckOut_md head)
{
var cdc = new CommonDataContext();
var result = new DBResult(true, "");
try
{
head = cdc.BillCheckOut.FirstOrDefault(x => x.GID == head.GID);
var mailtitle = "签单表";
var Body = new StringBuilder();
Body.Append("<html> <Body>");
Body.Append("<br />签单表内容:<br />业务编号:");
//Body.Append("<br />客户名称:" + headData.CUSTOMERNAME);
//Body.Append("<br />揽货人" + headData.SALE);
//Body.Append("<br />录入人" + headData.INPUTBY);
//Body.Append("<br />港口:" + headData.DESTINATION);
//Body.Append("<br />船期:" + headData.ETD);
//Body.Append("<br />船公司:" + headData.CARRIER);
//Body.Append("<br />箱量:" + headData.CNTRTOTAL);
//Body.Append("<br />备注:" + OrderData.REMARK);
Body.Append("</Body></html> ");
var mailto = head.RECEIVEEMAIL;
//var oplist = SysUserDAL.GetDataList("U.SHOWNAME='" + op + "' or U.SHOWNAME='" + headData.SALE + "' or U.SHOWNAME='" + OrderData.INPUTBY + "' ");
//foreach (var opbs in oplist)
//{
// if (opbs.EMAIL1 != "")
// {
// if (mailto == "")
// mailto = opbs.EMAIL1;
// else
// mailto = mailto + ";" + opbs.EMAIL1;
// }
//}
//if (mailto != "")
//{
// var j = 0;
// var filepath = "";
// var doclist = ReceiptDocDAL.GetDocList("BSNO='" + headData.BSNO + "'", " MODIFIEDTIME DESC ");
// foreach (var doc in doclist)
// {
// if (j == 0)
// {
// filepath = doc.Driect_URL;
// }
// j = j = 1;
// }
// result = MsSeaeOrderDAL.SendMailWithFile(mailtitle, Body.ToString(), filepath, mailto, Convert.ToString(Session["SHOWNAME"]));
//}
result = MsSeaeOrderDAL.MsSeaeOrderDAL.SendMailWithFile(mailtitle, Body.ToString(), head.MAILPDFURL, mailto, head.SENDER);
result.OK("发送成功");
}
catch (Exception e)
{
result.Success = false;
result.Message = e.Message;
}
return result;
}
#endregion
}
}