Solved

Json string error in acumatica sales order screen

  • 14 July 2023
  • 7 replies
  • 68 views

Userlevel 3
Badge

Hi,

I have a third party rest api to get bank details. 

When calling the API it response is json format.

When I click the ADD Order Button I need to add response statusDesc with sales order descirption field.

public PXAction<SOOrder> MyAction;
[PXUIField(DisplayName = "ADD ORDER", MapEnableRights = PXCacheRights.Select, MapViewRights = PXCacheRights.Select)]
[PXButton(CommitChanges = true)]
public virtual IEnumerable myAction(PXAdapter adapter)
{
var URL = "https://sandbox.corporate-api.hsbc.com/mock/v2/transactions";
var httpRequest = (HttpWebRequest)WebRequest.Create(URL);
httpRequest.Method = "POST";
httpRequest.ContentLength = 0;

//IRestResponse response = client.Execute(httpRequest);
var httpResponse = (HttpWebResponse)httpRequest.GetResponse();
//string responseBody = httpResponse.Content.ReadAsStringAsync();

SOOrder order = Base.Document.Current;
//order.OrderDesc = httpResponse.ContentType.ToString();

// Obtain a 'Stream' object associated with the response object.
Stream ReceiveStream = httpResponse.GetResponseStream();

Encoding encode = System.Text.Encoding.GetEncoding("utf-8");

// Pipe the stream to a higher level stream reader with the required encoding format.
StreamReader readStream = new StreamReader(ReceiveStream, encode);
Console.WriteLine("\nResponse stream received");
Char[] read = new Char[2560000];

// Read 256 charcters at a time.
int count = readStream.Read(read, 0, 2560000);
String str = new String(read, 0, count);


var myDetails = JsonConvert.DeserializeObject < MyDetail > (str);

order.OrderDesc = myDetails.statusDesc;



return adapter.Get();

}

But,When clicking the button below error is shown.

 

icon

Best answer by jinin 16 July 2023, 16:31

View original

7 replies

Userlevel 7
Badge +11

Hi @jeewanishalika20 

Could you please share the response you have received and the class template (MyDetail) for me to review?

 

 

Userlevel 3
Badge

Hi @jinin ,

public class MyDetail
{
    public string referenceId {
        get;
        set;
    }
    public string profileId {
        get;
        set;
    }
    public string statusCode {
        get;
        set;
    }
    public string statusDesc {
        get;
        set;
    }
    public string reportBase64 {
        get;
        set;
    }
    
}

Userlevel 7
Badge +11

Can you share the response sample as well?

Userlevel 3
Badge

hi @jinin ,

This is the response

