Developer Programs

Learn

Docs
Important notification about upcoming changes to the DMZ environment. Please read.

Tax Plan Inquiry

Enterprise SOAP API > API by Reference > Core Services > Tax Plan Inquiry

Tax Plan Inquiry

Tax Plan Inquiry is a jXchange service designed to obtain detail values for a specific tax plan from a service provider, such as distributions, beneficiaries, fees, etc.

Message Flow

In jXchange, the Tax Plan Inquiry service uses a typical exchange of MType messages to obtain detail values for a specific tax plan on a service provider.

Primary Request

The third-party consumer forwards the TaxPlnInqRq_MType message to the service provider.

The message contains the following simple elements:

  • ActIntent
  • CustId
  • PlnCode

The message contains the following complex elements:

  • AccountId_CType
  • Custom_CType
  • MsgRqHdr_CType

The message contains the following array:

  • IncXtendElemArray_AType

If the optional PlnType element is included with one of its required canonical values, only details of the plans corresponding to that canonical value is returned.

Primary Response

The service provider returns the TaxPlnInqRs_MType message to the third-party consumer.

The message contains the following simple elements:

  • ActIntent
  • ActIntentKey
  • CustId
  • PlnCode

The message contains the following complex elements:

  • AccountId_CType
  • Custom_CType
  • MsgRsHdr_CType
  • PlnCustRec_CType
  • x_PlnTaxInfo_CType
  • x_TaxPlnDist_CType

The elements returned detail the tax plan's values.

TaxPlnInqRq_MType

TaxPlnInqRq_MType is a message MType element. This is a major request complex that is optional.

Contains:

  • AccountId_CType
  • Custom_CType
  • IncXtendElemArray_AType
  • MsgRqHdr_CType

Simple Elements

The following simple elements are contained within this message.

ActIntent
Conveys the consumer intention for a subsequent operation for the data set included in the response. Canonical values are:
  • Dlt
  • ReadOnly
  • Upd

The default value is ReadOnly.

CustId
The identifier attached to a customer. It includes the OvrrdInstRtId attribute.
PlnCode
The service provider code that represents plan products for different plan types.

AccountId_CType

AccountId_CType is a complex CType element. This element contains the incoming account identification information and any restrictions.

Simple Elements

The following simple elements are contained within this complex.

AcctId
The number or character that identifies an account record.
AcctType
The number or character that categorizes the AcctId.
Rstr
The level of restrictions that can exist at a parent and/or child node. Canonical values are:
  • Hid
  • NoAccess
  • NoAccessPart
  • ReadOnly
  • ReadOnlyPart
  • ReadWrite
  • ReadWritePart

Custom_CType

Custom_CType is a complex CType element.

This element is optional.

IncXtendElemArray_AType

IncXtendElemArray_AType is an array AType element.

Contains:

  • IncXtendElemInfo_CType

IncXtendElemInfo_CType

IncXtendElemInfo_CType is a complex CType element.

Simple Elements

The following simple elements are contained within this complex.

XtendElem
Included extended elements. The consumer would ask by name for x_ prefix elements to be included in the response.

MsgRqHdr_CType

MsgRqHdr_CType is a complex CType element. This is the default message request header.

Contains:

  • AuthenUsrCred_CType
  • jXchangeHdr_CType

Simple Elements

The following simple elements are contained within this complex.

AuthenProdCred
Authentication of the Consumer Product Credentials in the form of a WS Security element that contains a single SAML V2.0 Assertion.

AuthenUsrCred_CType

AuthenUsrCred_CType is a complex CType element. This element represents authentication of the end-user credentials in the form of a WS Security element that contains a single SAML V2.0 Assertion.

Simple Elements

The following simple elements are contained within this complex.

Security
Defines the wsse:Security SOAP header element per section 4.

jXchangeHdr_CType

jXchangeHdr_CType is a complex CType element.

Simple Elements

The following simple elements are contained within this complex.

AuditUsrId
The user ID that the consumer would like written in the audit as performing the requested service. It varies, but it could be the same as the user ID. It is not used to authenticate. It is used to audit the Soap Header Fault.
AuditWsId
The workstation ID that the consumer would like written in the audit as performing the requested service for the Soap Header Fault. It varies, but it could be the same as the user ID.
AuthenUsrId
The user ID which the consumer would like the service provider to authenticate with for the Soap Header Fault. It is a user ID that the provider understands.

