X12 Document Submission Service Specifications

advertisement
5
NHIN X12 Document Submission Service Interface Specification
v 0.3
Nationwide Health Information Network (NHIN)
Service Interface Specification
X12 Document Submission
Service Specifications
V 0.3
08/01/2011
Page 1 of 18
5
NHIN X12 Document Submission Service Interface Specification
v 0.3
Contributors
Name
Melanie Combs-Dyer
Daniel Kalwa
Manoj Chaganti
Seonho Kim
Mary Lynn Bushman
Donna Jones
Kevin Castellow
Raja Kailer
Organization
CMS
CMS
CMS/QSSI
CHIC/MEDNET
Wellpoint
CMS/Signature Consulting
CMS/BNETI
CMS/BNETI
Area
Specification
Specification
Specification
Specification
Specification
Specification
Specification
Specification
Document Change History
Version
0.1
0.2
Date
07/15/2011
07/26/2011
0.3
08/01/2011
Changed By
Manoj Chaganti
Manoj Chaganti,
Mary Lynn, Kevin
Castellow, Raja
Kailer, Gary
Beaty, Donna
Jones
Raja Kailer, Gary
Beaty, Manoj
Chaganti, Donna
Jones
Items Changed Since Previous Version
Initial Draft
Review and updated the standards.
Provided the sample message
Updated the WSDL
Updated the Metadata
Reviewed the content and suggested change to schema,
5010, section 3.x
Page 2 of 18
5
NHIN X12 Document Submission Service Interface Specification
v 0.3
Document Approval
Version
Date
Approved By
Role
Page 3 of 18
5
NHIN X12 Document Submission Service Interface Specification
v 0.3
Table of Contents
1
PREFACE ............................................................................................................................................................5
1.1
1.2
1.3
1.4
1.5
1.6
2
INTERFACE DESCRIPTION ...........................................................................................................................6
2.1
2.2
2.3
2.4
2.5
3
INTRODUCTION ...............................................................................................................................................5
INTENDED AUDIENCE .....................................................................................................................................5
FOCUS OF THIS SPECIFICATION .......................................................................................................................5
REFERENCED DOCUMENTS AND STANDARDS .................................................................................................5
DEVIATIONS FROM STANDARDS .....................................................................................................................6
RELATIONSHIP TO OTHER NHIN SPECIFICATIONS ..........................................................................................6
DEFINITION.....................................................................................................................................................7
TRANSACTION STANDARD ..............................................................................................................................7
ASSUMPTIONS ................................................................................................................................................7
TECHNICAL PRE-CONDITIONS .........................................................................................................................7
TECHNICAL POST-CONDITIONS .......................................................................................................................7
INTERFACE DEFINITION ...............................................................................................................................8
3.1
CAQH CORE X12 TRANSACTION: ................................................................................................................8
3.2
MULTIPLE DOCUMENTS SUBMISSION .............................................................................................................8
3.3
SYNCHRONOUS/DEFERRED MESSAGING .........................................................................................................8
3.3.1
Synchronous Messaging Workflow ........................................................................................................8
3.3.2
Deferred Messaging Workflow ..............................................................................................................9
3.4
CORE METADATA ELEMENTS .......................................................................................................................9
3.5
CONNECTIVITY RULE ................................................................................................................................... 10
3.6
SOAP + WSDL BASED MESSAGE ENVELOPE ............................................................................................... 10
3.7
REAL-TIME DEFERRED MODE (REAL-TIME MODE, REAL-TIME PROCESSING MODE) ................................... 10
3.8
BATCH-TIME (BATCH-TIME MODE, BATCH-TIME PROCESSING MODE) ........................................................ 10
3.9
SAML ASSERTION BASED USER AUTHENTICATION AND AUTHORIZATION .................................................. 10
3.9.1
National Provider Identifier (NPI) Attribute ....................................................................................... 10
3.9.2
NPI Provider Name Attribute .............................................................................................................. 11
4
ERROR HANDLING ........................................................................................................................................ 11
5
AUDITING ......................................................................................................................................................... 11
APPENDIX A:
SAMPLE MESSAGES .............................................................................................................. 12
SAMPLE CORE SOAP + WSDL REAL-TIME REQUEST ............................................................................................ 12
SAMPLE CORE SOAP + WSDL REAL-TIME RESPONSE ........................................................................................... 12
APPENDIX B:
6
WSDL.......................................................................................................................................... 13
CORE PHASE II COMPLIANT XML SCHEMA SPECIFICATION ........................................................ 16
Page 4 of 18
5
1
NHIN X12 Document Submission Service Interface Specification
v 0.3
Preface
1.1
Introduction
This NwHIN X12 Document Submission Service Interface Specifications constitute the core services of an
operational Nationwide Health Information Network (NwHIN) with Accredited Standards Committee (ASC)
ANSI X12 Transactions. They are intended to provide a standard set of service interfaces that enable the
exchange of interoperable health information amongst a group of peer nodes referred to Nationwide
Health Information Exchanges (NHIEs).
NwHIN already defines services such as Document Submission service for IHE XDR Specification. This
specification will add the Accredited Standards Committee (ASC) ANSI X12 Document Submission
Service in addition to XDR Document Submission Service and these other services. It is important to
note that the functional services of this specification rest on a foundational set of defined core services
that includes the following:
1.
2.
3.
4.
5.
1.2
NHIN Trial Implementations Message Platform Service Interface Specification,
NHIN Trial Implementations Authorization Framework Service Interface Specification,
NHIN Trial Implementations Audit Log Query Service Interface Specification,
NHIN Trial Implementations NHIE Service Registry Interface Specification
NHIN Trial Implementations Authorized Case Follow-Up Service Interface Specification
Intended Audience
The primary audience for the NHIN X12 Document Submission Service Interface Specifications is the
individuals responsible for implementing software solutions that realize these interfaces for a NHIE that
will exchange Accredited Standards Committee (ASC) ANSI X12 transactions. After reading this
specification, one should have an understanding of the context in which the service interface is meant to
be used, the behavior of the interface, the underlying reference standards and specifications, the Web
Services Description Language (WSDLs) used to define the service, any Extensible Markup Language
(XML) schemas used to define the content, and what “compliance” means from an implementation testing
perspective.
1.3
Focus of this Specification
This document defines the NwHIN X12 Document Submission Service Interface Specification. The
purpose of this specification is to provide the ability to “push” data for a given patient from one NHIE to
another via configuration on the X12 submission side. This is a different model of exchange than
subscription (see the NHIN Trial Implementations Health Information Event Messaging Service
Specification for details on this approach) because the sender decides who the data should go to and the
receiver receives data on an appropriate available endpoint from the sources it authorizes (refer to the
Authorization Framework Service Interface Specification). Also, this is different payload and model of
exchange compare to XDR Document Submission based on ASC X12 Transactions.
1.4
Referenced Documents and Standards
The following documents and standards were referenced during the development of this specification.
Specific deviations from or constraints upon these standards are identified below.
1) Org/SDO name: CAQH
Page 5 of 18
5
NHIN X12 Document Submission Service Interface Specification
v 0.3
Reference # / Spec Name: CAQH CORE Phase II Connectivity Rule
Version #: v2.2.0 (March 28, 2011)
NHIN Deviations or Constraints:

