⚠️ Please ensure you have read the upgrade notes from the PREVIOUS RELEASE, if upgrading from an earlier version
- The
/api/userCredentials
API endpoint is removed. API users should use the/api/users
and/api/userLookup
API endpoints instead. - The APIs related to charts (
/api/charts
) and report tables (/api/reportTables
) are removed. Consumers should use the Visualization API instead (/api/visualizations
). Other existing endpoints that make any kind of reference to Chart and Report Table will now reference Visualization.
- The existing
F_GENERATE_MIN_MAX_VALUES
authority is now required to generate min-max values in the data administration app. PreviouslyF_PERFORM_MAINTENANCE
was required. - Creating data approval levels requires the
F_DATA_APPROVAL_LEVEL
authority. - Creating data approval workflows requires the
F_DATA_APPROVAL_WORKFLOW
authority.
In 2.38 we will be changing the default location of audits from the database to a logfile called dhis-audits.log
. If you don't want this
behavior and want to be futureproof it's recommended that you add these lines to your dhis.conf
:
audit.database = on
audit.logger = off
GET /systemSettings
returning JSONP (Accept=application/javascript
) was removed
Please note that from 2.38 onwards several API endpoints slightly change
their response root object to be in line with the majority of endpoints.
The root object returned pre 2.38 will become the member named response
of the root object returned by 2.38. Consumers can opt to either use
/api/37/...
to get the old behaviour or have to unpack to new response
by doing <root>.response
to resolve the old root from the 2.38 response.
In case of error responses this also entails an HTTP status code change from 200 OK
to 409 Conflict
.
Affected endpoints are:
POST /api/completeDataSetRegistrations
withJSON
/XML
(only nonasync
affected)POST /api/dataValueSets
withJSON
/XML
/ADX
/CSV
(only nonasync
affected)POST /api/metadata
withJSON
/XML
/GML
/CSV
(only nonasync
affected)POST /api/predictions
(only nonasync
affected)PUT /api/predictions
(only nonasync
affected)PUT /api/relationships/{id}
PUT /api/users/{uid}
withJSON
/XML
Depending on the DHIS2 version you're updating from, you may face migration issues/errors related to the removal of ReportTable and Chart tables. The failure could be caused by tables that are still present in very old versions of DHIS2. Even though they are not in usage they might still be referenced. This will cause errors when the migration scripts try to remove ReportTable and Chart tables because of the constraints present in those legacy tables. More details related to this issue can be found at https://jira.dhis2.org/browse/DHIS2-12601
Once those problems are identified and confirmed, a few legacy tables need to be dropped before attempting the migration to DHIS2 2.37.
Below we list the SQL statements that need to be executed directly in your PostgreSQL instance. These SQL statements are applicable if your starting DHIS 2 version is between 2.24 and 2.31 (inclusive).
DROP TABLE IF EXISTS charttranslations CASCADE;
DROP TABLE IF EXISTS reporttabletranslations CASCADE;
DROP TABLE IF EXISTS dashboarditem_reporttables CASCADE;
DROP TABLE IF EXISTS dashboarditem_charts CASCADE;
Assuming the statements are successfully executed you will be able to try the upgrade again.
During the upgrade process, the migration related to SMS codes might fail depending upon if database has invalid categoryoptioncomboid or not. The migration in question is named V2_37_46__Add_coc_fk_in_smscode.sql. If this occurs, you can resolve it using the SQL script provided below. More details can be found at https://dhis2.atlassian.net/browse/DHIS2-15169.
After applying the script, retry the upgrade process. This should resolve the issue and allow the upgrade to complete successfully.
Note: Please ensure you have a proper backup before executing any SQL scripts during the upgrade.
-- Set invalid cat option combos to default
update smscodes set optionid = (
select categoryoptioncomboid from categoryoptioncombo where name = 'default')
where optionid not in (
select distinct categoryoptioncomboid from categoryoptioncombo)
or optionid is null;