This element deprecates in accordance with XSD contract tenets. Effective date: 2017–01–01. The new complex element for user authentication credentials was added to both the Search Message Request Header SrchMsgRqHdr_CType and the Message Request Header MsgRqHdr_CType. AuthenUsrId is ignored by the service providers when the authentication user credentials AuthenUsrCred_CType package is delivered. The expectation is that the password credentials and the user name token are provided in the authentication user credential complex element in accordance with the standards established by WS-Security.

BusCorrelId
The correlation identification as related to business functions and activities.
ConsumerName
The name of the service consumer (business name) for the Soap Header Fault.
ConsumerProd
The name of the product which is consuming the service (business product name) for the Soap Header Fault.
InstEnv
An identification provided by the consumer that defines the environment in which the institution is operating. Canonical values are:
  • Prod
InstRtId
The identification of the entity of the submitted message. A financial institution entity uses the routing transit or nine-digit number assigned to financial institutions for routing as assigned by the American Bankers Association. Any leading zeros must be provided for a complete routing and transit number. A non-financial institution entity should use a mutually agreed upon identification that must contain at least one non-integer character. The canonical value is JHA.

The element is required in all message requests.

jXLogTrackingId
An identification provided by jXchange to be able to trace the request and response of a message from the third-party gateway, internal gateway, and service provider for the Soap Header Fault.
JxVer
Contains the version jXchange is running for the Soap Header Fault.
ValidConsmName
The consumer name that can be validated by enterprise governance. The canonical values are managed in a consumer/product enterprise table. The canonical value is: JHA.
ValidConsmProd
The consumer product name that can be validated by enterprise governance. The canonical values are managed in a consumer/product enterprise table.
WorkflowCorrelId
The correlation identification as related to workflow functions and activities.
jXchangeHdr_CType Deprecation Details
AuthenUsrId
The user ID which the consumer would like the service provider to authenticate with for the Soap Header Fault. It is a user ID that the provider understands.

This element deprecates in accordance with XSD contract tenets. Effective date: 2017–01–01. The new complex element for user authentication credentials was added to both the Search Message Request Header SrchMsgRqHdr_CType and the Message Request Header MsgRqHdr_CType. AuthenUsrId is ignored by the service providers when the authentication user credentials AuthenUsrCred_CType package is delivered. The expectation is that the password credentials and the user name token are provided in the authentication user credential complex element in accordance with the standards established by WS-Security.

TaxPlnInqRs_MType

TaxPlnInqRs_MType is a message MType element.

Contains:

  • AccountId_CType
  • Custom_CType
  • MsgRsHdr_CType
  • PlnCustRec_CType
  • x_PlnTaxInfo_CType
  • x_TaxPlnDist_CType

Simple Elements

The following simple elements are contained within this message.

ActIntent
Conveys the consumer intention for a subsequent operation for the data set included in the response. Canonical values are:
  • Dlt
  • ReadOnly
  • Upd

The default value is ReadOnly.

ActIntentKey
The service provider key that is delivered to the consumer to be submitted in a subsequent modification operation.
CustId
The identifier attached to a customer. It includes the OvrrdInstRtId attribute.
PlnCode
The service provider code that represents plan products for different plan types.

AccountId_CType

AccountId_CType is a complex CType element. This element contains the incoming account identification information and any restrictions.

Simple Elements

The following simple elements are contained within this complex.

AcctId
The number or character that identifies an account record.
AcctType
The number or character that categorizes the AcctId.
Rstr
The level of restrictions that can exist at a parent and/or child node. Canonical values are:
  • Hid
  • NoAccess
  • NoAccessPart
  • ReadOnly
  • ReadOnlyPart
  • ReadWrite
  • ReadWritePart

Custom_CType

Custom_CType is a complex CType element.

This element is optional.

MsgRsHdr_CType

MsgRsHdr_CType is a complex CType element. This is the default message response header.

Contains:

  • jXchangeHdr_CType
  • MsgRecInfoArray_AType

jXchangeHdr_CType

jXchangeHdr_CType is a complex CType element.

Simple Elements

The following simple elements are contained within this complex.