Use of TLS 1.0 as per Messaging Platform Specification

Use of Base64 encoding of payloads that have non-printable characters for SOAP RealTime1

Use of SAML Assertions as per NHIN Authorization Framework Specification
Underlying Specs:

CAQH CORE Phase I and II Connectivity Operating Rules
Link:
http://www.caqh.org/pdf/CLEAN5010/270-v5010.pdf
1.5
Deviations from Standards
Specific deviations from or constraints from the above-mentioned standards are identified.
This specification adopts the Real-Time Request/Response transaction Mode. Batch Processing Mode is
not supported in this specification. For details, please refer CAQH CORE Phase II Connectivity Rule,
Version 2.2.0
1.6
Relationship to Other NHIN Specifications
In some cases, the data exchanged between NHIEs will involve the communication of individually
identifiable health information (defined in 45 CFR Parts 160, 162, and 164). When individually identifiable
information is exchanged, then each NHIE must have a common understanding of the patient’s identity.
This specification is related to other NHIN specifications as described below:
2
1

Messaging Platform – specifies a base set of messaging standards and web service protocols
which must be implemented by each NHIN node and applies to all transactions including this
transaction. All NHIN messages sent between NHIN systems are SOAP messages over HTTP
using web services and all messages must be encrypted and digitally signed.

Authorization Framework – defines the exchange of metadata used to characterize each NHIN
request. The purpose of that exchange is to provide the responder with the information needed
to make an authorization decision for the requested function.

Services Registry – enables computer systems to discover and consume services. For NHIN,
the Services Registry is a UDDI web-services registry. This registry lists NHIN services which in
this case will consist of a single entry for endpoints that will respond to X12 messages as defined
herein.
Interface Description
Version 2.2.0 of CORE Connectivity Rule does not have MTOM support for SOAP Real-Time.
Page 6 of 18
5
NHIN X12 Document Submission Service Interface Specification
v 0.3
2.1
Definition
In this interface specification, a “document” refers to the format of clinical data as it is transferred between
NHIEs, and not as it is stored within an NHIE or electronic health record (EHR) system. A NHIE and its
participating organizations may store clinical data in whatever format or repository it chooses. Specifically,
a “document” transferred between NHIEs need not meet the criteria for persistence, stewardship, etc.
“Initiating NHIE” refers to a document source NHIE that initiates X12 document submission transaction for
one or more available documents on a particular patient.
“Receiving NHIE” refers to document recipient NHIE that receives X12 document submission transaction.
2.2
Transaction Standard
This interface identifies the CAQH CORE Phase II Connectivity Rule as the standard for NHIN X12
Document Submission Service Specification.
2.3
Assumptions
The following assumptions underlie this specification:

There is no central or federated service that performs transactions across multiple HIOs/HIHs.

The requesting NHIN Gateway shall be responsible for using the UDDI Services Registry to
determine which of these Services they will call for any specific X12 transaction request
message.

Security Assertion Markup Language (SAML) Authorization assertion(s) will be included in the
request message as specified by the Messaging Platform specification..