{
"referenceId": "b7e0fdacd8bd",
"profileId": "PC12345678",
"statusCode": "ACCP",
"statusDesc": "Account transactions report generated successfully.",
"reportBase64": "<?xml version="1.0" encoding="UTF-8"?>
<!-- Sample XML file generated by FFFS (www.fkl.fi) B2C project for FInnish Account Report, 2009-11-02, for different Entry instance for -->
<!-- MT210 / Prenotice of incoming inter national transaction (without balances) and one simple intra day balance report with one transaction-->
<Document xmlns="urn:iso:std:iso:20022:tech:xsd:camt.052.001.02" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="urn:iso:std:iso:20022:tech:xsd:camt.052.001.02
camt.052.001.02.xsd">
	<BkToCstmrAcctRpt>
		<GrpHdr>
			<MsgId>BANKFILEID219073</MsgId>
			<CreDtTm>2009-10-30T12:01:45+02:00</CreDtTm>
			<MsgRcpt>
				<Id>
					<OrgId>
						<Othr>
							<Id>123456789</Id>
							<SchmeNm>
								<Cd>BANK</Cd>
							</SchmeNm>
						</Othr>
					</OrgId>
				</Id>
			</MsgRcpt>
			<AddtlInf>Some additional message-specific info can be delivered from bank to customer here</AddtlInf>
		</GrpHdr>
		<!-- First Report with prenotice of incoming transaction separately in its onw report with no balances-->
		<Rpt>
			<Id>BANKFILEID00001NTR00001</Id>
			<!-- Electronic Sequence Number is optional per bank -->
			<ElctrncSeqNb>196</ElctrncSeqNb>
			<CreDtTm>2009-10-30T12:01:45+02:00</CreDtTm>
			<Acct>
				<Id>
					<IBAN>FI7433010001222090</IBAN>
				</Id>
				<Tp>
					<Cd>CACC</Cd>
				</Tp>
				<Ccy>EUR</Ccy>
				<Nm>Account name</Nm>
				<Ownr>
					<Nm>BANK ACCOUNT OWNER</Nm>
					<Id>
						<OrgId>
							<Othr>
								<Id>123456789</Id>
								<SchmeNm>
									<Cd>CUST</Cd>
								</SchmeNm>
							</Othr>
						</OrgId>
					</Id>
				</Ownr>
				<Svcr>
					<FinInstnId>
						<BIC>ESSEFIHX</BIC>
					</FinInstnId>
				</Svcr>
			</Acct>
			<!-- -->
			<TxsSummry>
				<TtlNtries>
					<NbOfNtries>1</NbOfNtries>
					<Sum>2120.00</Sum>
					<TtlNetNtryAmt>2120.00</TtlNetNtryAmt>
					<CdtDbtInd>CRDT</CdtDbtInd>
				</TtlNtries>
			</TxsSummry>
			<Ntry>
				<!-- As Account Servicer Reference is not yet available, NtryRef refers to prenotice SWIFT message -->
				<NtryRef>21892819</NtryRef>
				<Amt Ccy="EUR">2120.00</Amt>
				<CdtDbtInd>CRDT</CdtDbtInd>
				<Sts>PDNG</Sts>
				<BookgDt>
					<Dt>2009-11-02</Dt>
				</BookgDt>
				<ValDt>
					<Dt>2009-11-03</Dt>
				</ValDt>
				<BkTxCd>
					<Domn>
						<Cd>PMNT</Cd>
						<Fmly>
							<Cd>RCDT</Cd>
							<SubFmlyCd>XBCT</SubFmlyCd>
						</Fmly>
					</Domn>
				</BkTxCd>
				<NtryDtls>
					<TxDtls>
						<Refs>
							<!-- Reference used by the Debtor banks-->
							<InstrId>ISSRBKREF12345678</InstrId>
							<TxId>21892819</TxId>
						</Refs>
						<AmtDtls>
							<InstdAmt>
								<Amt Ccy="USD">3200.00</Amt>
								<CcyXchg>
									<SrcCcy>USD</SrcCcy>
									<TrgtCcy>EUR</TrgtCcy>
									<UnitCcy>EUR</UnitCcy>
									<XchgRate>0.666667</XchgRate>
									<!-- May differ in final booking -->
									<QtnDt>2009-10-30T10:00:00+02:00</QtnDt>
								</CcyXchg>
							</InstdAmt>
							<TxAmt>
								<Amt Ccy="EUR">2120.00</Amt>
							</TxAmt>
							<!-- Optional
							<CntrValAmt>
								<Amt Ccy="USD">3200.00</Amt>
								<CcyXchg>
									<SrcCcy>USD</SrcCcy>
									<TrgtCcy>EUR</TrgtCcy>
									<UnitCcy>EUR</UnitCcy>
									<XchgRate>0.666667</XchgRate>
									<QtnDt>2009-10-30T10:00:00+02:00</QtnDt>
								</CcyXchg>
							</CntrValAmt>
							-->
						</AmtDtls>
						<RltdPties>
							<Dbtr>
								<Nm>DEBTOR NAME</Nm>
								<Id>
									<OrgId>
										<Othr>
											<Id>123456789</Id>
											<SchmeNm>
												<Cd>DUNS</Cd>
											</SchmeNm>
										</Othr>
									</OrgId>
								</Id>
							</Dbtr>
						</RltdPties>
						<RltdAgts>
							<DbtrAgt>
								<FinInstnId>
									<BIC>BOFAUS6H</BIC>
								</FinInstnId>
							</DbtrAgt>
						</RltdAgts>
						<RmtInf>
							<Ustrd>INVOICE US20291092</Ustrd>
						</RmtInf>
					</TxDtls>
				</NtryDtls>
			</Ntry>
		</Rpt>
		<!-- Second Report with one booked intra-day transaction with inter -->
		<Rpt>
			<Id>BANKRPTID1972009</Id>
			<ElctrncSeqNb>197</ElctrncSeqNb>
			<CreDtTm>2009-10-30T12:00:00+02:00</CreDtTm>
			<FrToDt>
				<!-- Times also sepcified to indicate transaction report time limits within day -->
				<FrDtTm>2009-10-30T10:00:00+02:00</FrDtTm>
				<ToDtTm>2009-10-30T12:00:00+02:00</ToDtTm>
			</FrToDt>
			<Acct>
				<Id>
					<IBAN>FI7433010001222090</IBAN>
				</Id>
				<Tp>
					<Cd>CACC</Cd>
				</Tp>
				<Ccy>EUR</Ccy>
				<Ownr>
					<Nm>BANK ACCOUNT OWNER</Nm>
					<PstlAdr>
						<StrtNm>HELSINGINKATU</StrtNm>
						<BldgNb>31</BldgNb>
						<PstCd>00100</PstCd>
						<TwnNm>HELSINKI</TwnNm>
						<Ctry>FI</Ctry>
					</PstlAdr>
					<Id>
						<OrgId>
							<Othr>
								<Id>12345678901</Id>
								<SchmeNm>
									<Cd>BANK</Cd>
								</SchmeNm>
							</Othr>
						</OrgId>
					</Id>
				</Ownr>
				<Svcr>
					<FinInstnId>
						<BIC>ESSEFIHX</BIC>
					</FinInstnId>
				</Svcr>
			</Acct>
			<RltdAcct>
				<Id>
					<IBAN>FI1533010001911270</IBAN>
				</Id>
				<Ccy>EUR</Ccy>
			</RltdAcct>
			<Bal>
				<!-- "Opening balance" as interim booked on specific time of intra-day.  May be also OPBD if it is really Opening Booked Balance for the reporting day -->
				<Tp>
					<CdOrPrtry>
						<Cd>ITBD</Cd>
					</CdOrPrtry>
				</Tp>
				<CdtLine>
					<Incl>false</Incl>
					<Amt Ccy="EUR">1000.00</Amt>
				</CdtLine>
				<Amt Ccy="EUR">1000.00</Amt>
				<CdtDbtInd>CRDT</CdtDbtInd>
				<Dt>
					<DtTm>2009-10-30T10:00:00+02:00</DtTm>
				</Dt>
			</Bal>
			<Bal>
				<!-- "Closing balance" as interim booked on specific time of intra-day.  -->
				<Tp>
					<CdOrPrtry>
						<Cd>ITBD</Cd>
					</CdOrPrtry>
				</Tp>
				<CdtLine>
					<Incl>false</Incl>
					<Amt Ccy="EUR">1100.00</Amt>
				</CdtLine>
				<Amt Ccy="EUR">1100.00</Amt>
				<CdtDbtInd>CRDT</CdtDbtInd>
				<Dt>
					<DtTm>2009-10-30T12:00:00+02:00</DtTm>
				</Dt>
			</Bal>
			<TxsSummry>
				<TtlNtries>
					<NbOfNtries>1</NbOfNtries>
				</TtlNtries>
				<TtlCdtNtries>
					<NbOfNtries>1</NbOfNtries>
					<Sum>100.00</Sum>
				</TtlCdtNtries>
			</TxsSummry>
			<!--Transaction 1/ Single incoming SCT-->
			<Ntry>
				<Amt Ccy="EUR">100.00</Amt>
				<CdtDbtInd>CRDT</CdtDbtInd>
				<Sts>BOOK</Sts>
				<!-- Time with Booking Date to give info of booking event on bank ledger -->
				<BookgDt>
					<DtTm>2009-10-30T11:00:00+02:00</DtTm>
				</BookgDt>
				<ValDt>
					<Dt>2009-10-30</Dt>
				</ValDt>
				<AcctSvcrRef>091029ACCTSTMTARCH08</AcctSvcrRef>
				<BkTxCd>
					<Domn>
						<Cd>PMNT</Cd>
						<Fmly>
							<Cd>RCDT</Cd>
							<SubFmlyCd>ESCT</SubFmlyCd>
						</Fmly>
					</Domn>
				</BkTxCd>
				<NtryDtls>
					<TxDtls>
						<Refs>
							<EndToEndId>EndToEndIdSCT01</EndToEndId>
						</Refs>
						<AmtDtls>
							<TxAmt>
								<Amt Ccy="EUR">100.00</Amt>
							</TxAmt>
						</AmtDtls>
						<RltdPties>
							<Dbtr>
								<Nm>DEBTOR</Nm>
							</Dbtr>
							<UltmtDbtr>
								<Nm>ULTIMATE DEBTOR</Nm>
								<Id>
									<OrgId>
										<Othr>
											<Id>987654321</Id>
											<SchmeNm>
												<Cd>TXID</Cd>
											</SchmeNm>
										</Othr>
									</OrgId>
								</Id>
							</UltmtDbtr>
						</RltdPties>
						<RltdAgts>
							<DbtrAgt>
								<FinInstnId>
									<BIC>NDEAFIHH</BIC>
								</FinInstnId>
							</DbtrAgt>
						</RltdAgts>
						<Purp>
							<Cd>TREA</Cd>
						</Purp>
						<RmtInf>
							<Strd>
								<CdtrRefInf>
									<Tp>
										<CdOrPrtry>
											<Cd>SCOR</Cd>
										</CdOrPrtry>
										<Issr>ISO</Issr>
									</Tp>
									<Ref>RF98123456789012</Ref>
								</CdtrRefInf>
							</Strd>
						</RmtInf>
						<RltdDts>
							<AccptncDtTm>2009-10-28T03:00:00+02:00</AccptncDtTm>
						</RltdDts>
					</TxDtls>
				</NtryDtls>
			</Ntry>
		</Rpt>
	</BkToCstmrAcctRpt>
</Document>
"
}

 

