Exemplo n.º 1
0
        /// <summary>
        /// Perform a identifier search on the organisation search service.
        /// </summary>
        /// <param name="request">
        /// The search criteria. The following fields are expected:
        /// <list type="bullet">
        /// <item><description>hpioNumber (Mandatory)</description></item>
        /// <item><description>linkSearchType (Conditional)</description></item>
        /// </list>
        /// All other fields are to be null.
        /// </param>
        /// <returns>
        /// A response instance containing the result of the search:
        /// <list type="bullet">
        /// <item><description>serviceMessages</description></item>
        /// <item>
        ///     <description><b>organisationProviderDirectoryEntries</b>
        ///     <list type="bullet">
        ///         <item><description>hpioNumber</description></item>
        ///         <item><description>organisationName</description></item>
        ///         <description><b>organisationDetails</b>
        ///         <list type="bullet">
        ///             <item><description>australianBusinessNumber</description></item>
        ///             <item><description>australianCompanyNumber</description></item>
        ///         </list>
        ///         </description>
        ///         <item><description>organisationService</description></item>
        ///         <item><description>address</description></item>
        ///         <item><description>electronicCommunicationRecord</description></item>
        ///         <item><description>endpointLocatorService</description></item>
        ///         <item><description>linkedProviders</description></item>
        ///         <item><description>linkedOrganisations</description></item>
        ///         <item><description>additionalComments</description></item>
        ///         <item><description>priorityNumber</description></item>
        ///     </list>
        ///     </description>
        /// </item>
        /// </list>
        /// </returns>
        public searchHIProviderDirectoryForOrganisationResponse IdentifierSearch(searchHIProviderDirectoryForOrganisation request)
        {
            Validation.ValidateArgumentRequired("request.hpioNumber", request.hpioNumber);
            Validation.ValidateArgumentNotAllowed("request.australianAddressCriteria", request.australianAddressCriteria);
            Validation.ValidateArgumentNotAllowed("request.internationalAddressCriteria", request.internationalAddressCriteria);
            Validation.ValidateArgumentNotAllowed("request.name", request.name);
            Validation.ValidateArgumentNotAllowed("request.organisationDetails", request.organisationDetails);
            Validation.ValidateArgumentNotAllowed("request.organisationType", request.organisationType);
            Validation.ValidateArgumentNotAllowed("request.serviceType", request.serviceType);
            Validation.ValidateArgumentNotAllowed("request.unitType", request.unitType);

            return(HISearch(request));
        }
Exemplo n.º 2
0
        /// <summary>
        /// Perform the service call.
        /// </summary>
        /// <param name="request">The search criteria in a searchHIProviderDirectoryForOrganisation object.</param>
        /// <returns>The search results in a searchHIProviderDirectoryForOrganisationResponse object.</returns>
        private searchHIProviderDirectoryForOrganisationResponse HISearch(searchHIProviderDirectoryForOrganisation request)
        {
            searchHIProviderDirectoryForOrganisationRequest envelope = new searchHIProviderDirectoryForOrganisationRequest();

            envelope.searchHIProviderDirectoryForOrganisation = request;
            envelope.product   = product;
            envelope.user      = user;
            envelope.hpio      = hpio;
            envelope.signature = new SignatureContainerType();

            envelope.timestamp = new TimestampType()
            {
                created          = DateTime.Now,
                expires          = DateTime.Now.AddDays(30),
                expiresSpecified = true
            };

            // Set LastSoapRequestTimestamp
            LastSoapRequestTimestamp = envelope.timestamp;

            searchHIProviderDirectoryForOrganisationResponse1 response1 = null;

            try
            {
                response1 = providerSearchHIProviderDirectoryForOrganisationClient.searchHIProviderDirectoryForOrganisation(envelope);
            }
            catch (Exception ex)
            {
                // Catch generic FaultException and call helper to throw a more specific fault
                // (FaultException<ServiceMessagesType>
                FaultHelper.ProcessAndThrowFault <ServiceMessagesType>(ex);
            }

            if (response1 != null && response1.searchHIProviderDirectoryForOrganisationResponse != null)
            {
                return(response1.searchHIProviderDirectoryForOrganisationResponse);
            }
            else
            {
                throw new ApplicationException(Properties.Resources.UnexpectedServiceResponse);
            }
        }
