Skip to content

Data Integration With Vim - File-Based Integration

File-based integration allows organizations to securely share structured data with Vim via an sFTP server. Through this secure connection, structured data files are shared for each Vim application, with separate files for each app. These files follow a specified format and delivery cadence. Upon receiving a file, Vim validates and filters for invalid rows, then securely ingests the data under a dedicated namespace. As Gaps are addressed via Vim applications, Vim provides reporting passbacks to inform the data connection, facilitating accurate gaps file updates. This process ensures that the data is available, on demand, for use in Vim applications, enhancing application security and usability. Integration Flow Diagram This section will outline in detail the requirements and deliverables for the file-based integration between Vim and a data source.

Setting Up the sFTP Connection

The first step will be setting the sFTP connection to allow sharing files from the data source → Vim and from Vim → data source. Vim will be hosting the sFTP connection supporting public key-based authentication allowing a secure method for logging in via RSA SSH. This authentication method requires:

  • RSA SSH keys: This authentication method requires a public key and private key. The public key will be shared with Vim, while the private key will use the data source to connect to the sFTP server
  • IP whitelisting: Vim is allowing only identified IPs to access the sFTP server. The data source will share the IP addresses, or range of addresses, that will be allowed access to the sFTP server. Vim supports up to 20 IP addresses
  • Access details: Vim will define and share with the data source the username and hosting URL for the connection To authenticate with the Vim sFTP server, the data source will use the username provided by Vim and the private key they have created. Vim will verify it with the public key The sFTP server will hold two folders:
  • from Vim: All the files sent from Vim to the data source will be placed in this folder
  • from <data_source_name>: All the files sent from the data source will be placed in this folder For public key-based authentication hosted by the data source, please contact a Vim representative.

Preparing Your File

A prerequisite to the integration with Vim is a generation of a file following the specifications in this section. The file should contain the data your organization wants to share with providers, structured in the outlined format to support accurate processing.

File Level Specification and Configurations

Vim supports several configurations of the file, including different formats and cadence of sharing the file, as well as configurations that would impact the ingestion logic and the data presented in the application. In the following section, you can find the details of each specification and supported configuration.

File Format and Structure

Below you can find the specifications expected and the configurations supported for the file shared with Vim including the data to be presented in the application:

  • A file per gap type: Vim is expecting a separated file for diagnosis gaps and care gaps (file schema can be found below)
    • Vim also supports receiving a member eligibility file
  • File naming convention: <customer_name>_<gap_type_name>_<yyyy-mm-dd>.<format>. The naming convention format will be enforced during the ingestion process, file names that are not recognized will not be ingested
  • Accepted gap type names: diagnosis_gaps, care_gaps
  • Accepted characters: only lowercase letters, no spaces
  • File format: csv, txt, xls
    • The file can be zipped
    • Encrypted files are not supported out-of-the-box, please contact a Vim representative to support encrypted files
  • File delimiter: Comma or pipe
  • Encoding: UTF-8
  • Cadence: Daily, weekly, or monthly to your preference

File content Ingestion Configurations

Below you can find the configurations supported by the file ingestion logic allowing you to share data in the Vim application:

ConfigurationRelevant Data SetDescriptionMandatory?Optional Configurations
Gap systemDiagnosis gapsAllowing to define which gap type (ICD/ HCC) should be the primary gap presented in the applicationYesHCC/ ICD/ Hybrid*
Gap model versionDiagnosis gapsAllowing to define the default model version of the gaps sharedYesCMS HCC V24/ CMS HCC V28/ HHS-HCC/ RX-HCC V08/ Hybrid*
Gap status filteringDiagnosis gaps
Care gaps
Supporting filtering gaps form the display based on the gap's statusNoIndicate the statuses Vim should present in the application: Open/ In Progress/ Not Closed/ Closed
Custom fieldsDiagnosis gaps
Care gaps
Sharing additional specific information on the gap or patient, to be presented in the application Supporting up to 3 fieldsNoDetails to be provided per custom field: the title of the field to be present in the app, the entity the custom filed relates to (patient or gap), the type of the field (date, string, integer, decimal, URL)
Additional CPT code or descriptionsCare gapsVim's default mapping can be enhanced to add additional CPT codes or descriptionsNoYes - provide your mapping enhancements No - use Vim's default mapping
  • Hybrid: when more than one option is expected to be sent in the file. In that case the gap configuration should be specified in the file per gap in the appropriate field as indicated in the "data fields" sections