AuditUsrId
The user ID that the consumer would like written in the audit as performing the requested service. It varies, but it could be the same as the user ID. It is not used to authenticate. It is used to audit the Soap Header Fault.
AuditWsId
The workstation ID that the consumer would like written in the audit as performing the requested service for the Soap Header Fault. It varies, but it could be the same as the user ID.
AuthenUsrId
The user ID which the consumer would like the service provider to authenticate with for the Soap Header Fault. It is a user ID that the provider understands.

This element deprecates in accordance with XSD contract tenets. Effective date: 2017–01–01. The new complex element for user authentication credentials was added to both the Search Message Request Header SrchMsgRqHdr_CType and the Message Request Header MsgRqHdr_CType. AuthenUsrId is ignored by the service providers when the authentication user credentials AuthenUsrCred_CType package is delivered. The expectation is that the password credentials and the user name token are provided in the authentication user credential complex element in accordance with the standards established by WS-Security.

BusCorrelId
The correlation identification as related to business functions and activities.
ConsumerName
The name of the service consumer (business name) for the Soap Header Fault.
ConsumerProd
The name of the product which is consuming the service (business product name) for the Soap Header Fault.
InstEnv
An identification provided by the consumer that defines the environment in which the institution is operating. Canonical values are:
  • Prod
InstRtId
The identification of the entity of the submitted message. A financial institution entity uses the routing transit or nine-digit number assigned to financial institutions for routing as assigned by the American Bankers Association. Any leading zeros must be provided for a complete routing and transit number. A non-financial institution entity should use a mutually agreed upon identification that must contain at least one non-integer character. The canonical value is JHA.

The element is required in all message requests.

jXLogTrackingId
An identification provided by jXchange to be able to trace the request and response of a message from the third-party gateway, internal gateway, and service provider for the Soap Header Fault.
JxVer
Contains the version jXchange is running for the Soap Header Fault.
ValidConsmName
The consumer name that can be validated by enterprise governance. The canonical values are managed in a consumer/product enterprise table. The canonical value is: JHA.
ValidConsmProd
The consumer product name that can be validated by enterprise governance. The canonical values are managed in a consumer/product enterprise table.
WorkflowCorrelId
The correlation identification as related to workflow functions and activities.
jXchangeHdr_CType Deprecation Details
AuthenUsrId
The user ID which the consumer would like the service provider to authenticate with for the Soap Header Fault. It is a user ID that the provider understands.

This element deprecates in accordance with XSD contract tenets. Effective date: 2017–01–01. The new complex element for user authentication credentials was added to both the Search Message Request Header SrchMsgRqHdr_CType and the Message Request Header MsgRqHdr_CType. AuthenUsrId is ignored by the service providers when the authentication user credentials AuthenUsrCred_CType package is delivered. The expectation is that the password credentials and the user name token are provided in the authentication user credential complex element in accordance with the standards established by WS-Security.

MsgRecInfoArray_AType

MsgRecInfoArray_AType is an array AType element. This is an array of messages that can be returned in a response.

Contains:

  • MsgRec_CType
MsgRec_CType

MsgRec_CType is a complex CType element.

Simple Elements

The following simple elements are contained within this complex.

ErrCat
The Soap Header Fault error category.
ErrCode
The error code.
ErrDesc
The Soap Header Fault error description.
ErrElem
The Soap Header Fault when an error or fault occurs. This optional element contains the element which is causing the error condition.
ErrElemVal
The Soap Header Fault when an error or fault occurs. This optional element contains the value of the element which is causing the error condition.
ErrLoc
The Soap Header Fault error location. This is typically the program that generated the error condition.

PlnCustRec_CType

PlnCustRec_CType is a complex CType element.

Contains:

  • CondNotfArray_AType
  • Custom_CType
  • PlnAddrInfo_CType
  • PlnCust_CType

Simple Elements

The following simple elements are contained within this complex.

BenfDistDesc
The description of the method of the distribution.
BirthDt
The date of birth.
CustAgeAtEOY
The customers age by the end of the calendar year.
DeceasedDt
The date deceased.
PlnAvgRate
The average rate for the tax plan.
PlnCurBal
The tax plan's balance.
PlnDesc
The description of service provider code that represents plan products for different plan types.
PlnFeeDesc
The description of the fees charged to the tax plan.
PlnType
Tax plan types as approved by the IRS. Canonical values are:
  • EDU - Educational IRA
  • HSA - Health Savings
  • IRA - Regular IRA
  • MSA - Medical Savings
  • QRP - Keogh
  • RCV - ROTH Conversion
  • RTH - ROTH Retirement
  • SEP - Simplified Employer Plan
  • SIM - Simple Retirement
