2024-07-30 17:38:43 +05:30
|
|
|
-- Add a new table di_chart_entity
|
|
|
|
CREATE TABLE IF NOT EXISTS di_chart_entity (
|
|
|
|
id VARCHAR(36) GENERATED ALWAYS AS (json ->> '$.id') NOT NULL,
|
|
|
|
name VARCHAR(256) GENERATED ALWAYS AS (json ->> '$.name') NOT NULL,
|
|
|
|
fullyQualifiedName VARCHAR(256) GENERATED ALWAYS AS (json ->> '$.fullyQualifiedName') NOT NULL,
|
|
|
|
json JSON NOT NULL,
|
|
|
|
updatedAt BIGINT UNSIGNED GENERATED ALWAYS AS (json ->> '$.updatedAt') NOT NULL,
|
|
|
|
updatedBy VARCHAR(256) GENERATED ALWAYS AS (json ->> '$.updatedBy') NOT NULL,
|
|
|
|
fqnHash varchar(768) CHARACTER SET ascii COLLATE ascii_bin DEFAULT NULL,
|
|
|
|
deleted BOOLEAN GENERATED ALWAYS AS (json -> '$.deleted'),
|
|
|
|
UNIQUE(name),
|
|
|
|
INDEX name_index (name)
|
|
|
|
);
|
|
|
|
|
|
|
|
-- Update the KPI entity to remove the targetDefinition and set the targetValue to the value of the targetDefinition
|
|
|
|
UPDATE kpi_entity
|
|
|
|
SET json = JSON_REMOVE(
|
|
|
|
JSON_SET(json,
|
|
|
|
'$.targetValue',
|
|
|
|
CAST(JSON_UNQUOTE(JSON_EXTRACT(json, '$.targetDefinition[0].value')) AS DECIMAL) * 100
|
|
|
|
),
|
|
|
|
'$.targetDefinition'
|
|
|
|
)
|
|
|
|
WHERE JSON_UNQUOTE(JSON_EXTRACT(json, '$.metricType')) = 'PERCENTAGE';
|
|
|
|
|
|
|
|
UPDATE kpi_entity
|
|
|
|
SET json = JSON_REMOVE(
|
|
|
|
JSON_SET(json,
|
|
|
|
'$.targetValue',
|
|
|
|
CAST(JSON_UNQUOTE(JSON_EXTRACT(json, '$.targetDefinition[0].value')) AS DECIMAL)
|
|
|
|
),
|
|
|
|
'$.targetDefinition'
|
|
|
|
)
|
|
|
|
WHERE JSON_UNQUOTE(JSON_EXTRACT(json, '$.metricType')) = 'NUMBER';
|
2024-06-28 17:40:41 +02:00
|
|
|
-- Update DeltaLake service due to connection schema changes to enable DeltaLake ingestion from Storage
|
|
|
|
UPDATE dbservice_entity dbse
|
|
|
|
SET
|
|
|
|
dbse.json = JSON_REMOVE(JSON_REMOVE(
|
|
|
|
JSON_MERGE_PATCH(
|
|
|
|
dbse.json,
|
|
|
|
JSON_OBJECT(
|
|
|
|
'connection', JSON_OBJECT(
|
|
|
|
'config', JSON_OBJECT(
|
|
|
|
'configSource', JSON_OBJECT(
|
|
|
|
'connection', JSON_EXTRACT(dbse.json, '$.connection.config.metastoreConnection'),
|
|
|
|
'appName', JSON_UNQUOTE(JSON_EXTRACT(dbse.json, '$.connection.config.appName'))
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
, '$.connection.config.appName'), '$.connection.config.metastoreConnection')
|
|
|
|
WHERE dbse.serviceType = 'DeltaLake';
|
2024-07-05 06:35:32 -07:00
|
|
|
|
2024-07-08 11:19:16 +02:00
|
|
|
-- Allow all bots to update the ingestion pipeline status
|
|
|
|
UPDATE policy_entity
|
|
|
|
SET json = JSON_ARRAY_APPEND(
|
|
|
|
json,
|
|
|
|
'$.rules',
|
|
|
|
CAST('{
|
|
|
|
"name": "BotRule-IngestionPipeline",
|
|
|
|
"description": "A bot can Edit ingestion pipelines to pass the status",
|
|
|
|
"resources": ["ingestionPipeline"],
|
2024-07-09 11:13:57 +02:00
|
|
|
"operations": ["ViewAll","EditIngestionPipelineStatus"],
|
2024-07-08 11:19:16 +02:00
|
|
|
"effect": "allow"
|
|
|
|
}' AS JSON)
|
|
|
|
)
|
|
|
|
WHERE name = 'DefaultBotPolicy';
|
2024-07-05 06:35:32 -07:00
|
|
|
|
|
|
|
-- create API service entity
|
|
|
|
CREATE TABLE IF NOT EXISTS api_service_entity (
|
|
|
|
id VARCHAR(36) GENERATED ALWAYS AS (json ->> '$.id') STORED NOT NULL,
|
|
|
|
nameHash VARCHAR(256) NOT NULL COLLATE ascii_bin,
|
|
|
|
name VARCHAR(256) GENERATED ALWAYS AS (json ->> '$.name') NOT NULL,
|
|
|
|
serviceType VARCHAR(256) GENERATED ALWAYS AS (json ->> '$.serviceType') NOT NULL,
|
|
|
|
json JSON NOT NULL,
|
|
|
|
updatedAt BIGINT UNSIGNED GENERATED ALWAYS AS (json ->> '$.updatedAt') NOT NULL,
|
|
|
|
updatedBy VARCHAR(256) GENERATED ALWAYS AS (json ->> '$.updatedBy') NOT NULL,
|
|
|
|
deleted BOOLEAN GENERATED ALWAYS AS (json -> '$.deleted'),
|
|
|
|
PRIMARY KEY (id),
|
|
|
|
UNIQUE (nameHash),
|
|
|
|
INDEX (name)
|
|
|
|
);
|
|
|
|
|
|
|
|
-- create API collection entity
|
|
|
|
CREATE TABLE IF NOT EXISTS api_collection_entity (
|
|
|
|
id VARCHAR(36) GENERATED ALWAYS AS (json ->> '$.id') STORED NOT NULL,
|
|
|
|
name VARCHAR(256) GENERATED ALWAYS AS (json ->> '$.name') NOT NULL,
|
|
|
|
fqnHash VARCHAR(256) NOT NULL COLLATE ascii_bin,
|
|
|
|
json JSON NOT NULL,
|
|
|
|
updatedAt BIGINT UNSIGNED GENERATED ALWAYS AS (json ->> '$.updatedAt') NOT NULL,
|
|
|
|
updatedBy VARCHAR(256) GENERATED ALWAYS AS (json ->> '$.updatedBy') NOT NULL,
|
|
|
|
deleted BOOLEAN GENERATED ALWAYS AS (json -> '$.deleted'),
|
|
|
|
PRIMARY KEY (id),
|
|
|
|
UNIQUE (fqnHash),
|
|
|
|
INDEX (name)
|
|
|
|
);
|
|
|
|
|
|
|
|
-- create API Endpoint entity
|
|
|
|
CREATE TABLE IF NOT EXISTS api_endpoint_entity (
|
|
|
|
id VARCHAR(36) GENERATED ALWAYS AS (json ->> '$.id') STORED NOT NULL,
|
|
|
|
name VARCHAR(256) GENERATED ALWAYS AS (json ->> '$.name') NOT NULL,
|
|
|
|
fqnHash VARCHAR(256) NOT NULL COLLATE ascii_bin,
|
|
|
|
json JSON NOT NULL,
|
|
|
|
updatedAt BIGINT UNSIGNED GENERATED ALWAYS AS (json ->> '$.updatedAt') NOT NULL,
|
|
|
|
updatedBy VARCHAR(256) GENERATED ALWAYS AS (json ->> '$.updatedBy') NOT NULL,
|
|
|
|
deleted BOOLEAN GENERATED ALWAYS AS (json -> '$.deleted'),
|
|
|
|
PRIMARY KEY (id),
|
|
|
|
UNIQUE (fqnHash),
|
|
|
|
INDEX (name)
|
2024-07-08 11:19:16 +02:00
|
|
|
);
|
2024-07-15 11:37:38 +05:30
|
|
|
|
2024-07-18 12:03:22 +02:00
|
|
|
-- Clean dangling workflows not removed after test connection
|
|
|
|
truncate automations_workflow;
|
|
|
|
|
2024-07-15 11:37:38 +05:30
|
|
|
-- Remove date, dateTime, time from type_entity, as they are no more om-field-types, instead we have date-cp, time-cp, dateTime-cp as om-field-types
|
|
|
|
DELETE FROM type_entity
|
|
|
|
WHERE name IN ('date', 'dateTime', 'time');
|
2024-07-17 07:51:17 +02:00
|
|
|
|
|
|
|
-- Update BigQuery,Bigtable & Datalake model for gcpCredentials to move `gcpConfig` value to `gcpConfig.path`
|
|
|
|
UPDATE dbservice_entity
|
|
|
|
SET json = JSON_INSERT(
|
|
|
|
JSON_REMOVE(json, '$.connection.config.credentials.gcpConfig'),
|
|
|
|
'$.connection.config.credentials.gcpConfig',
|
|
|
|
JSON_OBJECT(),
|
|
|
|
'$.connection.config.credentials.gcpConfig.path',
|
|
|
|
JSON_EXTRACT(json, '$.connection.config.credentials.gcpConfig')
|
|
|
|
) where serviceType in ('BigQuery', 'BigTable') and
|
|
|
|
(JSON_EXTRACT(json, '$.connection.config.credentials.gcpConfig.type') OR
|
|
|
|
JSON_EXTRACT(json, '$.connection.config.credentials.gcpConfig.externalType') OR
|
|
|
|
JSON_EXTRACT(json, '$.connection.config.credentials.gcpConfig.path')) is NULL;
|
|
|
|
|
|
|
|
UPDATE dbservice_entity
|
|
|
|
SET json = JSON_INSERT(
|
|
|
|
JSON_REMOVE(json, '$.connection.config.configSource.securityConfig.gcpConfig'),
|
|
|
|
'$.connection.config.configSource.securityConfig.gcpConfig',
|
|
|
|
JSON_OBJECT(),
|
|
|
|
'$.connection.config.configSource.securityConfig.gcpConfig.path',
|
|
|
|
JSON_EXTRACT(json, '$.connection.config.configSource.securityConfig.gcpConfig')
|
|
|
|
) where serviceType in ('Datalake') and
|
|
|
|
(JSON_EXTRACT(json, '$.connection.config.configSource.securityConfig.gcpConfig.type') OR
|
|
|
|
JSON_EXTRACT(json, '$.connection.config.configSource.securityConfig.gcpConfig.externalType') OR
|
|
|
|
JSON_EXTRACT(json, '$.connection.config.configSource.securityConfig.gcpConfig.path')) is NULL and
|
|
|
|
JSON_EXTRACT(json, '$.connection.config.configSource.securityConfig.gcpConfig') is NOT NULL;
|
|
|
|
|
|
|
|
-- Update Powerbi model for pbitFilesSource to move `gcpConfig` value to `gcpConfig.path`
|
|
|
|
UPDATE dashboard_service_entity
|
|
|
|
SET json = JSON_INSERT(
|
|
|
|
JSON_REMOVE(json, '$.connection.config.pbitFilesSource.securityConfig.gcpConfig'),
|
|
|
|
'$.connection.config.pbitFilesSource.securityConfig.gcpConfig',
|
|
|
|
JSON_OBJECT(),
|
|
|
|
'$.connection.config.pbitFilesSource.securityConfig.gcpConfig.path',
|
|
|
|
JSON_EXTRACT(json, '$.connection.config.pbitFilesSource.securityConfig.gcpConfig')
|
|
|
|
) where serviceType in ('PowerBI') and
|
|
|
|
(JSON_EXTRACT(json, '$.connection.config.pbitFilesSource.securityConfig.gcpConfig.type') OR
|
|
|
|
JSON_EXTRACT(json, '$.connection.config.pbitFilesSource.securityConfig.gcpConfig.externalType') OR
|
|
|
|
JSON_EXTRACT(json, '$.connection.config.pbitFilesSource.securityConfig.gcpConfig.path')) is NULL AND
|
|
|
|
JSON_EXTRACT(json, '$.connection.config.pbitFilesSource.securityConfig.gcpConfig') is not null;
|
|
|
|
|
|
|
|
UPDATE storage_service_entity
|
|
|
|
SET json = JSON_INSERT(
|
|
|
|
JSON_REMOVE(json, '$.connection.config.credentials.gcpConfig'),
|
|
|
|
'$.connection.config.credentials.gcpConfig',
|
|
|
|
JSON_OBJECT(),
|
|
|
|
'$.connection.config.credentials.gcpConfig.path',
|
|
|
|
JSON_EXTRACT(json, '$.connection.config.credentials.gcpConfig')
|
|
|
|
) where serviceType in ('GCS') and
|
|
|
|
(JSON_EXTRACT(json, '$.connection.config.credentials.gcpConfig.type') OR
|
|
|
|
JSON_EXTRACT(json, '$.connection.config.credentials.gcpConfig.externalType') OR
|
|
|
|
JSON_EXTRACT(json, '$.connection.config.credentials.gcpConfig.path')) is NULL;
|
|
|
|
|
|
|
|
UPDATE ingestion_pipeline_entity
|
|
|
|
SET json = JSON_INSERT(
|
|
|
|
JSON_REMOVE(json, '$.sourceConfig.config.dbtConfigSource.dbtSecurityConfig.gcpConfig'),
|
|
|
|
'$.sourceConfig.config.dbtConfigSource.dbtSecurityConfig.gcpConfig',
|
|
|
|
JSON_OBJECT(),
|
|
|
|
'$.sourceConfig.config.dbtConfigSource.dbtSecurityConfig.gcpConfig.path',
|
|
|
|
JSON_EXTRACT(json, '$.sourceConfig.config.dbtConfigSource.dbtSecurityConfig.gcpConfig')
|
|
|
|
) where JSON_EXTRACT(json, '$.sourceConfig.config.type') = 'DBT' and (
|
|
|
|
JSON_EXTRACT(json, '$.sourceConfig.config.dbtConfigSource.dbtSecurityConfig.gcpConfig.type') OR
|
|
|
|
JSON_EXTRACT(json, '$.sourceConfig.config.dbtConfigSource.dbtSecurityConfig.gcpConfig.externalType') OR
|
|
|
|
JSON_EXTRACT(json, '$.sourceConfig.config.dbtConfigSource.dbtSecurityConfig.gcpConfig.path')
|
2024-07-18 12:03:22 +02:00
|
|
|
) is NULL AND JSON_EXTRACT(json, '$.sourceConfig.config.dbtConfigSource.dbtSecurityConfig.gcpConfig') is not null;
|
2024-07-29 23:06:39 -07:00
|
|
|
|
|
|
|
-- Update Owner Field to Owners
|
|
|
|
DELETE from event_subscription_entity where name = 'ActivityFeedAlert';
|
|
|
|
|
|
|
|
-- Update thread_entity to move previousOwner and updatedOwner to array
|
|
|
|
UPDATE thread_entity
|
|
|
|
SET json = JSON_SET(
|
|
|
|
json,
|
|
|
|
'$.feedInfo.entitySpecificInfo.previousOwner',
|
|
|
|
JSON_ARRAY(
|
|
|
|
JSON_EXTRACT(json, '$.feedInfo.entitySpecificInfo.previousOwner')
|
|
|
|
)
|
|
|
|
)
|
|
|
|
WHERE JSON_CONTAINS_PATH(json, 'one', '$.feedInfo.entitySpecificInfo.previousOwner')
|
|
|
|
AND JSON_TYPE(JSON_EXTRACT(json, '$.feedInfo.entitySpecificInfo.previousOwner')) <> 'ARRAY';
|
|
|
|
|
|
|
|
UPDATE thread_entity
|
|
|
|
SET json = JSON_SET(
|
|
|
|
json,
|
|
|
|
'$.feedInfo.entitySpecificInfo.updatedOwner',
|
|
|
|
JSON_ARRAY(
|
|
|
|
JSON_EXTRACT(json, '$.feedInfo.entitySpecificInfo.updatedOwner')
|
|
|
|
)
|
|
|
|
)
|
|
|
|
WHERE JSON_CONTAINS_PATH(json, 'one', '$.feedInfo.entitySpecificInfo.updatedOwner')
|
|
|
|
AND JSON_TYPE(JSON_EXTRACT(json, '$.feedInfo.entitySpecificInfo.updatedOwner')) <> 'ARRAY';
|
|
|
|
|
|
|
|
-- Update entity_extension to move owner to array
|
|
|
|
UPDATE entity_extension
|
|
|
|
SET json = JSON_SET(
|
|
|
|
json,
|
|
|
|
'$.owner',
|
|
|
|
JSON_ARRAY(
|
|
|
|
JSON_EXTRACT(json, '$.owner')
|
|
|
|
)
|
|
|
|
)
|
|
|
|
WHERE JSON_CONTAINS_PATH(json, 'one', '$.owner')
|
|
|
|
AND JSON_TYPE(JSON_EXTRACT(json, '$.owner')) <> 'ARRAY';
|
2024-08-01 14:31:36 +05:30
|
|
|
|
|
|
|
-- set templates to fetch emailTemplates
|
|
|
|
UPDATE openmetadata_settings
|
|
|
|
SET json = JSON_SET(json, '$.templates', 'openmetadata')
|
2024-08-02 10:16:14 +05:30
|
|
|
WHERE configType = 'emailConfiguration';
|
|
|
|
|
|
|
|
ALTER TABLE thread_entity ADD COLUMN domain VARCHAR(256) GENERATED ALWAYS AS (json ->> '$.domain');
|
|
|
|
|