- Facility Migrations
- NCA (National Cemetery Administration) Facilities
- VAMC (VA Medical Center) Facilities
- VBA (Veterans Benefits Administraion) Facilities
- Vet Centers, Mobile VCs, and Vet Center Outstions
- Status Changes to Lighthouse
graph TD;
vast[VAST, Access To Care, etc]-- 7:30AM -->fapi;
fapi[(Facility API)]-- 8:00AM -->migrations[CMS migrations];
fapi-->fl[[Facility Locator App]];
teamsite[Teamsite Status Lovell only]-- every 15 min -->migrations;
migrations-->nodes[Nodes: VAMC, Vet Centers, VBA, NCA];
nodes-->FE[[FE pages]];
nodes-->data
data[CMS supplemental data: status, health services] -- On change in CMS -->fapi;
Facility migrations occur once per day and the six types of facilities are updated with any data from the Facility API including the creation of new facilities, updating titles, addresses, etc. The facility is connected to the facility API by its unique "Facility Locator API ID"
When a new facility appears in the Facility API, it is created in the CMS in draft state. It will need the following operations performed. It is flagged as "new" and appears on the Flagged dashboard. An email message is sent to CMS Support to kick off the New Facility Runbook.
Updates to facility address or hours are updated and maintain the current moderation state of the facility node. If the node is published, the new changes will become published. These changes are routine and need no intervention. If a title changes, the title of the facility updates but the name change does NOT. In the event of a title change, the facility is flagged and appears on the Flagged dashboard to kick off the Facility Name Change Runbook.
When a facility is removed from the Facility API, a nightly scan (drush va_gov_migrate:flag-missing-facilities) reveals that it has been removed and flags it "Removed from source". The flag makes it appear on the Flagged dashboard to kick off the Facility Closed Runbook.
The nightly migrations are handled as part of our tasks-periodic.yml and are triggered by Jenkins at midnight. Revisions for any saves are created and attributed to the user "CMS Migrator"
- NCA (National Cemetery Administration) Facilities - va_node_facility_nca
- VAMC (VA Medical Center) Facilities - va_node_health_care_local_facility
- VBA (Veterans Benefits Administraion) Facilities - va_node_facility_vba
- Vet Centers - va_node_facility_vet_centers
- Mobile Vet Centers - vet_center_mobile_vet_center
- Outstations - vet_center_outstation
- Vet Center Community Access Points - vet_center_cap The CMS is the source of truth for these and will be pushing data to the facility API not migrating from it.
VAMC Statuses are updated by a separate migration va_node_health_care_local_facility_status
that runs every 15 min. It grabs only a single CSV for Lovell Federal health care which is scraped from TeamSite (hosted by EWIS) and updates the fields:
- "Operating status" (
field_operating_status_facility
) - "Operating status - more info" (
field_operating_status_more_info
)
Changes to operating status also get pushed to Lighthouse.
These are created and run as needed as part of the VAMC Upgrade teams effort to get all the services into the CMS. VAMC upgrade team will provide separate CSVs, one for system health services and one for facility health services.
There are dependencies in the migration that will cause a migrated item to be skipped and create a migration message:
- System Health Service Dependencies
- National Service Taxonomy term must exist.
- The System must exist.
- Facility Health Dependencies
- System Health Service must exist (which is why the system health service migration must be run first)
- VAMC facility must exist.
A migration should not be considered complete if there are ANY migrate messages logged.
ddev drush migrate:status {migration_id}
- gives the status of the migration. Number of items total, number unprocessed.ddev drush migrate:reset-status {migration_id}
- Resets a migration that may have not completed due to a fatal error.ddev drush migrate:rollback {migration_id}
- Rolls back all items tracked by the migration.ddev drush migrate:messages {migration_id}
- List any messages from the last run of the migration. Subsequent runs of the migration will remove ald messages. When run in the UI, this list only includes any messages from the last batch (which my only be the last 25 things migrated).- Useful options
--id-list={ID}
- Limits the command to just a specific row/item in the migration. Useful for rolling back and re-migrating a specific troublesome item. The ID is the row ID based on what unique ID is defined in the migration.--limit={quantity}
- limits the action to a specific number of items.
For these migrations to function, you'll need to obtain a Facility API Key from a member of the development team and place the key, along with the following code, into your settings.local.php file. This file should be located in docroot/sites/default/settings.local.php
.
<?php
$settings['post_api_endpoint_host'] = 'https://sandbox-api.va.gov';
$settings['post_api_apikey'] = 'PASTE_KEY_HERE';
$facility_api_urls = ['https://sandbox-api.va.gov/services/va_facilities/v0/facilities/all'];
$facility_api_key = $settings['post_api_apikey'];
$facility_migrations = [
'va_node_health_care_local_facility',
'va_node_facility_vba',
'va_node_facility_nca',
'va_node_facility_vet_centers',
'va_node_facility_vet_centers_mvc',
'va_node_facility_vet_centers_os',
];
foreach ($facility_migrations as $facility_migration) {
$config["migrate_plus.migration.{$facility_migration}"]['source']['urls'] = $facility_api_urls;
$config["migrate_plus.migration.{$facility_migration}"]['source']['headers']['apikey'] = $facility_api_key;
}
- Edit or create a new migration configuration in docroot/modules/custom/va_gov_migrate/config/install
- Use
ddev migrate-sync
to copy the config into config/sync imported it and export it again. Always work inva_gov_migrate/config/install
and then sync. This preserves any comments in the migration yml. - Preflight any new data from the VAMC upgrade team in libre office by importing the CSV with the import config set to separator: ; and encapsulation: '. Look for jumped columns missing data or the appearance of wrapping quotes.
- Append the data to an existing CSV or add it as new (if you are dealing with thousands, add it as new.) Name the file as a match to the id of the migration you are creating.
- Run the System Health Service migration. Look for presence of migrate messages. The messages will indicate the problems with the data. Fix, rollback, repeat until there are no messages created and the row count of the data, matches the created count.
- Run the Facility Health Service migration. Look for messages. The messages will indicate the problems with the data. Fix, rollback, repeat until there are no messages created and the row count of the data, matches the created count.