This specification requires use of CORE Simple Object Access Protocol (SOAP) + WSDL Method
(Envelope Standard B)

This specification does not require use of CORE HTTP MIME Multipart (Envelope Standard A)
2.4
Technical Pre-conditions
The following technical pre-conditions exist for this interface specification:

Responding Medicaid HIOs must publish in the NHIN UDDI Services Registry data containing
descriptive and technical information about their NHIN Medicaid Eligibility Verification service.

The Medicaid HIO to which the query will be directed have been selected and applicable service
end points have been identified using the NHIN UDDI Services Registry.

The Requesting HIOs have a pre-established trust relationship with the Medicaid HIO they are
calling, that enables them to participate in an eligibility verification data exchange.

The Initiating HIO must include SAML assertion containing user-level credentials sufficient to
enable authentication and/or authorization by the receiving Medicaid system.
2.5
Technical Post-conditions
The following technical post-conditions will result after the execution of this interface specification:

Errors encountered will be handled and included in the response as specified in CAQH CORE
Phase II Connectivity Rule.

The response to this request is a payload containing an X12 Transaction message and some
metadata describing the transaction such as Payload ID, Sender ID, Receiver ID, etc. (required
CORE Metadata will be described in section 3.3.2 in detail).
Page 7 of 18
5
3
3.1
NHIN X12 Document Submission Service Interface Specification
v 0.3
Interface Definition
CAQH CORE X12 Transaction:
This transaction is described in CAQH CORE Phase II Connectivity Rule Section 4.The figure below
illustrates the actors and transaction (Any Transactions) involved in CORE SOAP + WSDL Real-time
Request/Response transaction.
HealthCare Provider
Initiating HIH/HIO
X12 Payload in Request
(Any Transaction)
X12 Payload in Response
(Any Transaction)
3.2
Receiving HIH/HIO
X12 Document Submission Request
X12 Document Submission Response
Review Contractor/
Health Plan
X12 Payload in Request
(Any Transaction)
X12 Payload in Response
(Any Transaction)
Multiple Documents Submission
This interface supports the ability to include multiple documents for a single patient in a single Submission
Transaction
3.3
Synchronous/Deferred Messaging
Receiving NHIEs must support synchronous (immediate) document submission transactions; however
deferred document submission transactions may also optionally be supported, or may restrict
submissions to use either messaging mode based on agreements with its trading partners.
When not restricted by the Receiving NHIE, the Initiating NHIE may choose whether to use synchronous
or deferred interactions. A Receiving NHIE that supports both synchronous and deferred messaging
modes would set up two services. One for synchronous and other one for deferred. Additionally, the
Initiating NHIE would provide a response service entry point by which the deferred response is delivered
from Receiving NHIE in a separate HTTP Session to the Initiating NHIE. The Synchronous and Deferred
Messaging Workflow are defined in the NHIN Messaging Platform Specification document.
3.3.1 Synchronous Messaging Workflow
The Initiating NHIE and Receiving NHIE handle the Document Submission transaction in a single in-out
message exchange pattern as defined in the NHIN Messaging Platform Specification document. In other
words, Initiating NHIE sends a Document submission request to the Receiving NHIE and waits for a
response to come back on the same HTTP connection. The receiving NHIE receives the Document
submission request and processes it in real-time and sends back the response to the Initiating NHIE on
that same HTTP connection. It should be noted that the Action names and namespaces in the
synchronous and the deferred versions of the WSDLs would need to be different so that code generation
of the web service code in a gateway supporting both do not have conflicts.
SOAP action for Document Submission Request in synchronous mode is:
Page 8 of 18
5
NHIN X12 Document Submission Service Interface Specification
v 0.3
SOAP action for Document Submission Response in synchronous mode is:
3.3.2
Deferred Messaging Workflow
Deferred Messaging workflow is supported by this specification to solve the issues of extreme latency
involved in processing of Document Submission request and the attached payload(s) associated with the
request.
In a deferred mode, the Document Submission is a two-way message as shown in the diagram below:
3.4
CORE Metadata Elements
The required CORE Metadata is described in the table below. CORE metadata elements are used in
several ways in NHIN. The primary uses of the metadata are:
 Message routing
 Transaction auditing
 Transaction Scheduling
 Resource Allocation
 Backward compatibility
 Error handling
 Audit logging