Exemplo n.º 3
0
        /// <summary>
        /// Perform a demographic details search on the organisation search service.
        /// </summary>
        /// <param name="request">
        /// The search criteria. The following fields can be provided:
        /// <list type="bullet">
        /// <item><description>name (Conditional)</description></item>
        /// <item><description>organisationType (Optional)</description></item>
        /// <item><description>serviceType (Optional)</description></item>
        /// <item><description>unitType (Optional)</description></item>
        /// <item><description>organisationDetails (Optional)</description></item>
        /// <item>
        ///     <description><b>australianAddressCriteria</b> (Conditional)
        ///     <list type="bullet">
        ///         <item>
        ///             <description><b>unitGroup</b> (Optional)
        ///             <list type="bullet">
        ///                 <item><description>unitType (Conditional)</description></item>
        ///                 <item><description>unitNumber (Conditional)</description></item>
        ///             </list>
        ///             </description>
        ///         </item>
        ///         <item>
        ///             <description><b>levelGroup</b> (Optional)
        ///             <list type="bullet">
        ///                 <item><description>levelType (Conditional)</description></item>
        ///                 <item><description>levelNumber (Optional)</description></item>
        ///             </list>
        ///             </description>
        ///         </item>
        ///         <item><description>addressSiteName (Optional)</description></item>
        ///         <item><description>streetNumber (Optional)</description></item>
        ///         <item><description>lotNumber (Optional)</description></item>
        ///         <item><description>streetName (Optional)</description></item>
        ///         <item><description>streetType (Conditional on if streetTypeSpecified is set to true)</description></item>
        ///         <item><description>streetTypeSpecified (Mandatory)</description></item>
        ///         <item><description>streetSuffix (Conditional on if streetSuffixSpecified is set to true)</description></item>
        ///         <item><description>streetSuffixSpecified (Mandatory)</description></item>
        ///         <item>
        ///             <description><b>postalDeliveryGroup</b> (Optional)
        ///             <list type="bullet">
        ///                 <item><description>deliveryType (Mandatory)</description></item>
        ///                 <item><description>deliveryNumber (Optional)</description></item>
        ///             </list>
        ///             </description>
        ///         </item>
        ///         <item><description>unstructuredAddressLine (Conditional)</description></item>
        ///         <item><description>suburb (Mandatory)</description></item>
        ///         <item><description>state (Mandatory)</description></item>
        ///         <item><description>postcode (Mandatory)</description></item>
        ///     </list>
        ///     </description>
        /// </item>
        /// <item>
        ///     <description><b>internationalAddress</b> (Optional)
        ///     <list type="bullet">
        ///         <item><description>internationalAddressLine (Mandatory)</description></item>
        ///         <item><description>internationalStateProvince (Mandatory)</description></item>
        ///         <item><description>internationalPostcode (Mandatory)</description></item>
        ///         <item><description>country (Mandatory)</description></item>
        ///     </list>
        ///     </description>
        /// </item>
        /// </list>
        /// All other fields are to be null.
        /// </param>
        /// <returns>
        /// A response instance containing the result of the search:
        /// <list type="bullet">
        /// <item><description>serviceMessages</description></item>
        /// <item>
        ///     <description><b>organisationProviderDirectoryEntries</b>
        ///     <list type="bullet">
        ///         <item><description>hpioNumber</description></item>
        ///         <item><description>organisationName</description></item>
        ///         <description><b>organisationDetails</b>
        ///         <list type="bullet">
        ///             <item><description>australianBusinessNumber</description></item>
        ///             <item><description>australianCompanyNumber</description></item>
        ///         </list>
        ///         </description>
        ///         <item><description>organisationService</description></item>
        ///         <item><description>address</description></item>
        ///         <item><description>electronicCommunicationRecord</description></item>
        ///         <item><description>endpointLocatorService</description></item>
        ///         <item><description>linkedProviders</description></item>
        ///         <item><description>linkedOrganisations</description></item>
        ///         <item><description>additionalComments</description></item>
        ///         <item><description>priorityNumber</description></item>
        ///     </list>
        ///     </description>
        /// </item>
        /// </list>
        /// </returns>
        public searchHIProviderDirectoryForOrganisationResponse DemographicSearch(searchHIProviderDirectoryForOrganisation request)
        {
            Validation.ValidateArgumentNotAllowed("request.hpioNumber", request.hpioNumber);
            Validation.ValidateArgumentNotAllowed("request.linkSearchType", request.linkSearchType);

            if (request.australianAddressCriteria != null)
            {
                Validation.ValidateArgumentNotAllowed("request.internationalAddressCriteria", request.internationalAddressCriteria);
                Validation.ValidateArgumentRequired("request.australianAddressCriteria.suburb", request.australianAddressCriteria.suburb);
                Validation.ValidateArgumentRequired("request.australianAddressCriteria.state", request.australianAddressCriteria.state);
                Validation.ValidateArgumentRequired("request.australianAddressCriteria.postcode", request.australianAddressCriteria.postcode);
            }

            if (request.internationalAddressCriteria != null)
            {
                Validation.ValidateArgumentNotAllowed("request.australianAddressCriteria", request.australianAddressCriteria);
                Validation.ValidateArgumentRequired("request.internationalAddressCriteria.internationalAddressLine", request.internationalAddressCriteria.internationalAddressLine);
                Validation.ValidateArgumentRequired("request.internationalAddressCriteria.internationalStateProvince", request.internationalAddressCriteria.internationalStateProvince);
                Validation.ValidateArgumentRequired("request.internationalAddressCriteria.internationalPostcode", request.internationalAddressCriteria.internationalPostcode);
                Validation.ValidateArgumentRequired("request.internationalAddressCriteria.country", request.internationalAddressCriteria.country);
            }

            return(HISearch(request));
        }
        public void Sample()
        {
            // ------------------------------------------------------------------------------
            // Set up
            // ------------------------------------------------------------------------------

            // Obtain the certificate by serial number
            X509Certificate2 tlsCert = X509CertificateUtil.GetCertificate(
                "Serial Number",
                X509FindType.FindBySerialNumber,
                StoreName.My,
                StoreLocation.CurrentUser,
                true
                );

            // The same certificate is used for signing the request.
            // This certificate will be different to TLS cert for some operations.
            X509Certificate2 signingCert = tlsCert;

            // Set up client product information (PCIN)
            // Values below should be provided by Medicare
            ProductType product = new ProductType()
            {
                platform       = "Your system platform (Eg. Windows XP SP3)", // Can be any value
                productName    = "Product Name",                              // Provided by Medicare
                productVersion = "Product Version",                           // Provided by Medicare
                vendor         = new QualifiedId()
                {
                    id        = "Vendor Id",                                // Provided by Medicare
                    qualifier = "Vendor Qualifier"                          // Provided by Medicare
                }
            };

            // Set up user identifier details
            QualifiedId user = new QualifiedId()
            {
                id        = "User Id",                                      // User ID internal to your system
                qualifier = "http://<anything>/id/<anything>/userid/1.0"    // Eg: http://ns.yourcompany.com.au/id/yoursoftware/userid/1.0
            };

            // Set up user identifier details
            QualifiedId hpio = new QualifiedId()
            {
                id        = "HPIO",                                       // HPIO internal to your system
                qualifier = "http://<anything>/id/<anything>/hpio/1.0"    // Eg: http://ns.yourcompany.com.au/id/yoursoftware/userid/1.0
            };

            // ------------------------------------------------------------------------------
            // Client instantiation and invocation
            // ------------------------------------------------------------------------------

            // Instantiate the client
            ProviderSearchHIProviderDirectoryForOrganisationClient client = new ProviderSearchHIProviderDirectoryForOrganisationClient(
                new Uri("https://HIServiceEndpoint"),
                product,
                user,
                hpio,
                signingCert,
                tlsCert);

            // Set up the request
            searchHIProviderDirectoryForOrganisation request = new searchHIProviderDirectoryForOrganisation();

            request.hpioNumber = HIQualifiers.HPIOQualifier + "8003624166667003";

            try
            {
                // Invokes an identifier search
                searchHIProviderDirectoryForOrganisationResponse response = client.IdentifierSearch(request);
            }
            catch (Exception ex)
            {
                // If an error is encountered, client.LastSoapResponse often provides a more
                // detailed description of the error.
                string soapResponse = client.SoapMessages.SoapResponse;
            }
        }