Пример #1
0
    public static void SendSms(string cellNo, string taxrefNo, string year, string message)
    {
        var correspondance = new CorrespondenceManagementRequestStructure
        {
            RequestOperation = RequestOperation.ISSUE_CORRESPONDENCE,
            OutChannel       = CorrespondenceManagementRequestStructureOutChannel.SMS,
            SMS = new CorrespondenceManagementRequestStructureSMS
            {
                CellularNos = new[] { cellNo },
                Message     = message
            }
        };

        var messageId   = Guid.NewGuid();
        var corXml      = Sars.Systems.Serialization.XmlObjectSerializer.GetXmlWithNoDeclaration(correspondance);
        var soapMessage = FdrCommon.CreateSoapSms(corXml, taxrefNo, messageId.ToString());

        soapMessage = FdrCommon.FormatXml(soapMessage);
        var queueInfo = new QueueInfo
        {
            Manager        = MQConfigurationSettings.CorrespondenceOutQManagerName,
            Channel        = MQConfigurationSettings.CorrespondenceOutQChannelName,
            UseManagerName = false,
            Port           = MQConfigurationSettings.CorrespondenceOutPortNumber,
            HostName       = MQConfigurationSettings.CorrespondenceOutHostName,
            QueueName      = MQConfigurationSettings.CorrespondenceOutQName,
            CorrelationId  = messageId.ToString(),
            Message        = soapMessage
        };

        FdrMessaging.SendMessageToQueue(queueInfo);
    }
Пример #2
0
 protected void Page_Load(object sender, EventArgs e)
 {
     if (!IsPostBack)
     {
         var xml = DBReadManager.GetLetterXml(Request["Id"]);
         txtXml.SetValue(FdrCommon.FormatXml(xml));
     }
 }
Пример #3
0
    protected void Page_Load(object sender, EventArgs e)
    {
        var file = @"D:\SARS\Validate\IE_SCHEMA_VALIDATION4.txt";

        var cbcXml  = FdrCommon.FormatXml(File.ReadAllText(file));
        var _client = new ESBMessagingServiceClient("basic");

        var cbcSchemaVal = _client.ValidateSchema(Configurations.CbCValidationServiceID, cbcXml);

        _client.Close();
    }
Пример #4
0
    public static void SendLetter(string taxrefNo, string year)
    {
        var correspondance = new CorrespondenceManagementRequestStructure
        {
            RequestOperation = RequestOperation.ISSUE_CORRESPONDENCE,
            TaxRef           = new TaxRefStructure
            {
                TaxRefNo  = taxrefNo,
                TypeOfTax = TypeOfTaxType.INCOME_TAX
            },
            OutChannel = CorrespondenceManagementRequestStructureOutChannel.EFL,
            TaxYear    = year
        };

        //optional

        var letter = new CorrespondenceManagementRequestStructureLetter
        {
        };

        var ret = File.ReadAllBytes(@"D:\Rejection of Master Files and Local Files.pdf");

        letter.Content = Convert.ToBase64String(ret);

        var letters = new List <CorrespondenceManagementRequestStructureLetter>
        {
            letter
        };

        correspondance.Letters = letters.ToArray();

        var messageId   = Guid.NewGuid();
        var corXml      = Sars.Systems.Serialization.XmlObjectSerializer.GetXmlWithNoDeclaration(correspondance);
        var soapMessage = FdrCommon.CreateSoapLetter(corXml, taxrefNo, messageId.ToString());

        soapMessage = FdrCommon.FormatXml(soapMessage);
        var queueInfo = new QueueInfo
        {
            Manager        = MQConfigurationSettings.CorrespondenceOutQManagerName,
            Channel        = MQConfigurationSettings.CorrespondenceOutQChannelName,
            UseManagerName = false,
            Port           = MQConfigurationSettings.CorrespondenceOutPortNumber,
            HostName       = MQConfigurationSettings.CorrespondenceOutHostName,
            QueueName      = MQConfigurationSettings.CorrespondenceOutQName,
            CorrelationId  = messageId.ToString(),
            Message        = soapMessage
        };

        FdrMessaging.SendMessageToQueue(queueInfo);
    }
