-
Notifications
You must be signed in to change notification settings - Fork 766
Upgrading
MITREid Connect strives to keep data schemas and most major dependencies steady within a release stream. Upgrades within a stream can usually be accomplished by simply replacing the component with its new version.
The Spring and Spring security version dependencies often change between version streams. This necessitates changes to the schema references for any configuration files. See the default configuration files in the main project for examples of the proper references.
The underlying data model changes between version streams, and updates to the database are required. As such, existing data must be exported and re-imported during an upgrade if it is desired to be retained. There are no supported means for modifying the database directly.
MITREid Connect's data API can be used to support backup/restore and upgrades. Each version stream of MITREid Connect can import data exports from previous versions, but not from future versions. For example, a 1.3
server can import data from 1.2
or 1.1
, but 1.2
can't import from 1.3
.
To access this API, log in as an administrator and send a GET
request to /api/data
to return the JSON object representing the server's current state. NOTE WELL: this export includes information including tokens, authentication objects, client secrets, and other sensitive security information. Therefore, the data export must be protected.
To re-import this data, log in as an administrator on a newly-installed server and send a POST
request to /api/data
with a content type of application/json
and the fully-formed JSON document exported from the API. This import MUST be done on an empty database with full schema or else you risk newly imported objects conflicting with existing objects.
The recommended process is as follows:
- Log into the old server as an administrator
- Export the server state by performing a
GET
request on/api/data
, save as a JSON file - Shut down the old server
- Connect to the MySQL or HSQL database as a user with appropriate rights
- Clear the database, remove all tables related to OIDC
- Initialize the database with the empty schema
- Deploy the version new server
- Log into the new server as an administrator
- Import the server state from the saved JSON file by performing a
POST
request to/api/data
with the data exported
Software is available under the Apache 2.0 license. Documentation available under the Creative Commons 3.0 By-NC license.