Userlevel 6
Badge +3

What happens if you try to use HttpClient? It is in System.Net.Http.dll.

var httpClient = new HttpClient();
var res = httpClient.PostAsync(new Uri("url"), new StringContent("")/*request body*/ ).Result.Content.ReadAsStringAsync().Result;
var myDetail = JsonConvert.DeserializeObject<MyDetail>(res);

 

Userlevel 7
Badge +11

Hi @jeewanishalika20 ,

Refer to the below code. It's working fine for me.

 public PXAction<SOOrder> MyAction;
        [PXUIField(DisplayName = "ADD ORDER", MapEnableRights = PXCacheRights.Select, MapViewRights = PXCacheRights.Select)]
        [PXButton(CommitChanges = true)]
        public virtual IEnumerable myAction(PXAdapter adapter)
        {
            var URL = "https://sandbox.corporate-api.hsbc.com/mock/v2/transactions";
            var httpRequest = (HttpWebRequest)WebRequest.Create(URL);
            httpRequest.Method = "POST";
            httpRequest.ContentLength = 0;
            var httpResponse = (HttpWebResponse)httpRequest.GetResponse();

            SOOrder order = Base.Document.Current;

            using (var streamReader = new StreamReader(httpResponse.GetResponseStream()))
            {
                var responseText = streamReader.ReadToEnd();
                var responseJson = JsonConvert.DeserializeObject(responseText);

                var myDetails = JsonConvert.DeserializeObject<MyDetail>(responseJson.ToString());
                order.OrderDesc = myDetails.statusDesc;
                Base.Document.Update(order);
            }

            return adapter.Get();
        }



 

 public class MyDetail
    {
        public string referenceId
        {
            get;
            set;
        }
        public string profileId
        {
            get;
            set;
        }
        public string statusCode
        {
            get;
            set;
        }
        public string statusDesc
        {
            get;
            set;
        }

    }

Userlevel 3
Badge

Hi @jinin ,

It’s working thank you.

Reply


About Acumatica ERP system
Acumatica Cloud ERP provides the best business management solution for transforming your company to thrive in the new digital economy. Built on a future-proof platform with open architecture for rapid integrations, scalability, and ease of use, Acumatica delivers unparalleled value to small and midmarket organizations. Connected Business. Delivered.
© 2008 — 2024  Acumatica, Inc. All rights reserved