Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Expand
titleTable Of Contents
Table of Contents
stylenone

Introduction

Last Updated 11/21/24

This document provides a detailed mapping between the properties of the JSON response and the NextGen API schema
for the Mandate Extraction and Analysis API. The goal is to demonstrate how each property in the utilized Legacy Services API JSON
response corresponds to properties in the NextGen JSON schema, facilitating a smooth transition and integration.

General Overview

  • Legacy Services API Approach: Requires creating a Shared Authority Document List and invoking APIs using the List ID or Authority Document ID. Returns all Authority Document metadata, Citations, Mandates, and Common Controls in a single payload.

  • New NextGen API Approach: Eliminates the need for Shared Authority Document Lists. Authority Document metadata, Citations, Mandates, and Common Controls are accessed through separate, dedicated endpoints.

Example:

  • Legacy Services API: /authority-document/:id/details (Returns all related data in one response)

  • New NextGen API:

    • /authority-document/:id (Metadata)

    • /authority-document/:id/citation (Citations)

    • /authority-document/:id/mandate (Mandates)

    • /authority-document/:id/control (Common Controls)


Backward Compatibility: Legacy (CCH) Authority Document IDs

Warning

Note due to the 12/3/24 change request (see /wiki/spaces/ICP/pages/2707947567) - we will be leveraging legacy IDs in Nextgen where possible. The below endpoints and workflows will no longer be necessary by December 20th 2024.

You can retrieve Authority Documents using legacy IDs via the /authority-document/legacy/:id endpoint to fetch the new elementid for subsequent API calls.

  • Retrieve Authority Document by Legacy ID

    • GET /authority-document/legacy/:id

      • Path Variables:

        • :id : The legacy CCH elementIdprefixed by “legacy”, ie. legacy-3304 (would retrieve 3304)

    • This endpoint returns the NextGen Authority Document ID and and legacy ID .(in the coreMetaData object)

    • The NextGen AD ID is required for all subsequent API requests (to retrieve metadata, citations, mandates & controls)

Furthermore, when retrieving the metadata of an authority document from NextGen, the legacy CCH elementId will be returned as a property.

  • MetaData Example: For example:

Code Block
languagejson
{
    "@context": "URL",
    "@id": "URL",
    "@type": "string",
    "elementId": "string",
    "schemaVersion": "string",
    "authorityDocumentType": "string",
    "officialName": "string",
    "legacyId": "string",
    .........
}

Endpoint & Property Mapping

  • Legacy Services API: Properties from the CCH Services API JSON response.

  • New NextGen JSON: Corresponding properties in the NextGen API schema.

  • Notes: Additional information or context about the mapping.

Endpoints

Function

Legacy Services API

NextGen API

Notes

Get Account Information

/my-account

/my-account

Returns information about the account.

Search for Authority Documents

Not Available

/authority-document?page=1&perPage=100&search=<value>

Returns documents containing the search term. Optionally remove the search parameter to retrieve all documents.

Retrieve Authority Document

/authority-document/:document-id/details

/authority-document/:id

Legacy returns the document metadata, all citations, all mandates and all controls. NextGen only returns the document metadata.

Search for Citations in a document

Not Available

/authority-document/:id/citation?page=1&perPage=100&search=<value>

Returns citations containing the search term. Optionally remove the search parameter to retrieve all citations for the document.

Retrieve a specific Citation

Not Available

/authority-document/:id/citation/:citationId

NextGen can retrieve specific citations within a document

Search for Mandates in a document

Not Available

/authority-document/:id/mandate?page=1&perPage=100&search=<value>

Returns mandates containing the search term. Optionally remove the search parameter to retrieve all mandates for the document.

Retrieve a specific Mandate

Not Available

/authority-document/:id/mandate/:mandateId

NextGen can retrieve specific mandates within a document.

Search for Controls in a document

Not Available

/authority-document/:id/control?page=1&perPage=100&search=<value>

Returns controls containing the search term. Optionally remove the search parameter to retrieve all controls for the document.

Retrieve a specific Common Control

Not Available

/authority-document/:id/control/:controlId

NextGen can retrieve specific controls within a document

Retrieve all Common Controls for a list of Authority Documents

/cch-ad-list/:list-id/tracked-controls/details

/authority-document/:id/control?page=1&perPage=100

Legacy returns all common controls for all documents in the list. For NextGen, retrieve all of the controls for one document at a time.

Top-Level Properties

JSON Property Mapping Matrix

Legacy Services API

New NextGen

Notes

live

coreMetaData.live

Indicates if the mandate is active.

deprecated_by

coreMetaData.deprecatedBy

URL indicating what deprecated the mandate.

deprecation_notes

coreMetaData.notes

Additional notes on deprecation.