Required Data Fields Row Level Specifications

The received file is expected in the following structure and fields. Each data type (diagnosis gaps, care gaps) will require a separated file following the specifications below.

Diagnosis Gaps File Schema

This table outlines the expected file schema, accepted data types, and field names that will be provided to Vim for ingestion Diagnosis Gaps data and display in the application:

Field NameDescriptionRequired?TypeValid Values/FormatUI displayExample
patient_first_nameThe patient's first nameRequiredStringLetters only, up to 50 charactersTRUEJohn
patient_last_nameThe patient's last nameRequiredStringLetters only, up to 50 charactersTRUEDoe
unique_patient_idAn internal identifier shared by the customer that uniquely identifies a patient in the fileRequiredStringLetters + digits, up to 50 charactersFALSE1234qwer
patient_dobThe patient's date of birthRequiredDateYYYY-MM-DDTRUE1990-07-19
patient_insurance_idThe id of the patient in the health plan (member/ subscriber_id)Required - at least one of these fields is requiredStringUp to 50 charactersFALSE123445455
ehr_patient_idThe patient's EHR unique identifierOptional - once one field is sharedStringUp to 50 charactersFALSEa1b2c3d4
patient_zip_codeThe patient's Zip codeStringxxxxx/xxxxx-xxxx/xxxxxxxxxFALSE90210
patient_insurerThe patient's insurance companyOptionalStringUp to 50 charactersFALSEUnited Health Care
patient_stateThe patient's US stateOptionalStringUS states codes onlyFALSEFL
gap_idAn ID that identifies a unique gap per gap code and patientRequiredStringUp to 50 charactersFALSE1234567890
gap_systemDefining the primary gap code presented in appRequired for Hybrid filesEnumHCC/ICDFALSEHCC
hcc_codeThe HCC gap code to presentRequiredStringCMS codes onlyTRUE18
hcc_descriptionDescription of the HCC codeOptionalStringUp to 250 charactersTRUEDiabetes with chronic complications
icd_codeThe ICD code to presentRequired for ICD system, Optional for HCCStringCMS codes onlyTRUEE11.21
icd_descriptionDescription of ICD codeRequired for ICD system, Optional for HCCStringUp to 250 charactersTRUEDM with nephropathy
hcc_model_versionSpecific HCC model version if CMSRequired for Hybrid, Optional otherwiseEnumCMS-HCC V24/V28/HHS-HCC/RX-HCC V08TRUECMS-HCC V24
gap_backgroundPreviously coded vs suspected diagnosisOptionalEnumKNOWN/SUSPECTEDTRUEKNOWN
gap_statusGap's status for filteringOptionalEnumOPEN/IN PROGRESS/NOT CLOSED/CLOSEDFALSEOPEN
gap_raf_scoreRisk adjustment factorOptionalNumericNot accepting "-"TRUE2.659
gap_sourceSource of the gapOptionalStringUp to 250 charactersTRUE2024 claims
last_recorded_dosMost recent recorded dateOptionalDateYYYY-MM-DDTRUE1990-07-19
last_recorded_npiNPI of most recent providerOptionalNumeric10 digitsTRUE1234567890
last_recorded_npi_nameName of most recent providerOptionalStringUp to 100, letters onlyTRUEJohn Smith
notesAdditional gap informationOptionalStringUp to 250 charactersTRUEPlease address all suggested gaps
custom_field_1_valueAdditional custom informationOptionalAs configuredAs configuredTRUE2.51
custom_field_2_valueAdditional custom informationOptionalAs configuredAs configuredTRUE-
custom_field_3_valueAdditional custom informationOptionalAs configuredAs configuredTRUE-
Care Gaps Data Schema

This table outlines the expected file schema, accepted data types, and field names that will be provided to Vim for ingestion Care Gaps data and display in the application:

