Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add new "references" attribute to saved objects for relationships #28199

Merged
merged 65 commits into from
Jan 30, 2019
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
65 commits
Select commit Hold shift + click to select a range
3c21c65
Add new references attribute to saved objects
mikecote Jan 7, 2019
1cc774e
Add dual support for dashboard export API
mikecote Jan 8, 2019
e7ff9d3
Use new relationships API supporting legacy relationships extraction
mikecote Jan 8, 2019
bf3b9fb
Code cleanup
mikecote Jan 9, 2019
49344fb
Fix style and CI error
mikecote Jan 9, 2019
3d43ab4
Add missing spaces test for findRelationships
mikecote Jan 9, 2019
d2ba949
Merge branch 'master' of github.com:mikecote/kibana into add-references
mikecote Jan 10, 2019
09c76e4
Merge branch 'master' of github.com:mikecote/kibana into add-references
mikecote Jan 10, 2019
f29a572
Convert collect_references_deep to typescript
mikecote Jan 10, 2019
76877a9
Add missing trailing commas
mikecote Jan 10, 2019
89318e4
Merge branch 'master' of github.com:mikecote/kibana into add-references
mikecote Jan 10, 2019
b54d17d
Fix broken test by making saved object API consistently return refere…
mikecote Jan 10, 2019
3e5e89b
Fix broken api integration tests
mikecote Jan 10, 2019
9deb6a8
Add comment about the two TS types for saved object
mikecote Jan 11, 2019
aadb163
Only return title from the attributes returned in findRelationships
mikecote Jan 11, 2019
8c8b63f
Fix broken test
mikecote Jan 11, 2019
d7a6e85
Add missing security tests
mikecote Jan 21, 2019
32c8153
Merge branch 'master' of github.com:mikecote/kibana into add-references
mikecote Jan 21, 2019
61d5096
Drop filterTypes support
mikecote Jan 21, 2019
4eba4d8
Merge branch 'master' of github.com:mikecote/kibana into add-references
mikecote Jan 22, 2019
0d971d6
Implement references to search, dashboard, visualization, graph
mikecote Jan 22, 2019
3fdaa5c
Add index pattern migration to dashboards
mikecote Jan 22, 2019
0dfa760
Add references mapping to dashboard mppings.json
mikecote Jan 22, 2019
5e02996
Remove findRelationships from repository and into it's own function /…
mikecote Jan 23, 2019
aabc917
Apply PR feedback pt1
mikecote Jan 23, 2019
87ee26d
Merge branch 'master' of github.com:mikecote/kibana into add-references
mikecote Jan 23, 2019
830c528
Fix some failing tests
mikecote Jan 23, 2019
5f328bb
Remove error throwing in migrations
mikecote Jan 23, 2019
fd3085e
Add references to edit saved object screen
mikecote Jan 23, 2019
7264bc7
Pass types to findRelationships
mikecote Jan 23, 2019
a2caa10
Merge branch 'master' of github.com:elastic/kibana into pr/28199
Jan 23, 2019
5f8b3b9
[ftr] restore snapshots from master, rely on migrations to add refere…
Jan 23, 2019
2e26652
[security] remove `find_relationships` action
Jan 23, 2019
acb991e
Merge branch 'master' of github.com:elastic/kibana into pr/28199
Jan 24, 2019
9bcfd57
remove data set modifications
Jan 23, 2019
4c9e0bf
[security/savedObjectsClient] remove _getAuthorizedTypes method
Jan 23, 2019
a2941c6
fix security & spaces tests to consider references and migrationVersion
mikecote Jan 24, 2019
b4ef670
Add space id prefixes to es_archiver/saved_objects/spaces/data.json
mikecote Jan 24, 2019
d2c68be
Merge branch 'master' of github.com:mikecote/kibana into add-references
mikecote Jan 24, 2019
ddc0496
Rename referenced attributes to have a suffix of RefName
mikecote Jan 24, 2019
5e8989f
Merge branch 'master' of github.com:elastic/kibana into add-references
mikecote Jan 24, 2019
b8d1f7f
Fix length check in scenario references doesn't exist
mikecote Jan 24, 2019
489b0e5
Add test for inject references to not be called when references array…
mikecote Jan 24, 2019
07eae56
Merge branch 'master' of github.com:elastic/kibana into add-references
mikecote Jan 25, 2019
304a31f
some code cleanup
mikecote Jan 25, 2019
0a8f5b1
Make migrations run on machine learning data files, fix rollup filter…
mikecote Jan 25, 2019
371fdfd
fix broken test
mikecote Jan 25, 2019
4a59408
Fix collector.js to include references in elasticsearch response
mikecote Jan 25, 2019
c379ab7
code cleanup pt2
mikecote Jan 25, 2019
a379ff1
add some more tests
mikecote Jan 25, 2019
5cd9518
Merge branch 'master' of github.com:elastic/kibana into add-references
mikecote Jan 25, 2019
71501d2
fix broken tests
mikecote Jan 25, 2019
876cb3f
updated documentation on referencedBy option for saved object client …
mikecote Jan 25, 2019
4ff0d12
Merge branch 'master' of github.com:elastic/kibana into add-references
mikecote Jan 28, 2019
882753f
Move visualization migrations into kibana plugin
mikecote Jan 28, 2019
dee9ce2
Update docs with better description on references
mikecote Jan 28, 2019
d22399a
Merge with master
mikecote Jan 29, 2019
14a2f55
Merge branch 'master' of github.com:elastic/kibana into add-references
mikecote Jan 29, 2019
1122c92
Merge w/ master
mikecote Jan 30, 2019
6babefe
Apply PR feedback
mikecote Jan 30, 2019
8924666
Merge with master
mikecote Jan 30, 2019
d3f11ed
Fix merge
mikecote Jan 30, 2019
6a313f4
fix tests I broke adressing PR feedback
mikecote Jan 30, 2019
c36c728
Merge with master
mikecote Jan 30, 2019
9ff87bd
PR feedback pt2
mikecote Jan 30, 2019
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 3 additions & 0 deletions docs/api/saved-objects/bulk_create.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,9 @@ contains the following properties:
`attributes` (required)::
(object) The data to persist