Пример #5
0
    public void SendEmail(string messageBody, string subject, string emailAddress, byte[] attachement, string fileName, string taxrefNo, int year)
    {
        if (!Configurations.SendToEmails)
        {
            return;
        }
        var correspondance = new CorrespondenceManagementRequestStructure
        {
            RequestOperation = RequestOperation.ISSUE_CORRESPONDENCE,
            OutChannel       = CorrespondenceManagementRequestStructureOutChannel.EMAIL,
            Email            = new CorrespondenceManagementRequestStructureEmail
            {
                ToAddresses = new[] { emailAddress },
                Body        = messageBody,
                Subject     = subject,
                Attachments = attachement == null?null: new CorrespondenceManagementRequestStructureEmailAttachment[1]
                {
                    new CorrespondenceManagementRequestStructureEmailAttachment
                    {
                        Content  = attachement,//FdrCommon.GetRejectionLetter("1"),
                        Type     = DocumentType.PDF,
                        Filename = string.Format("{0}.pdf", fileName)
                    }
                }
            }
        };
        var messageId   = Guid.NewGuid();
        var message     = Sars.Systems.Serialization.XmlObjectSerializer.GetXmlWithNoDeclaration(correspondance);
        var soapMessage = FdrCommon.CreateSoapEmail(message, emailAddress, messageId.ToString());

        soapMessage = FdrCommon.FormatXml(soapMessage);
        var queueInfo = new QueueInfo
        {
            Manager        = MQConfigurationSettings.CorrespondenceOutQManagerName,
            Channel        = MQConfigurationSettings.CorrespondenceOutQChannelName,
            UseManagerName = false,
            Port           = MQConfigurationSettings.CorrespondenceOutPortNumber,
            HostName       = MQConfigurationSettings.CorrespondenceOutHostName,
            QueueName      = MQConfigurationSettings.CorrespondenceOutQName,
            CorrelationId  = messageId.ToString(),
            Message        = soapMessage
        };

        FdrMessaging.SendMessageToQueue(queueInfo);
        DBWriteManager.SaveCorrespondanceTrail(messageId.ToString(), taxrefNo, year, soapMessage);
    }
Пример #6
0
    public void SendSms(string cellNo, string taxrefNo, string message, int year)
    {
        if (!Configurations.SendToSms)
        {
            return;
        }
        if (Convert.ToInt64(cellNo) == 0)
        {
            //MessageBox.Show(string.Format("SMS will not be sent to this number {0}", cellNo));
            return;
        }
        var correspondance = new CorrespondenceManagementRequestStructure
        {
            RequestOperation = RequestOperation.ISSUE_CORRESPONDENCE,
            OutChannel       = CorrespondenceManagementRequestStructureOutChannel.SMS,
            SMS = new CorrespondenceManagementRequestStructureSMS
            {
                CellularNos = new[] { cellNo },
                Message     = message
            }
        };

        var messageId   = Guid.NewGuid();
        var corXml      = XmlObjectSerializer.GetXmlWithNoDeclaration(correspondance);
        var soapMessage = FdrCommon.CreateSoapSms(corXml, taxrefNo, messageId.ToString());

        soapMessage = FdrCommon.FormatXml(soapMessage);
        var queueInfo = new QueueInfo
        {
            Manager        = MQConfigurationSettings.CorrespondenceOutQManagerName,
            Channel        = MQConfigurationSettings.CorrespondenceOutQChannelName,
            UseManagerName = false,
            Port           = MQConfigurationSettings.CorrespondenceOutPortNumber,
            HostName       = MQConfigurationSettings.CorrespondenceOutHostName,
            QueueName      = MQConfigurationSettings.CorrespondenceOutQName,
            CorrelationId  = messageId.ToString(),
            Message        = soapMessage
        };

        FdrMessaging.SendMessageToQueue(queueInfo);
        DBWriteManager.SaveCorrespondanceTrail(messageId.ToString(), taxrefNo, year, soapMessage);
    }
    private static string CreateXml(string header, Sars.ESBSchema.ApplicationInformation.v31.ApplicationInformationStructure appInfo, string body)
    {
        //var applicationInformationStructure = new Sars.ESBSchema.ApplicationInformation.v31.ApplicationInformationStructure
        //{
        //    ApplicationInformationResult = new Sars.ESBSchema.ApplicationInformation.v31.ApplicationInformationStructureApplicationInformationResult[1]
        //};
        //applicationInformationStructure.ApplicationInformationResult[0] =
        //    new Sars.ESBSchema.ApplicationInformation.v31.ApplicationInformationStructureApplicationInformationResult
        //    {
        //        Code = "0000",
        //        Description = "Processed",
        //        MessageType = Sars.ESBSchema.ApplicationInformation.v31.MessageTypeEnum.INFORMATION
        //    };

        var applicationInformationStructureXml = Sars.Systems.Serialization.XmlObjectSerializer.GetXmlWithNoDeclaration(appInfo, "fdri", "http://www.egovernment.gov.za/GMD/ApplicationInformation/xml/schemas/version/3.1");

        var xmlBuilder = new StringBuilder();

        xmlBuilder.Append(
            "<?xml version=\"1.0\" encoding=\"ISO-8859-1\"?> " +
            "<soap12:Envelope xmlns:soap12=\"http://www.w3.org/2003/05/soap-envelope\" " +
            "xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\" " +
            "xmlns:esb=\"http://www.egovernment.gov.za/GMD/MessageIdentification/xml/schemas/version/7.1\">"

            );
        xmlBuilder.AppendFormat(
            "{0}" +
            " <soap12:Body>" +
            "{1}" +
            "{2}" +
            "</soap12:Body>" +
            "</soap12:Envelope>",
            header,
            applicationInformationStructureXml,
            body
            );
        return(FdrCommon.FormatXml(xmlBuilder.ToString()));
    }