PlnYTDInt
The amount of year-to-date interest paid in the tax plan.
SpousPlnDesc
The description of the code for spousal retirement plan.

CondNotfArray_AType

CondNotfArray_AType is an array AType element. This is an array of condition notifiers used to define conditional notification status.

Contains:

  • CondNotfInfo_CType
CondNotfInfo_CType

CondNotfInfo_CType is a complex CType element.

Simple Elements

The following simple elements are contained within this complex.

CondNotf
The conditions that exist on an account or customer to notify the consumer to use another service. Canonical values:
  • AcctAnlys
  • AcctCombStmt
  • AcctProdOvrrd
  • AcctRecon
  • AcctSweep
  • ACHEDI
  • AddrAcct
  • AddrIRSRpt
  • AddrNot
  • AddrOvrrd
  • AddrPmts
  • AddrSeasonal
  • AddrStmt
  • AlertMsg
  • CollatMsg
  • CollatTrack
  • ColMsg
  • EnhAcctAnlys
  • Escrw
  • FASB91
  • FraudAlert
  • InstDefFld
  • LnPmtSched
  • LnRateSched
  • LnUnit
  • LineOfCr
  • MemoPost
  • Msg
  • ODProt
  • PlnBenf
  • RealEstateProp
  • StopAlerts
  • StopHold
  • StopPay
  • Stops
  • StopSpecInstr
  • TimeDepRenOvrrd
  • XferACH
  • XferFut

Custom_CType

Custom_CType is a complex CType element.

This element is optional.

PlnAddrInfo_CType

PlnAddrInfo_CType is a complex CType element.

Contains:

  • Addr_CType
Addr_CType

Addr_CType is a complex CType element containing address information. This element is optional.

Contains:

  • FreeFormAddr_AType
Simple Elements

The following simple elements are contained within this complex.

BusAddr
Answers the question: Is this a business address? Y states it is a business address.
City
The city name.
Cntry
The country name.
CntryType
The country abbreviation from ISO 3166.
County
The county name.
DlvryPt
The delivery point added to the ZIP code.
FornAddr
Is this a foreign address? Y states it is a foreign address.
InvAddr
Is this address invalid? Y states mail has been returned from this address.
PostalCode
The postal code or ZIP code.
StateCode
The two-character alpha code which represents a state. For example, MO.
StateProv
The state or province or region.
StreetAddr1
The street address.
StreetAddr2
The second line of street address.
StreetAddr3
The third line of street address.
FreeFormAddr_AType

FreeFormAddr_AType is an array AType element. This is an array of free form address lines 1–11 in a printable/usable form.

Contains:

  • AddrLineInfo_CType
AddrLineInfo_CType

AddrLineInfo_CType is a complex CType element.

Simple Elements

The following simple elements are contained within this complex.

AddrLine
Free-form element of address lines 1–11 in a printable/usable form, generally not separated.

PlnCust_CType

PlnCust_CType is a complex CType element.

Simple Elements

The following simple elements are contained within this complex.

Note: The date of death at the plan owner level may be entered at a different time than the customer level due to plan distribution calculations for some providers.
BenfDistCode
The code for the method of the distribution.
CntrbAmtPriorYTD
The prior tax year-to-date contribution amounts for a tax plan.
CntrbAmtYTD
The current tax year-to-date contribution amounts for a tax plan.
DeathDistDt
The date the tax plan proceeds were distributed to the beneficiary.
DeathDist
The proceeds of the tax plan were distributed due to the death of the plan owner.
FirstContrbDt
The date of the first tax plan contribution.
OrigOwnBirthDt
The original owners of the tax plan's birth date.
OrigOwnCustId
The original owners of the tax plan's customer ID.
OrigOwnDeceaseDt
The original owners of the tax plan's date of death.
OrigOwnName
The name of the original owner of the tax plan.
PlanDistDeceasedDt
The date deceased.
PlnEstbDt
The date the tax plan was established.
PlnFeeAmt
The fee charge for maintaining the tax plan.
PlnFeeCode
The code for the fees charged to the tax plan.
QRPCustId
The customer ID of the administrator for a qualified retirement (Keogh) tax plan.
QRPPlnId
The plan ID of the employer for a qualified retirement (Keogh) tax plan.
SoleSpousBenf
A code that references if the tax plan is taking advantage of the sole spousal distribution.
SpousPlnCode
The code to determine if the tax plan qualifies as a spousal retirement plan in accord with IRS Regulations.
SpousSingleOwn
References if the tax plan is using the spousal single life election rule.