`references` (optional)::
(array) An array of objects with `name`, `id`, and `type` properties that describe the other saved objects this object references. The `name` can be used in the attributes to refer to the other saved object, but never the `id`, which may be updated automatically in the future during migrations or import/export.

`version` (optional)::
(number) Enables specifying a version

Expand Down
2 changes: 2 additions & 0 deletions docs/api/saved-objects/create.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,8 @@ Note: You cannot access this endpoint via the Console in Kibana.
`attributes` (required)::
(object) The data to persist

`references` (optional)::
(array) An array of objects with `name`, `id`, and `type` properties that describe the other saved objects this object references. The `name` can be used in the attributes to refer to the other saved object, but never the `id`, which may be updated automatically in the future during migrations or import/export.

==== Examples

Expand Down
2 changes: 2 additions & 0 deletions docs/api/saved-objects/find.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,8 @@ Note: You cannot access this endpoint via the Console in Kibana.
(array|string) The fields to return in the response
`sort_field` (optional)::
(string) The field on which the response will be sorted
`has_reference` (optional)::
(object) Filters to objects having a relationship with the type and id combination

[NOTE]
==============================================
Expand Down
2 changes: 2 additions & 0 deletions docs/api/saved-objects/update.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,8 @@ Note: You cannot access this endpoint via the Console in Kibana.
`attributes` (required)::
(object) The data to persist

`references` (optional)::
(array) An array of objects with `name`, `id`, and `type` properties that describe the other saved objects this object references. The `name` can be used in the attributes to refer to the other saved object, but never the `id`, which may be updated automatically in the future during migrations or import/export.

==== Examples

Expand Down
2 changes: 1 addition & 1 deletion src/legacy/core_plugins/kibana/mappings.json
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@
}
}
},
"savedSearchId": {
mikecote marked this conversation as resolved.
Show resolved Hide resolved
"savedSearchRefName": {
"type": "keyword"
},
"title": {
Expand Down
93 changes: 92 additions & 1 deletion src/legacy/core_plugins/kibana/migrations.js
Original file line number Diff line number Diff line change
Expand Up @@ -19,9 +19,53 @@

import { cloneDeep, get, omit } from 'lodash';

function migrateIndexPattern(doc) {
const searchSourceJSON = get(doc, 'attributes.kibanaSavedObjectMeta.searchSourceJSON');
if (typeof searchSourceJSON !== 'string') {
return;
}
let searchSource;
try {
searchSource = JSON.parse(searchSourceJSON);
} catch (e) {
// Let it go, the data is invalid and we'll leave it as is
return;
}
if (!searchSource.index) {
return;
}
doc.references.push({
name: 'kibanaSavedObjectMeta.searchSourceJSON.index',
type: 'index-pattern',
id: searchSource.index,
});
searchSource.indexRefName = 'kibanaSavedObjectMeta.searchSourceJSON.index';
delete searchSource.index;
doc.attributes.kibanaSavedObjectMeta.searchSourceJSON = JSON.stringify(searchSource);
}

export const migrations = {
visualization: {
'7.0.0': (doc) => {
// Set new "references" attribute
doc.references = doc.references || [];

// Migrate index pattern
mikecote marked this conversation as resolved.
Show resolved Hide resolved
migrateIndexPattern(doc);

// Migrate saved search
const savedSearchId = get(doc, 'attributes.savedSearchId');
if (savedSearchId) {
doc.references.push({
type: 'search',
name: 'search_0',
id: savedSearchId,
});
doc.attributes.savedSearchRefName = 'search_0';
delete doc.attributes.savedSearchId;
}

// Migrate table splits
try {
const visState = JSON.parse(doc.attributes.visState);
if (get(visState, 'type') !== 'table') {
Expand Down Expand Up @@ -55,5 +99,52 @@ export const migrations = {
throw new Error(`Failure attempting to migrate saved object '${doc.attributes.title}' - ${e}`);
}
}
}
},
dashboard: {
'7.0.0': (doc) => {
// Set new "references" attribute
doc.references = doc.references || [];
// Migrate index pattern
migrateIndexPattern(doc);
// Migrate panels
const panelsJSON = get(doc, 'attributes.panelsJSON');
if (typeof panelsJSON !== 'string') {
return doc;
}
let panels;
try {
panels = JSON.parse(panelsJSON);
} catch (e) {
// Let it go, the data is invalid and we'll leave it as is
return doc;
}
if (!Array.isArray(panels)) {
return doc;
}
panels.forEach((panel, i) => {
if (!panel.type || !panel.id) {
return;
}
panel.panelRefName = `panel_${i}`;
doc.references.push({
name: `panel_${i}`,
type: panel.type,
id: panel.id,
});
delete panel.type;
delete panel.id;
});
doc.attributes.panelsJSON = JSON.stringify(panels);
return doc;
},
},
search: {
'7.0.0': (doc) => {
// Set new "references" attribute
doc.references = doc.references || [];
// Migrate index pattern
migrateIndexPattern(doc);
return doc;
},
},
};
Loading