Пример #8
0
    public string GetTaxpayerRegistrationData(string taxRefNo)
    {
        var reg = new RegistrationManagementRequestStructure
        {
            RequestOperation = RegistrationManagementRequestStructureRequestOperation.RETRIEVE_ENTITY_DETAILS,
            PartyIdentifiers = new[]
            {
                new RegistrationManagementRequestStructurePartyIdentifier
                {
                    IdentifierType = "REFERENCE_NO",
                    Value          = taxRefNo
                }
            }
        };
        var messageId   = Guid.NewGuid();
        var corXml      = Sars.Systems.Serialization.XmlObjectSerializer.GetXmlWithNoDeclaration(reg);
        var soapMessage = FdrCommon.CreateSoapRegistrationQuery(corXml, taxRefNo, messageId.ToString());

        soapMessage = FdrCommon.FormatXml(soapMessage);

        var queueInfo = new QueueInfo
        {
            Manager        = MQConfigurationSettings.RegistrationOutQManagerName,
            Channel        = MQConfigurationSettings.RegistrationOutQChannelName,
            UseManagerName = false,
            Port           = MQConfigurationSettings.RegistrationOutPortNumber,
            HostName       = MQConfigurationSettings.RegistrationOutHostName,
            QueueName      = MQConfigurationSettings.RegistrationOutQName,
            CorrelationId  = messageId.ToString(),
            Message        = soapMessage
        };

        FdrMessaging.SendMessageToQueue(queueInfo);

        return(messageId.ToString());
    }