time_created

coreMetaData.created.timeStamp

Timestamp when the mandate was created.

date_added

coreMetaData.created.timeStamp

Date when the mandate was added.

time_updated

coreMetaData.modified.timeStamp

Timestamp when the mandate was last updated.

date_modified

coreMetaData.modified.timeStamp

Date when the mandate was modified.

language

language.name

Language of the mandate (e.g., "eng").

license_info

license.url

URL to the license terms.

sort_value

hierarchyItems.sortValue

Used for sorting mandates.

genealogy

hierarchyItems.hierarchicalParents

Represents the hierarchical lineage.

sort_id

hierarchyItems.sortPath

Calculated value for quick sorting

reference

primaryCitation.reference

The citation reference string.

guidance

primaryCitation.taggedText.text

The primary citation text the mandate is derived from.

guidance_as_tagged

taggedText.text

The mandate text (Full text of primary citation, additional citation, and additional guidance in current system).

is_audit_question

-

-

id

elementId

Unique identifier for the mandate (Not a direct mapping).

authority_document

authorityDocument

Object representing the source document.

control

matchedControl.control

Object representing the matched control.

audit_item

-

-

asset

-

Asset information related to the control.

compliance_document

-

-

role

-

-

data_content

-

Data content information.

organizational_function

-

Organizational function related to the control.

record_example

-

-

metric

-

-

monitored_event

-

-

organizational_task

-

Organizational task information.

record_category

-

-

configurable_item_with_settings

-

-

sentence

taggedText

Main text of the mandate with annotations.

parent

hierarchyItems.hierarchicalParents

Parent mandates in the hierarchy.

check_digit

coreMetaData.checksum

Used for validation of response data (Not a direct mapping).


Nested Objects

Authority Document

JSON Path

  • Legacy Services API: authority_document

  • New NextGen: authorityDocument

JSON Property Mapping Matrix

Legacy Services API

New NextGen

Notes

id

authorityDocument.elementId

Identifier for the document (Not a direct mapping).

_href

authorityDocument.@id

URL to the document details (Not a direct mapping).

Control

JSON Path

  • Legacy Services API: control

  • New NextGen: matchedControl.control

JSON Property Mapping Matrix

Legacy Services API

New NextGen

Notes

live

coreMetaData.live

Indicates if the control is active.

deprecated_by

coreMetaData.deprecatedBy

URL indicating what deprecated the control.

deprecation_notes

coreMetaData.notes

Notes on deprecation.

time_created

coreMetaData.created.timeStamp

Creation timestamp.

time_updated

coreMetaData.modified.timeStamp

Last update timestamp.

language

language.name

Language of the control.

license_info

license.url

License information URL.

name

control.name

Name of the control.

impact_zone

control.impactZone.name

Impact zone classification.

type

control.controlType.name

Type of the control.

classification

control.classification.name

Classification of the control.

sentence

control.taggedText

Control's text with annotations.

parent

hierarchyItems.hierarchicalParents

Parent controls in the hierarchy.

id

control.elementId

Unique identifier for the control (Not a direct mapping).

_href

control.@id

URL to the control details (Not a direct mapping).

Sentence

JSON Path

  • JSON Path: sentence

  • NextGen JSON Path: taggedText

JSON Property Mapping Matrix

Legacy Services API

New NextGen

Notes

sentence

taggedText.text

The raw text of the mandate.

tagged_phrases

taggedText.taggedTerms

Annotated terms within the text.

live

coreMetaData.live

Indicates if the sentence is active.

time_created

coreMetaData.created.timeStamp

Creation timestamp.

time_updated

coreMetaData.modified.timeStamp

Last update timestamp.

id

taggedText.elementId

Unique identifier for the tagged text (Not a direct mapping).

correct

-

-

Tagged Phrases

JSON Path

  • Legacy Services API: sentence.tagged_phrases

  • New NextGen: taggedText.taggedTerms

JSON Property Mapping Matrix

Legacy Services API

New NextGen

Notes

start

Derived from tokens.start

Start index of the term in the text.

end

Derived from tokens.end

End index of the term in the text.

nonstandard

term.nonstandard

Indicates if the term is nonstandard.

id

taggedTerm.elementId

Unique identifier for the tagged term (Not a direct mapping).

sentence.id

taggedText.elementId

Unique identifier for the tagged text (Not a direct mapping).

type.name

taggedType.name

Classification of the term (e.g., "Primary Noun").

term

term

Contains term details such as name and lemma.

definition

definition.text

Textual definition of the term.

language

language.name

Language of the term.

license_info

license.url

License information URL.

Info

Note: The tokens property in taggedTerm references the tokens in taggedText.tokens array. The startand end indices help identify the specific tokens associated with the term.