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 3
Badge

Hi @jinin ,

It’s working thank you.

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 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 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 7
Badge +11

Can you share the response sample as well?

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

Hi @jeewanishalika20 

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

 

 

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