Пример #9
0
    protected void Page_Load(object sender, EventArgs e)
    {
        var uid    = Request["uid"].ToUpper();
        var source = Request["src"].ToUpper();

        if (string.IsNullOrEmpty(uid) || string.IsNullOrEmpty(source))
        {
            Response.Write("PARAMETER MISSING");
            return;
        }

        Guid guid;

        if (!Guid.TryParse(uid, out guid))
        {
            Response.Write("UID PARAMETER IN NOT VALID");
            return;
        }
        var procedureName = string.Empty;

        switch (source)
        {
        case "IN":
        {
            procedureName = "usp_READ_ReportXml_IN";
            break;
        }

        case "OUT":
        {
            procedureName = "usp_READ_ReportXml_OUT";
            break;
        }

        case "MNE":
        {
            procedureName = "usp_READ_ReportXml_MNE";
            break;
        }

        default:
        {
            procedureName = null;
            break;
        }
        }
        if (string.IsNullOrEmpty(procedureName))
        {
            MessageBox.Show("PROCEDURE NAME IS NOT VALID");
            return;
        }
        var recordSet = new RecordSet(procedureName, QueryType.StoredProcedure, new DBParamCollection {
            { "@UID", guid.ToString() }
        });

        if (!recordSet.HasRows)
        {
            MessageBox.Show("THER IS NO DATA AVAILABLE"); return;
        }

        var xmlData = recordSet[0][0].ToString();
        var cbcXml  = "";

        if (source.Equals("MNE", StringComparison.CurrentCultureIgnoreCase))
        {
            var doc = new XmlDocument();
            doc.LoadXml(xmlData);
            var cbCXmlNodeList = doc.GetElementsByTagName("CBC_OECD", "*");
            if (cbCXmlNodeList.Count > 0)
            {
                cbcXml = cbCXmlNodeList[0].OuterXml;
            }
        }
        else
        {
            cbcXml = xmlData;
        }

        var client = new ESBMessagingServiceClient("basic");

        //cbcXml = File.ReadAllText(@"D:\FDR\Report\CBC_OUT_KR.xml");
        cbcXml = FdrCommon.FormatXml(cbcXml);
        var cbcSchemaVal = client.ValidateSchema(Configurations.CbCValidationServiceID, cbcXml);

        if (!cbcSchemaVal.IsValid)
        {
            return;
        }
        cbcXml = cbcXml.Replace("<CBC_OECD>", "<CBC_OECD xmlns=\"urn:oecd:ties:cbc:v1\">");
        cbcXml = FdrCommon.FormatXml(cbcXml);
        var cbcMessage = XmlObjectSerializer.ConvertXmlToObject <CBC_OECD>(cbcXml);

        if (cbcMessage == null)
        {
            return;
        }

        var overAllReport = new StringBuilder();

        overAllReport.Append(CreateMessageSpec(cbcMessage));

        foreach (var cbcBody in cbcMessage.CbcBody)
        {
            var reportingEntity           = cbcBody.ReportingEntity;
            var reportingEntityHeader     = CreateReportingEntityHeader();
            var reportingEntityRowAndData = CreateReportingEntityRowAndData(reportingEntity);
            if (cbcBody.CbcReports != null && cbcBody.CbcReports.Any())
            {
                reportingEntityRowAndData.AppendFormat("<tr><td {0}></td><td colspan=\"11\">", GetColumnAttributes());
                var cbcReportHeaderRow = CreatCbCReportHeader();
                var cbcReportDataRows  = CreateCbCReportRowsAndData(cbcBody);
                reportingEntityRowAndData.AppendFormat("<table width=\"100%\">{0}{1}</table></td></tr>", cbcReportHeaderRow, cbcReportDataRows);
            }
            overAllReport.Append(reportingEntityHeader);
            overAllReport.Append(reportingEntityRowAndData);

            //if (cbcBody.AdditionalInfo != null && cbcBody.AdditionalInfo.Any())
            //{
            //    var additionalInfoHeaderRow = CreatAdditionalInfoHeader();
            //    var additionalInfoDataRow = new StringBuilder();
            //    foreach (var infoType in cbcBody.AdditionalInfo)
            //    {
            //        additionalInfoDataRow.Append(CreatAdditionalInfoRowAndData(infoType));
            //    }

            //    overAllReport.AppendFormat("<table width=\"100%\">{0}{1}</table></td></tr>", additionalInfoHeaderRow, additionalInfoDataRow);
            //}
        }
        overAllReport.Append("</table></div>");
        Export(overAllReport);
    }