Field NameDescriptionRequired?TypeValid Values/FormatUI displayExample
patient_first_nameThe patient's first nameRequiredStringLetters only, up to 50 charactersTRUEJohn
patient_last_nameThe patient's last nameRequiredStringLetters only, up to 50 charactersTRUEDoe
unique_patient_idInternal patient identifierRequiredStringLetters + digits, up to 50 charactersFALSE1234qwer
patient_dobPatient's date of birthRequiredDateYYYY-MM-DDTRUE1990-07-19
patient_insurance_idHealth plan member IDRequired - at least oneStringUp to 50 charactersFALSE123445455
ehr_patient_idEHR patient identifierOptional after one requiredStringUp to 50 charactersFALSEa1b2c3d4
patient_zip_codePatient's zip codeStringxxxxx/xxxxx-xxxx/xxxxxxxxxFALSE90210
patient_insurerInsurance companyOptionalStringUp to 50 charactersFALSEUnited Health Care
patient_stateUS stateOptionalStringUS states codes onlyFALSEFL
gap_typeCare gap categoryOptionalEnumCustomer provided list *Will be available in early Q2 2025TRUEHEDIS
gap_idUnique gap identifierRequiredStringUp to 50 charactersFALSE1234567890
gap_codeGap codeAt least one requiredString-TRUE18
gap_display_nameGap descriptionStringUp to 250
cpt_II_codeRecommended CPT II code associated with the gapOptionalStringUp to 100, letters onlyTRUEJohn Doe
cpt_II_descriptionRecommended CPT II description associated with the gapOptionalStringUp to 100, letters onlyTRUEMost recent systolic BP less than 130 mm Hg
gap_statusThe gap's status, allowing to filter the gaps displayed in the UI according to the desired statusOptionalEnumopen, not closed, closed, in progressFALSEopen
gap_sourceThe gap's sourceOptionalStringUp to 250TRUE2021 claims
collection_dateDate in which the prior values were documentedOptionalNumericYYYY-MM-DDTRUE1234567890
required_actionThe action that should be taken by the healthcare providerOptionalNumericNot accepting "-"TRUE2.659
last_recorded_dosMost recent recorded date of the diagnosis being coded by a providerOptionalDateYYYY-MM-DDTRUE1990-07-19
last_recorded_npiNPI of the most recent coding providerOptionalNumeric10 digitsTRUE1234567890
last_recorded_npi_nameName of the most recent coding providerOptionalStringUp to 100, letters onlyTRUEJohn Doe
notesAdditional information related to the gapOptionalStringUp to 250TRUEPlease address all suggested gaps
custom_field_1_valueAdditional customized informationOptionalAs configuredAs configuredTRUE2.51
custom_field_2_valueAdditional customized informationOptionalAs configuredAs configuredTRUE-
custom_field_3_valueAdditional customized informationOptionalAs configuredAs configuredTRUE-
How Data Will Be Presented in the Application

Some of the fields sent in the files will be presented in the UI, below you can find the data that will presented in the Care Insights application:

Diagnosis Gaps Data

Vim Connect Overview

Care Gaps Data

Vim Connect Overview

File Ingestion Process

Vim's ingestion process will ingest the latest file received via sFTP with the configured file name. This is a full refresh process where the new data entirely replaces the old data, without introducing downtime. The process will not allow partial ingestion when the process has not been completed successfully.

Data Validations

As part of the ingestion process Vim is validating the file received. Upon a file rejection, the data will not be ingested and Vim will contact the data connection to notify the issue and resolution path. A file will not be ingested upon:

  1. Ingestion process will not start when the file was not received in the expected format, naming convention or delimiter
  2. The file is empty
  3. The file does not include headers
  4. Changes in the file schema: new columns, deleted columns, changes to column name, changes to column type or changes in column order
  5. The data type deviates from the definitions in the BRD
  6. The file size is 60% lower/higher than the previous file

During the ingestion process, Vim is validating that all the data entries meet the requirements. Data entries that will not meet the requirements will be excluded and will not be visible to the end user. These rows will be added to a gating file, which will be sent back to the customer via the SFTP connection. Rows will be excluded upon:

  1. Any required fields are empty
  2. At least one of these three fields are missing: member_id, ehr_patient_identifier, zip_code
  3. The unique patient ID or gap ID are not unique (all duplicated rows will be excluded)