x_PlnTaxInfo_CType

x_PlnTaxInfo_CType is a complex CType element.

Contains:

  • Custom_CType
  • TaxPlnTaxInfo_CType

Simple Elements

The following simple elements are contained within this complex.

PlnFedWithDesc
Federal withholding code description.
PlnStateWithDesc
State withholding code description.

Custom_CType

Custom_CType is a complex CType element.

This element is optional.

TaxPlnTaxInfo_CType

TaxPlnTaxInfo_CType is a complex CType element.

Simple Elements

The following simple elements are contained within this complex.

PlnFedWithAltAcctId
Withholding alternate account number.
PlnFedWithAltAcctType
Withholding alternate account type.
PlnFedWithAltRate
Withholding alternate rate.
PlnFedWithCode
Fed W/H code. Value is passed from the service of record during the pilot phase.
PlnFedWithEffDt
Fed W/H effective date.
PlnFedWithFixAmt
Federal withholding fixed holding amount.
PlnFedWithLastYR
Federal withholding last year.
PlnFedWithMTD
Federal withholding month-to-date.
PlnFedWithQTD
Federal withholding quarter-to-date.
PlnFedWithYTD
Federal withholding year-to-date.
PlnStateWithAltAcctId
State withholding alternate account number.
PlnStateWithAltAcctType
State withholding alternate account type D.
PlnStateWithAltRate
State withholding alternate rate.
PlnStateWithCode
State W/H code. Value is passed from the service of record during the pilot phase.
PlnStateWithEffDt
State W/H effective date.
PlnStateWithFixAmt
State withholding fixed holding amount.
PlnStateWithLastYR
State withholding last year.
PlnStateWithMTD
State withholding month-to-date.
PlnStateWithQTD
State withholding quarter-to-date.
PlnStateWithYTD
State withholding year-to-date.

x_TaxPlnDist_CType

x_TaxPlnDist_CType is a complex CType element.

Contains:

  • Custom_CType
  • TaxPlnDist_CType

Simple Elements

The following simple elements are contained within this complex.

ACHSendPreNoteDesc
The description of the code that determines if an ACH prenotification should be generated, as governed by Nacha® rules.
ACHTrnDesc
The description of the transaction code to be used for the ACH item, as governed by Nacha® rules.
AutoStartDistDesc
The description of the code that references if the tax plan should automatically start distributions.
DistAmtRemDesc
The description of the remaining amount of the tax plan distribution.
DistCalcMthdDesc
The description of the code that references the method that should be used for distributions from the tax plan.
DistFrqDesc
The description of the code that references the frequency of the distributions from the tax plan.
DistIncIntDesc
The description of the code that references if the tax plan distributions should include accrued but unpaid interest.
DistSeqOrderDesc
The description of the code that references if the order the funds should be debited from the instruments for the tax plan distributions.
DistStatDesc
The description of the status of the scheduled distribution from the tax plan.
DistTrnDesc
The description of the transaction code that is used when making distributions from the tax plan.
DlyFirstDistDesc
The description of the code that references if the tax plan should delay the first mandatory distribution until the following tax year.
ElecDistAmtDesc
The description of the elected distribution amount from the tax plan.
MinRDAAgeOvrrdDesc
The description of the election taken by the account owner to use the minimum RDA age override, as allowed by the tax plan.
OwnDistCalcMthdDesc
The description of the code to determine the method to be used when calculating the RMD amount if the plan still belongs to the original owner.
RecalcDistAmtDesc
The description of the code that references if tax plan elected distribution amount should be recalculated automatically on a periodic basis.
RedLastAnnDistDesc
The description of the code that determines if the last distribution in the year should be reduced so only the minimum distribution required is distributed as governed by the tax plan.
ReqMinDistDesc
The description of the required minimum distribution from the tax plan as required by IRS statues.
SoleSpousDistDesc
The description of the code that references if the sole beneficiary is the spouse.
WavMndtryDistDesc
The description of the code that references the reason the mandatory distribution amount is being waived.