Пример #10
0
    public XmlElement EnquireRegistration(string taxRefNo)
    {
        var reg = new RegistrationManagementRequestStructure
        {
            RequestOperation = RegistrationManagementRequestStructureRequestOperation.RETRIEVE_ENTITY_DETAILS,
            PartyIdentifiers = new[]
            {
                new RegistrationManagementRequestStructurePartyIdentifier
                {
                    IdentifierType = "REFERENCE_NO",
                    Value          = taxRefNo
                }
            }
        };
        var doc         = new XmlDocument();
        var messageId   = Guid.NewGuid();
        var corXml      = XmlObjectSerializer.GetXmlWithNoDeclaration(reg);
        var soapMessage = FdrCommon.CreateSoapRegistrationQuery(corXml, taxRefNo, messageId.ToString());

        soapMessage = FdrCommon.FormatXml(soapMessage);
        var queueInfo = new QueueInfo {
            Manager        = MQConfigurationSettings.RegistrationOutQManagerName,
            Channel        = MQConfigurationSettings.RegistrationOutQChannelName,
            UseManagerName = false,
            Port           = MQConfigurationSettings.RegistrationOutPortNumber,
            HostName       = MQConfigurationSettings.RegistrationOutHostName,
            QueueName      = MQConfigurationSettings.RegistrationOutQName,
            CorrelationId  = messageId.ToString(),
            Message        = soapMessage
        };
        var message = string.Empty;

        FdrMessaging.SendMessageToQueue(queueInfo);
        Thread.Sleep(1);
        var data = DBReadManager.GetResponse(messageId.ToString());
        var i    = 1;

        while (!data.HasRows && i <= Configurations.QueueResponseTime)
        {
            Thread.Sleep(1);
            i++;
            data = DBReadManager.GetResponse(messageId.ToString());
        }
        if (!data.HasRows && i >= Configurations.QueueResponseTime)
        {
            doc.LoadXml(string.Format("<Errors><Error message=\"{0}\" /></Errors>", Configurations.QueueTimeoutMessage));
            return(doc.DocumentElement);
        }
        if (string.IsNullOrEmpty(message))
        {
            if (Convert.ToInt32(data[0]["ReturnCode"]) != 0)
            {
                message = data[0]["ReturnMessage"].ToString();
                doc.LoadXml(string.Format("<Errors><Error message=\"{0}\" /></Errors>", message));
                return(doc.DocumentElement);
            }
        }
        var xml = data[0]["Message"].ToString();

        doc.LoadXml(xml);
        return(doc.DocumentElement);
    }