Element
Payload Type
Processing
Mode
Payload ID
Time Stamp
Sender
Identifier
Receiver
Identifier
CORE Rule
Version
Error Code
Error
Message
Description
The type of payload included within
a request/response. This shall be
“X12_xxx_005010X092A1” for a
request and
“X12_xxx_005010X092A1” for a
response
Note: xxx is a transaction type
The mode of processing. This shall
be “RealTime”
A payload ID assigned by the
sender. This shall conform to ISO
UUID standards with hexadecimal
notation, generated using a
combination of local timestamp as
well as the hardware (MAC)
address
A single coordinated Universal
Time (UTC) time stamp including
time zone. This does not require a
shared time server
A unique business entity (trading
partner) identifier
A unique business entity (trading
partner) identifier
The CORE Rule version that the
envelope is using
The error code indicating the error
when processing the envelope
Text error message
Field Name
PayloadType
Optionality
R
Data Type
Coded Set
ProcessingMode
R
Coded Set
PayloadID
R
String
TimeStamp
R
dateTime
SenderID
R
String
ReceiverID
R
String
CORERuleVersion
R
Coded Set
ErrorCode
R
Coded Set
ErrorMessage
R
String
Page 9 of 18
5
3.5
NHIN X12 Document Submission Service Interface Specification
v 0.3
Connectivity Rule
This transaction is described in detail in CORE Phase II Connectivity Rule Version 2.2.0 section 4.2.2.
3.6
SOAP + WSDL based Message Envelope
The SOAP + WSDL based method requires SOAP version 1.2 as specified by the NHIN Messaging
Platform specification. There is no specific requirement for the SOAP header2. The SOAP body contains
the remaining metadata defined by CORE Phase II compliant XML Schema Specification (see Appendix
C). The message envelope structure is defined in the CORE Phase II WSDL file. (see Appendix B)
3.7
Real-time Deferred Mode (Real-time Mode, Real-time Processing Mode)
Constraint: For Real-time using SOAP envelope, payloads (files) that contain non-printable characters
must be Base64 encoded.
3.8
Batch-time (Batch-time Mode, Batch-time Processing Mode)
3.9
SAML Assertion based User Authentication and Authorization
For submitter authentication/authorization3, SAML Assertion shall need to include additional <Attribute>
elements required by HIT systems. The additional <Attribute> elements required by this specification
include 1) National Provider Identifier (NPI) Attribute and 2) NPI Provider Name Attribute. Other elements
required by this specification include1) User Organization ID Attribute, 2) User Role Attribute and 3)
Purpose of Use Attribute which are defined in NHIN Authorization Framework Service Interface
Specification. User Authentication will be performed on an NPI Attribute and NPI Provider Name Attribute
pair against the NPPES by the State Medicaid MMIS system. State Medicaid system will validate
requests per NPI Attribute, User Role Attribute, and Purpose of Use Attribute. Details on submitter
authentication/authorization by the State Medicaid systems are out of scope of this specification.
3.9.1 National Provider Identifier (NPI)4 Attribute
This <Attribute> element shall have the Name attribute set to “urn:oasis:names:tc:xspa:1.0:subject:npi”
and a NPI number shall be placed as a string in plain text in the value of the <AttributeValue> element.
An example of the syntax of this element is as follows:
<saml:Attribute Name="urn:oasis:names:tc:xspa:1.0:subject:npi">
<saml:AttributeValue>1467433888</saml:AttributeValue>
</saml:Attribute>
2
CORE Phase II Connectivity Rule requires that WS-Security Username and Password token must be added to the SOAP Header
in the request for user authentication/authorization. This requirement is replaced with SAML Assertion based user
authentication/authorization described in section 3.6 in this specification.
3
CORE Phase II Connectivity Rule specifies two methods for submitter authentication: 1) Username/Password based
authentication and 2) X.509 Certificate based authentication over SSL. This specification will use SAML Assertion.
4
NPI is a US Government issued unique provider identifier required for all Health Insurance Portability and Accountability Act
(HIPAA) Privacy Disclosure Accounting transactions.
Page 10 of 18
5
NHIN X12 Document Submission Service Interface Specification
v 0.3
3.9.2 NPI Provider Name Attribute
This <Attribute> element shall have the Name attribute set to “urn:nhin:names:saml:npiProviderName”
and a provider name, which is associated with an identifier provided in NPI <Attribute>, shall be placed as
a string in plain text in the value of the <AttributeValue> element. An example of the syntax of this
element is as follows:
<saml:Attribute Name="urn:nhin:names:saml:npiProviderName">
<saml:AttributeValue>Family Medical Clinic</saml:AttributeValue>
</saml:Attribute>
4
Error Handling
This section follows error handling specified in the section 4.3.3 of the CORE Phase II Connection Rule.
The error codes relevant to the Medicaid Eligibility Verification are listed in the following table:
Error Codes
<FieldName>Illegal
<FieldName>Required
<FieldName>NotUnderstood
VersionMismatch
UnAuthorized
Sender
Receiver
5
Description
Illegal value provided for <FieldName>.
The field <FieldName> is required but was not provided.
The field <FieldName> is not understood at the receiver. In
the case of SOAP, this error is returned as a NotUnderstood
SOAP fault.
The version of the envelope sent is not acceptable to the
receiver. If the SOAP version is not valid at the receiver, a
SOAP fault is returned with this fault code.
The username/password or Client certificate could not be
verified.
The envelope sent by the sender did not conform to the
expected format. In the case of SOAP, this error should be
sent as a SOAP fault with “Sender” fault code.
The message could not be processed for reasons
attributable to the Receiver (e.g., upstream process is not
reachable). In the case of SOAP, this error should be sent
as a SOAP fault with “Receiver” fault code.
Auditing
This transaction shall be audited as specified in the section 4.3.4 of the CORE Phase II Connection Rule.
Page 11 of 18
5
NHIN X12 Document Submission Service Interface Specification
v 0.3
Appendix A: Sample Messages
Sample CORE SOAP + WSDL Real-time Request
<soapenv:Envelope xmlns:soapenv="http://www.w3.org/2003/05/soap-envelope">
<soapenv:Header>
<wsse:Security
xmlns:wsse="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext1.0.xsd" soapenv:mustUnderstand="true">
<wsse:UsernameToken
xmlns:wsu=http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility1.0.xsd wsu:Id="UsernameToken-21621663">
<wsse:Username>bob</wsse:Username>
<wsse:Password Type="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-usernametoken-profile-1.0#PasswordText">bobPW</wsse:Password>
</wsse:UsernameToken>
</wsse:Security>
</soapenv:Header>
<soapenv:Body>
<ns1:COREEnvelopeRealTimeRequest
xmlns:ns1="http://www.caqh.org/SOAP/WSDL/CORERule2.2.0.xsd ">
<PayloadType>X12_270_004010X092A1</PayloadType>
<ProcessingMode>RealTime</ProcessingMode>
<PayloadID>f81d4fae-7dec-11d0-a765-00a0c91e6bf6</PayloadID>
<TimeStamp>2007-08-30T10:20:34Z</TimeStamp>
<SenderID>HospitalA</SenderID>
<ReceiverID>PayerB</ReceiverID>
<CORERuleVersion>2.2.0</CORERuleVersion>
<Payload><![CDATA[ISA*00* *00* *ZZ*NEHEN780 *ZZ*NEHEN003 ...IEA*1*000000031]]></Payload>
</ns1:COREEnvelopeRealTimeRequest>
</soapenv:Body>
</soapenv:Envelope>
Sample CORE SOAP + WSDL Real-time Response
<soapenv:Envelope xmlns:soapenv="http://www.w3.org/2003/05/soap-envelope">
<soapenv:Body>
<ns1:COREEnvelopeRealTimeResponse
xmlns:ns1="http://www.caqh.org/SOAP/WSDL/CORERule2.2.0.xsd">
<PayloadType>X12_271_004010X092A1</PayloadType>
<ProcessingMode>RealTime</ProcessingMode>
<PayloadID>a81d44ae-7dec-11d0-a765-00a0c91e6ba0</PayloadID>
<TimeStamp>2007-08-30T10:20:34Z</TimeStamp>
<SenderID>PayerB</SenderID>
<ReceiverID>HospitalA</ReceiverID>
<CORERuleVersion>2.2.0</CORERuleVersion>
<Payload><![CDATA[ISA*00* *00* *ZZ*NEHEN780 *ZZ*NEHEN003 ...IEA*1*000000031]]></Payload>
<ErrorCode>Success</ErrorCode>
<ErrorMessage></ErrorMessage>
</ns1:COREEnvelopeRealTimeResponse>
</soapenv:Body>
</soapenv:Envelope>
Page 12 of 18
5
NHIN X12 Document Submission Service Interface Specification
v 0.3
Appendix B: WSDL
CAQH CORE Phase II Connectivity Rule provides a WSDL definition 5
. <?xml version="1.0" encoding="UTF-8"?>
<wsdl:definitions xmlns:CORE="http://www.caqh.org/SOAP/WSDL/"
xmlns:soap12="http://schemas.xmlsoap.org/wsdl/soap12/"
xmlns:xsd="http://www.w3.org/2001/XMLSchema"
xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/"
xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/"
xmlns:CORE-XSD="http://www.caqh.org/SOAP/WSDL/CORERule2.2.0.xsd"
xmlns="http://schemas.xmlsoap.org/wsdl/"
name="CORE"
targetNamespace="http://www.caqh.org/SOAP/WSDL/">
<wsdl:types>
<xsd:schema xmlns="http://schemas.xmlsoap.org/wsdl/"
elementFormDefault="qualified"
targetNamespace="http://www.caqh.org/SOAP/WSDL/">
<xsd:import namespace="http://www.caqh.org/SOAP/WSDL/CORERule2.2.0.xsd"
schemaLocation="CORERule2.2.0.xsd"/>
</xsd:schema>
</wsdl:types>
<wsdl:message name="RealTimeRequestMessage">
<wsdl:part name="body" element="CORE-XSD:COREEnvelopeRealTimeRequest"/>
</wsdl:message>
<wsdl:message name="RealTimeResponseMessage">
<wsdl:part name="body" element="CORE-XSD:COREEnvelopeRealTimeResponse"/>
</wsdl:message>
<wsdl:message name="BatchSubmissionMessage">
<wsdl:part name="body" element="CORE-XSD:COREEnvelopeBatchSubmission"/>
</wsdl:message>
<wsdl:message name="BatchSubmissionResponseMessage">
<wsdl:part name="body" element="CORE-XSD:COREEnvelopeBatchSubmissionResponse"/>
</wsdl:message>
<wsdl:message name="BatchSubmissionAckRetrievalRequestMessage">
<wsdl:part name="body"
element="CORE-XSD:COREEnvelopeBatchSubmissionAckRetrievalRequest"/>
</wsdl:message>
<wsdl:message name="BatchSubmissionAckRetrievalResponseMessage">
<wsdl:part name="body"
element="CORE-XSD:COREEnvelopeBatchSubmissionAckRetrievalResponse"/>
</wsdl:message>
<wsdl:message name="BatchResultsRetrievalRequestMessage">
<wsdl:part name="body"
element="CORE-XSD:COREEnvelopeBatchResultsRetrievalRequest"/>
</wsdl:message>
<wsdl:message name="BatchResultsRetrievalResponseMessage">
<wsdl:part name="body"
element="CORE-XSD:COREEnvelopeBatchResultsRetrievalResponse"/>
</wsdl:message>
<wsdl:message name="BatchResultsAckSubmissionMessage">
<wsdl:part name="body" element="CORE-XSD:COREEnvelopeBatchResultsAckSubmission"/>
</wsdl:message>
<wsdl:message name="BatchResultsAckSubmissionResponseMessage">
<wsdl:part name="body" element="CORE-XSD:COREEnvelopeBatchResultsAckSubmissionResponse"/>
</wsdl:message>
<wsdl:portType name="CORETransactions">
<wsdl:operation name="RealTimeTransaction">
<wsdl:input message="CORE:RealTimeRequestMessage"/>
<wsdl:output message="CORE:RealTimeResponseMessage"/>
</wsdl:operation>
<wsdl:operation name="BatchSubmitTransaction">
<wsdl:input message="CORE:BatchSubmissionMessage"/>
<wsdl:output message="CORE:BatchSubmissionResponseMessage"/>
</wsdl:operation>
5
Since Batch Processing Mode is not supported in this specification, some of this WSDL (i.e. Batch Submission) shall not be used.
The original CORE Phase II Connectivity WSDL can be downloaded at http://www.caqh.org/SOAP/WSDL/CORERule2.2.0.wsdl.
Page 13 of 18
5
NHIN X12 Document Submission Service Interface Specification
v 0.3
<wsdl:operation name="GenericBatchSubmissionTransaction">
<wsdl:input message="CORE:BatchSubmissionMessage"/>
<wsdl:output message="CORE:BatchSubmissionResponseMessage"/>
</wsdl:operation>
<wsdl:operation name="BatchSubmitAckRetrievalTransaction">
<wsdl:input message="CORE:BatchSubmissionAckRetrievalRequestMessage"/>
<wsdl:output message="CORE:BatchSubmissionAckRetrievalResponseMessage"/>
</wsdl:operation>
<wsdl:operation name="BatchResultsRetrievalTransaction">
<wsdl:input message="CORE:BatchResultsRetrievalRequestMessage"/>
<wsdl:output message="CORE:BatchResultsRetrievalResponseMessage"/>
</wsdl:operation>
<wsdl:operation name="BatchResultsAckSubmitTransaction">
<wsdl:input message="CORE:BatchResultsAckSubmissionMessage"/>
<wsdl:output message="CORE:BatchResultsAckSubmissionResponseMessage"/>
</wsdl:operation>
<wsdl:operation name="GenericBatchRetrievalTransaction">
<wsdl:input message="CORE:BatchResultsRetrievalRequestMessage"/>
<wsdl:output message="CORE:BatchResultsRetrievalResponseMessage"/>
</wsdl:operation>
<wsdl:operation name="GenericBatchReceiptConfirmationTransaction">
<wsdl:input message="CORE:BatchResultsAckSubmissionMessage"/>
<wsdl:output message="CORE:BatchResultsAckSubmissionResponseMessage"/>
</wsdl:operation>
</wsdl:portType>
<wsdl:binding name="CoreSoapBinding" type="CORE:CORETransactions">
<soap12:binding style="document" transport="http://schemas.xmlsoap.org/soap/http"/>
<wsdl:operation name="RealTimeTransaction">
<soap12:operation soapAction="RealTimeTransaction" style="document"/>
<wsdl:input>
<soap12:body use="literal"/>
</wsdl:input>
<wsdl:output>
<soap12:body use="literal"/>
</wsdl:output>
</wsdl:operation>
<wsdl:operation name="BatchSubmitTransaction">
<soap12:operation soapAction="BatchSubmitTransaction" style="document"/>
<wsdl:input>
<soap12:body use="literal"/>
</wsdl:input>
<wsdl:output>
<soap12:body use="literal"/>
</wsdl:output>
</wsdl:operation>
<wsdl:operation name="GenericBatchSubmissionTransaction">
<soap12:operation
soapAction="GenericBatchSubmissionTransaction" style="document"/>
<wsdl:input>
<soap12:body use="literal"/>
</wsdl:input>
<wsdl:output>
<soap12:body use="literal"/>
</wsdl:output>
</wsdl:operation>
<wsdl:operation name="BatchSubmitAckRetrievalTransaction">
<soap12:operation
soapAction="BatchSubmitAckRetrievalTransaction" style="document"/>
<wsdl:input>
<soap12:body use="literal"/>
</wsdl:input>
<wsdl:output>
<soap12:body use="literal"/>
</wsdl:output>
</wsdl:operation>
<wsdl:operation name="BatchResultsRetrievalTransaction">
<soap12:operation
soapAction="BatchResultsRetrievalTransaction" style="document"/>
<wsdl:input>
<soap12:body use="literal"/>
Page 14 of 18
5
NHIN X12 Document Submission Service Interface Specification
v 0.3
</wsdl:input>
<wsdl:output>
<soap12:body use="literal"/>
</wsdl:output>
</wsdl:operation>
<wsdl:operation name="BatchResultsAckSubmitTransaction">
<soap12:operation
soapAction="BatchResultsAckSubmitTransaction" style="document"/>
<wsdl:input>
<soap12:body use="literal"/>
</wsdl:input>
<wsdl:output>
<soap12:body use="literal"/>
</wsdl:output>
</wsdl:operation>
<wsdl:operation name="GenericBatchRetrievalTransaction">
<soap12:operation
soapAction="GenericBatchRetrievalTransaction" style="document"/>
<wsdl:input>
<soap12:body use="literal"/>
</wsdl:input>
<wsdl:output>
<soap12:body use="literal"/>
</wsdl:output>
</wsdl:operation>
<wsdl:operation name="GenericBatchReceiptConfirmationTransaction">
<soap12:operation
soapAction="GenericBatchReceiptConfirmationTransaction"
style="document"/>
<wsdl:input>
<soap12:body use="literal"/>
</wsdl:input>
<wsdl:output>
<soap12:body use="literal"/>
</wsdl:output>
</wsdl:operation>
</wsdl:binding>
<wsdl:service name="Core">
<wsdl:port name="CoreSoapPort" binding="CORE:CoreSoapBinding">
<soap12:address location="http://URL_OF_WEB_SERVICE"/>
</wsdl:port>
</wsdl:service>
</wsdl:definitions>
Page 15 of 18
5
6
NHIN X12 Document Submission Service Interface Specification
v 0.3
CORE Phase II compliant XML Schema Specification6
.
<?xml version="1.0"?>
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns="http://www.caqh.org/SOAP/WSDL/CORERule2.2.0.xsd"
targetNamespace="http://www.caqh.org/SOAP/WSDL/CORERule2.2.0.xsd">
<xs:element name="COREEnvelopeRealTimeRequest">
<xs:complexType>
<xs:sequence>
<xs:element name="PayloadType" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="ProcessingMode" type="RealTimeMode" minOccurs="1" maxOccurs="1"/>
<xs:element name="PayloadID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="TimeStamp" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="SenderID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="ReceiverID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="CORERuleVersion" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="Payload" type="xs:string" minOccurs="1" maxOccurs="1"/>
</xs:sequence>
</xs:complexType>
</xs:element>
<xs:element name="COREEnvelopeRealTimeResponse">
<xs:complexType>
<xs:sequence>
<xs:element name="PayloadType" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="ProcessingMode" type="RealTimeMode" minOccurs="1" maxOccurs="1"/>
<xs:element name="PayloadID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="TimeStamp" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="SenderID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="ReceiverID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="CORERuleVersion" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="Payload" type="xs:string" minOccurs="0" maxOccurs="1"/>
<xs:element name="ErrorCode" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="ErrorMessage" type="xs:string" minOccurs="1" maxOccurs="1"/>
</xs:sequence>
</xs:complexType>
</xs:element>
<xs:element name="COREEnvelopeBatchSubmission">
<xs:complexType>
<xs:sequence>
<xs:element name="PayloadType" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="ProcessingMode" type="BatchMode" minOccurs="1" maxOccurs="1"/>
<xs:element name="PayloadID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="PayloadLength" type="xs:int" minOccurs="1" maxOccurs="1"/>
<xs:element name="TimeStamp" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="SenderID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="ReceiverID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="CORERuleVersion" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="CheckSum" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="Payload" type="xs:base64Binary" minOccurs="1" maxOccurs="1"/>
</xs:sequence>
</xs:complexType>
</xs:element>
<xs:element name="COREEnvelopeBatchSubmissionResponse">
<xs:complexType>
<xs:sequence>
<xs:element name="PayloadType" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="ProcessingMode" type="BatchMode" minOccurs="1" maxOccurs="1"/>
<xs:element name="PayloadID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="PayloadLength" type="xs:int" minOccurs="0" maxOccurs="1"/>
<xs:element name="TimeStamp" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="SenderID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="ReceiverID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="CORERuleVersion" type="xs:string" minOccurs="1" maxOccurs="1"/>
6
Since Batch Processing Mode is not supported in this specification, some of this schema (i.e. Batch Submission) shall not be
used. The schema specification file is available at http://www.caqh.org/SOAP/WSDL/CORERule2.2.0.xsd.
Page 16 of 18
5
NHIN X12 Document Submission Service Interface Specification
v 0.3
<xs:element name="CheckSum" type="xs:string" minOccurs="0" maxOccurs="1"/>
<xs:element name="Payload" type="xs:base64Binary" minOccurs="0" maxOccurs="1"/>
<xs:element name="ErrorCode" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="ErrorMessage" type="xs:string" minOccurs="1" maxOccurs="1"/>
</xs:sequence>
</xs:complexType>
</xs:element>
<xs:element name="COREEnvelopeBatchSubmissionAckRetrievalRequest">
<xs:complexType>
<xs:sequence>
<xs:element name="PayloadType" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="ProcessingMode" type="BatchMode" minOccurs="1" maxOccurs="1"/>
<xs:element name="PayloadID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="PayloadLength" type="xs:int" minOccurs="0" maxOccurs="1"/>
<xs:element name="TimeStamp" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="SenderID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="ReceiverID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="CORERuleVersion" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="CheckSum" type="xs:string" minOccurs="0" maxOccurs="1"/>
<xs:element name="Payload" type="xs:base64Binary" minOccurs="0" maxOccurs="1"/>
</xs:sequence>
</xs:complexType>
</xs:element>
<xs:element name="COREEnvelopeBatchSubmissionAckRetrievalResponse">
<xs:complexType>
<xs:sequence>
<xs:element name="PayloadType" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="ProcessingMode" type="BatchMode" minOccurs="1" maxOccurs="1"/>
<xs:element name="PayloadID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="PayloadLength" type="xs:int" minOccurs="0" maxOccurs="1"/>
<xs:element name="TimeStamp" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="SenderID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="ReceiverID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="CORERuleVersion" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="CheckSum" type="xs:string" minOccurs="0" maxOccurs="1"/>
<xs:element name="Payload" type="xs:base64Binary" minOccurs="0" maxOccurs="1"/>
<xs:element name="ErrorCode" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="ErrorMessage" type="xs:string" minOccurs="1" maxOccurs="1"/>
</xs:sequence>
</xs:complexType>
</xs:element>
<xs:element name="COREEnvelopeBatchResultsRetrievalRequest">
<xs:complexType>
<xs:sequence>
<xs:element name="PayloadType" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="ProcessingMode" type="BatchMode" minOccurs="1" maxOccurs="1"/>
<xs:element name="PayloadID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="PayloadLength" type="xs:int" minOccurs="0" maxOccurs="1"/>
<xs:element name="TimeStamp" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="SenderID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="ReceiverID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="CORERuleVersion" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="CheckSum" type="xs:string" minOccurs="0" maxOccurs="1"/>
<xs:element name="Payload" type="xs:base64Binary" minOccurs="0" maxOccurs="1"/>
</xs:sequence>
</xs:complexType>
</xs:element>
<xs:element name="COREEnvelopeBatchResultsRetrievalResponse">
<xs:complexType>
<xs:sequence>
<xs:element name="PayloadType" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="ProcessingMode" type="BatchMode" minOccurs="1" maxOccurs="1"/>
<xs:element name="PayloadID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="PayloadLength" type="xs:int" minOccurs="0" maxOccurs="1"/>
<xs:element name="TimeStamp" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="SenderID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="ReceiverID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="CORERuleVersion" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="CheckSum" type="xs:string" minOccurs="0" maxOccurs="1"/>
<xs:element name="Payload" type="xs:base64Binary" minOccurs="0" maxOccurs="1"/>
Page 17 of 18
5
NHIN X12 Document Submission Service Interface Specification
v 0.3
<xs:element name="ErrorCode" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="ErrorMessage" type="xs:string" minOccurs="1" maxOccurs="1"/>
</xs:sequence>
</xs:complexType>
</xs:element>
<xs:element name="COREEnvelopeBatchResultsAckSubmission">
<xs:complexType>
<xs:sequence>
<xs:element name="PayloadType" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="ProcessingMode" type="BatchMode" minOccurs="1" maxOccurs="1"/>
<xs:element name="PayloadID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="PayloadLength" type="xs:int" minOccurs="0" maxOccurs="1"/>
<xs:element name="TimeStamp" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="SenderID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="ReceiverID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="CORERuleVersion" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="CheckSum" type="xs:string" minOccurs="0" maxOccurs="1"/>
<xs:element name="Payload" type="xs:base64Binary" minOccurs="0" maxOccurs="1"/>
</xs:sequence>
</xs:complexType>
</xs:element>
<xs:element name="COREEnvelopeBatchResultsAckSubmissionResponse">
<xs:complexType>
<xs:sequence>
<xs:element name="PayloadType" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="ProcessingMode" type="BatchMode" minOccurs="1" maxOccurs="1"/>
<xs:element name="PayloadID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="PayloadLength" type="xs:int" minOccurs="0" maxOccurs="1"/>
<xs:element name="TimeStamp" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="SenderID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="ReceiverID" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="CORERuleVersion" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="CheckSum" type="xs:string" minOccurs="0" maxOccurs="1"/>
<xs:element name="Payload" type="xs:base64Binary" minOccurs="0" maxOccurs="1"/>
<xs:element name="ErrorCode" type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="ErrorMessage" type="xs:string" minOccurs="1" maxOccurs="1"/>
</xs:sequence>
</xs:complexType>
</xs:element>
<xs:simpleType name="RealTimeMode">
<xs:restriction base="xs:string">
<xs:pattern value="RealTime"/>
</xs:restriction>
</xs:simpleType>
<xs:simpleType name="BatchMode">
<xs:restriction base="xs:string">
<xs:pattern value="Batch"/>
</xs:restriction>
</xs:simpleType>
</xs:schema>
Page 18 of 18
Download