Custom_CType

Custom_CType is a complex CType element.

This element is optional.

TaxPlnDist_CType

TaxPlnDist_CType is a complex CType element.

Contains:

  • ACHPmtInfo_CType
Simple Elements

The following simple elements are contained within this complex.

AutoStartDistCode
The code that references if the tax plan should automatically start distributions.
CalcBenfAge
The calculated age of the beneficiary to be used for the RMD amount. This could differ from the beneficiary age.
DistAcctId
The account identification for the tax plan distribution for direct deposit.
DistAcctType
The account type for the tax plan distribution for direct deposit.
DistAmtRemCode
The code that references the remaining amount of the tax plan distribution.
DistAmtRem
The description of the remaining amount of the tax plan distribution.
DistAmt
The amount of the scheduled distribution from the tax plan.
DistCalcMthdCode
The code that references the method that should be used for distributions from the tax plan.
DistDayofMonth
The specific day of the month the distribution should be created from the tax plan.
DistFactor
The distribution factor to be used in the RMD amount for the tax plan.
DistFrqCode
The code that references the frequency of the distributions from the tax plan.
DistFrq
The frequency of the distribution should be created from the tax plan.
DistIncIntCode
The code that references if the tax plan distributions should include accrued but unpaid interest.
DistSeqOrderCode
The code that references the order the funds should be debited from the instruments for the tax plan distributions.
DistStatCode
The status of the scheduled distribution from the tax plan.
DistTrnCode
The transaction code that is used when making distributions from the tax plan.
DlyFirstDistCode
The code that references if the tax play should delay the first mandatory distribution until the following tax year.
ElecDistAmt
The elected distribution amount from the tax plan.
LastDistAmt
The amount of the last distribution from the tax plan.
LastDistDt
The date of the last distribution from the tax plan.
MinRDAAgeOvrrdCode
The election taken by the account owner to use the minimum RDA age override, as allowed by the tax plan.
MndtryDistDt
The date mandatory distributions must start from the tax plan.
NxtDistDt
The next scheduled distribution date from the tax plan.
OwnDistCalcMthdCode
The code to determine the method to be used when calculating the RMD amount if the plan still belongs to the original owner.
RecalcDistAmtCode
The code that references if the tax plan elected distribution amount should be recalculated automatically on a periodic basis.
RedLastAnnDistCode
The code that determines if the last distribution in the year should be reduced so only the minimum distribution required is distributed as governed by the tax plan.
ReqMinDistAmt
The required minimum distribution from the tax plan as required by IRS statues.
SoleSpousDistCode
The code that references if the sole beneficiary is the spouse.
StartDistDt
The date the scheduled distributions started from the tax plan.
WavMndtryDistCode
The code that references the reason the mandatory distribution amount is being waived.
ACHPmtInfo_CType

ACHPmtInfo_CType is a complex CType element. This element is optional.

Simple Elements

The following simple elements are contained within this complex.

ACHCompDiscrData
The ACH company discretionary data, as governed by Nacha® rules.
ACHCompEntryDesc
The ACH company entry description, as governed by Nacha® rules.
ACHCompId
The ACH company ID.
ACHCompName
The ACH company name, as governed by Nacha® rules.
ACHCrAcctId
The account ID of the credit account for the ACH item.
ACHCrName
The account holder's name of the credit account for the ACH item.
ACHCrRtNum
The routing and transit number of the credit account's bank for the ACH item.
ACHDrAcctId
The account ID of the debit account for the ACH item.
ACHDrName
The account holder's name of the debit account for the ACH item.
ACHDrRtNum
The routing and transit number of the debit account's bank for the ACH item.
ACHSendPreNoteCode
The code that determines if an ACH prenotification should be generated, as governed by Nacha® rules.
ACHStdEntryClass
The ACH standard entry class.
ACHTrnCode
The transaction code to be used for the ACH item, as governed by Nacha® rules.

Have a Question?
Have a how-to question? Seeing a weird error? Get help on StackOverflow.
Register for the Digital Toolkit Meetup where we answer technical Q&A from the audience.
Last updated Mon Jan 24 2022