Failed Gaps Gating File

A gating file, indicating rows with violations that were not ingested, will be shared following every ingestion (daily). The file will include the rows that were rejected along with the reason for the row rejection.

Feedback Loop

Vim tracks user actions and sends structured feedback passback to the customer for reporting and data updates, allowing the data source to monitor and update the gaps that were addressed. Feedback files are shared through the same sFTP connection.

File Format and Structure

  1. File name: <CUSTOMERNAME>YYYY_MM_DD__HH_MM_SS<diagnosis/quality>_gaps_report
  2. File type: CSV
  3. File delimiter: Comma or pipe, where pipe is the default
  4. Cadence: Daily, weekly or monthly to your preference
    • Recommended - in alignment with the cadence of the gaps files send - daily if a refresh file is sent from the customer on a daily basis
  5. Coverage timeframe: Day, week, or month to your preference
    • Recommended - according to the cadence of the gaps files send - if the files refreshes daily, sharing the passback daily to share data on the past day
  6. Sending time: A time at the end of the working day of the customers, to capture all the actions of the past day to your preference
    • The configuration of the sending time should take into account the sFTP sync processes

Shared Data Fields

The feedback passback format below applies to both gaps data sets and will be sent separately for each diagnosis and/or care gaps data:

Field NameDescriptionRequired?TypeExample Diagnosis GapsExample Care Gaps
organization_nameThe user's in session organization's name as defined in the Vim systemRequiredvarcharScott's ClinicScott's Clinic
vim_organization_keyThe unique organization ID as available in the Vim systemRequiredvarchar8i7owzgbgo6zJHYNxkNLRc8i7owzgbgo6zJHYNxkNLRc
user_first_nameThe user's in session first name as defined in the Vim systemOptionalvarcharScottScott
user_last_nameThe user's in session last name as defined in the Vim systemOptionalvarcharCohenCohen
ehr_usernameThe user's in session EHR usernameOptionalvarcharscott.cohenscott.cohen
user_npiThe user's in session National Provider Identifier (NPI)Optionalvarchar(10)84957384758495738475
encounter_idThe ID of the patient's EHR encounter which is in context during the sessionOptionalvarchar859574859574
encounter_dateThe date of the patient's EHR encounter which is in context during the session (according to the organization's timezone)OptionalDate (YYYY-MM-DD)2023-10-172023-10-17
gap_systemThe type of gaps presented in the application Shared only for Diagnosis GapsRequiredvarcharhccN/A
gap_idThe unique ID of the gap selected during the sessionRequiredvarchar32fn48f347g4rg
gap_codeThe code of the gap selected during the sessionRequiredvarchar82CBP
gap_descriptionThe description of the gap selected during the sessionOptionalvarcharAssess Drug DependenceControlling Blood Pressure
selected_medical_codesThe medical code(s) selected during the sessionOptionalvarchar
action_dateThe date of the reported action (EST)Requireddate (YYYY-MM-DD)2023-10-192023-10-19
action_typeThe type of the reported actionRequiredtextacceptdismiss
action_reasonThe reason of the reported actionOptionalvarcharADDEVALUATE_NEXT_VISIT
action_additional_commentsThe free text added by the user for the reported action. Available only for the "dismiss" action_typeOptionalvarcharnot seen today
patient_customer_idThe unique customer internal patient identifier received by the customerRequiredvarchar738463738463

Testing the Integration

Vim supports the data source with the ability to perform end to end testing of the integration on Vim's mock EHR. If you wish to perform end to end testing in lower environments, please contact a vim representative.

Recommended: to be able to perform a production verification of the integration prior to the rollout, Vim supports adding dummy patients to the production file. A dummy patient should include the word "test" in the patient's first or last name.

Monitoring and Support

Vim is committed to knowledge and identify the root cause upon file ingestion failure within 24 hours from ingestion process start (excluding weekends).

For questions or technical assistance, contact Vim's Support Team at [email protected].