Пример #11
0
    public void SendLetter(decimal submissionId, string taxrefNo, int year, string letterContent, string letterHead, bool isAcceptance, string userSid)
    {
        if (!Configurations.SendToEfiling)
        {
            return;
        }
        var currentUser = Sars.Systems.Security.ADUser.CurrentUser;

        if (currentUser == null)
        {
            return;
        }
        var correspondance = new CorrespondenceManagementRequestStructure {
            OutChannel       = CorrespondenceManagementRequestStructureOutChannel.EFL,
            RequestOperation = RequestOperation.ISSUE_CORRESPONDENCE,
            TaxRef           = new TaxRefStructure {
                TaxRefNo  = taxrefNo,
                TypeOfTax = TypeOfTaxType.INCOME_TAX
            },
            TaxYear = year.ToString()
        };
        RegistrationQueryDetails registration = null;

        try{
            registration = new RegistrationQueryDetails();
            registration.LookUpRegistrationDetails(taxrefNo);
            if (!registration.DetailsFound)
            {
                MessageBox.Show(registration.Message);
                return;
            }
        }
        catch (Exception) {
        }
        if (registration == null)
        {
            return;
        }

        if (!registration.DetailsFound)
        {
            MessageBox.Show(string.Format("Letter could not be sent because FDR could not get registration details for the number {0} \n U3TM reason : {1}", taxrefNo, registration.Message));
            return;
        }
        if (registration.PreferredAddress == null)
        {
            MessageBox.Show("Letter could not be sent because FDR could not get registration address.");
            return;
        }
        var sarsSysgenltr = new SARS_SYSGENLTR {
            ADDRESSEE_DETAILS = new SARS_SYSGENLTRADDRESSEE_DETAILS {
                //ADDRESS_FIELD_F001 = "What is Here",
                //ADDRESS_FIELD_F002 = "Pretoria",
                //ADDRESS_FIELD_F003 = "299 Bronkhorst street",
                //ADDRESS_FIELD_F004 = "QA TESTING",
                //ADDRESS_FIELD_F005 = "Brooklyn",
                //ADDRESS_FIELD_F006 = "2000",
                //ADDRESS_FIELD_F007 = ""

                ADDRESS_FIELD_F001 = registration.RegistrationName,
                ADDRESS_FIELD_F002 = "",
                ADDRESS_FIELD_F003 = string.Format("{0} {1}", registration.PreferredAddress.StreetNo, registration.PreferredAddress.StreetName),
                ADDRESS_FIELD_F004 = registration.PreferredAddress.Suburb,
                ADDRESS_FIELD_F005 = registration.PreferredAddress.City,
                ADDRESS_FIELD_F006 = registration.PreferredAddress.PostalCode,
                ADDRESS_FIELD_F007 = ""
            },
            FORM_INFORMATION = new FORM_INFORMATION {
                FORM_ID = "CBC_LET_GEN",
                GUID    = new GlobalUniqueIDStructure {
                    UniqueIdentifier = Guid.NewGuid().ToString()
                },
                TIMESTAMP   = DateTime.Now,
                TAX_REF_NO  = taxrefNo,
                TAX_YEAR    = year.ToString(),
                LANGUAGE    = "english",
                FORM_TYPE   = isAcceptance ? "CBCACC" : "CBCREJ",
                CASE_NUMBER = string.Empty
            },
            CONTACT_DETAILS = new SARS_SYSGENLTRCONTACT_DETAILS {
                HeaderLabel        = "Contact Detail",
                ADDRESS_CD01       = "SARS Head Office",
                TEL_NO_CD02        = currentUser.Telephone,
                WEB_ADDRESS_CD03   = "SARS online: www.sars.gov.za",
                TOLL_FREE_NO_CD04  = "",
                FAX_NO_CD05        = "",
                EMAIL_ADDRESS_CD06 = currentUser.Name
            },
            LETTER_CONTENT = new SARS_SYSGENLTRLETTER_CONTENT {
                CONTENT = letterContent.Replace(Environment.NewLine, "")
            },
            DETAILS = new SARS_SYSGENLTRDETAILS {
                TAXREF_NO = new SARS_SYSGENLTRDETAILSTAXREF_NO {
                    TAXREF_FIELD_F004 = taxrefNo,
                    TAXREF_LABEL_L003 = "Tax Reference No.:"
                },
                DATE = new SARS_SYSGENLTRDETAILSDATE {
                    DATE_LABEL_L008 = "Date:",
                    DATE_FIELD_F009 = DateTime.Now.ToString("yyyy-MM-dd")
                },
                ENQUIRY_NOTE = new SARS_SYSGENLTRDETAILSENQUIRY_NOTE {
                    NOTE_LABEL_L005 = "Always quote this reference number when contacting SARS"
                }
            },
            LETTER_HEADER = new SARS_SYSGENLTRLETTER_HEADER
            {
                LETTER_HEADER_LABEL = letterHead
            },
            LETTER_NAME_HEADER = new SARS_SYSGENLTRLETTER_NAME_HEADER {
                LETTER_NAME = string.Empty //letterHead.ToUpper()
            }
            //,
            //Paragraphs = new string[2]
            //{
            //    "Paragraph 1",
            //    "Paragraph 2"
            //},
        };

        var letterDetails = Sars.Systems.Serialization.XmlObjectSerializer.GetXmlWithNoDeclaration(sarsSysgenltr, "SARS", "http://www.sars.gov.za/forms/").Replace(Environment.NewLine, "");
        var letters       = new List <CorrespondenceManagementRequestStructureLetter> {
            new CorrespondenceManagementRequestStructureLetter {
                Content         = string.Format("<![CDATA[{0}]]>", letterDetails),
                TemplateDetails = new TemplateDetailsStructure {
                    Language = LanguageType.ENGLISH,
                    Name     = "SARS_SysGenOutLet_RO_E_v2012.01.05"
                },
                Type = isAcceptance ? "CBCACC" : "CBCREJ"
            }
        };

        correspondance.Letters = letters.ToArray();
        var messageId   = Guid.NewGuid();
        var corXml      = XmlObjectSerializer.GetXmlWithNoDeclaration(correspondance);
        var soapMessage = FdrCommon.CreateSoapLetter(corXml, taxrefNo, messageId.ToString());

        soapMessage = FdrCommon.FormatXml(soapMessage).Replace("&lt;", "<").Replace("&gt;", ">").Replace("&amp;lt;", "<").Replace("&amp;gt;", ">");
        var queueInfo = new QueueInfo {
            Manager        = MQConfigurationSettings.CorrespondenceOutQManagerName,
            Channel        = MQConfigurationSettings.CorrespondenceOutQChannelName,
            UseManagerName = false,
            Port           = MQConfigurationSettings.CorrespondenceOutPortNumber,
            HostName       = MQConfigurationSettings.CorrespondenceOutHostName,
            QueueName      = MQConfigurationSettings.CorrespondenceOutQName,
            CorrelationId  = messageId.ToString(),
            Message        = soapMessage
        };

        FdrMessaging.SendMessageToQueue(queueInfo);
        DBWriteManager.SaveLetter(submissionId, soapMessage, taxrefNo, year, userSid);
        DBWriteManager.SaveCorrespondanceTrail(messageId.ToString(), taxrefNo, year);
    }