mirror of
https://github.com/elastic/kibana.git
synced 2025-04-24 09:48:58 -04:00
[RAC][Rule Registry] Fix bug where namespaces with dashes could cause conflicts (#107991)
* Fix bug where namespaces with dashes could cause conflicts * Missing word in comment * Apply logic changes to consolidated RuleData implementation
This commit is contained in:
parent
5d404fff6b
commit
edfb98104c
1 changed files with 57 additions and 44 deletions
|
@ -241,59 +241,72 @@ export class ResourceInstaller {
|
|||
|
||||
logger.debug(`Creating write target for ${primaryNamespacedAlias}`);
|
||||
|
||||
const { body: indicesExist } = await clusterClient.indices.exists({
|
||||
index: primaryNamespacedPattern,
|
||||
allow_no_indices: false,
|
||||
});
|
||||
try {
|
||||
// When a new namespace is created we expect getAlias to return a 404 error,
|
||||
// we'll catch it below and continue on. A non-404 error is a real problem so we throw.
|
||||
|
||||
if (!indicesExist) {
|
||||
await this.installNamespacedIndexTemplate(indexInfo, namespace);
|
||||
|
||||
try {
|
||||
await clusterClient.indices.create({
|
||||
index: initialIndexName,
|
||||
body: {
|
||||
aliases: {
|
||||
[primaryNamespacedAlias]: {
|
||||
is_write_index: true,
|
||||
},
|
||||
},
|
||||
},
|
||||
});
|
||||
} catch (err) {
|
||||
// If the index already exists and it's the write index for the alias,
|
||||
// something else created it so suppress the error. If it's not the write
|
||||
// index, that's bad, throw an error.
|
||||
if (err?.meta?.body?.error?.type === 'resource_already_exists_exception') {
|
||||
const { body: existingIndices } = await clusterClient.indices.get({
|
||||
index: initialIndexName,
|
||||
});
|
||||
if (
|
||||
!existingIndices[initialIndexName]?.aliases?.[primaryNamespacedAlias]?.is_write_index
|
||||
) {
|
||||
throw Error(
|
||||
`Attempted to create index: ${initialIndexName} as the write index for alias: ${primaryNamespacedAlias}, but the index already exists and is not the write index for the alias`
|
||||
);
|
||||
}
|
||||
} else {
|
||||
throw err;
|
||||
}
|
||||
}
|
||||
} else {
|
||||
// If we find indices matching the pattern, then we expect one of them to be the write index for the alias.
|
||||
// Throw an error if none of them are the write index.
|
||||
const { body: aliasesResponse } = await clusterClient.indices.getAlias({
|
||||
// It's critical that we specify *both* the index pattern and alias in this request. The alias prevents the
|
||||
// request from finding other namespaces that could match the -* part of the index pattern
|
||||
// (see https://github.com/elastic/kibana/issues/107704). The index pattern prevents the request from
|
||||
// finding legacy .siem-signals indices that we add the alias to for backwards compatibility reasons. Together,
|
||||
// the index pattern and alias should ensure that we retrieve only the "new" backing indices for this
|
||||
// particular alias.
|
||||
const { body: aliases } = await clusterClient.indices.getAlias({
|
||||
index: primaryNamespacedPattern,
|
||||
name: primaryNamespacedAlias,
|
||||
});
|
||||
|
||||
// If we find backing indices for the alias here, we shouldn't be making a new concrete index -
|
||||
// either one of the indices is the write index so we return early because we don't need a new write target,
|
||||
// or none of them are the write index so we'll throw an error because one of the existing indices should have
|
||||
// been the write target
|
||||
if (
|
||||
!Object.entries(aliasesResponse).some(
|
||||
([_, aliasesObject]) => aliasesObject.aliases[primaryNamespacedAlias]?.is_write_index
|
||||
Object.values(aliases).some(
|
||||
(aliasesObject) => aliasesObject.aliases[primaryNamespacedAlias].is_write_index
|
||||
)
|
||||
) {
|
||||
throw Error(
|
||||
return;
|
||||
} else {
|
||||
throw new Error(
|
||||
`Indices matching pattern ${primaryNamespacedPattern} exist but none are set as the write index for alias ${primaryNamespacedAlias}`
|
||||
);
|
||||
}
|
||||
} catch (err) {
|
||||
// 404 is expected if the alerts-as-data index hasn't been created yet
|
||||
if (err.statusCode !== 404) {
|
||||
throw err;
|
||||
}
|
||||
}
|
||||
|
||||
await this.installNamespacedIndexTemplate(indexInfo, namespace);
|
||||
|
||||
try {
|
||||
await clusterClient.indices.create({
|
||||
index: initialIndexName,
|
||||
body: {
|
||||
aliases: {
|
||||
[primaryNamespacedAlias]: {
|
||||
is_write_index: true,
|
||||
},
|
||||
},
|
||||
},
|
||||
});
|
||||
} catch (err) {
|
||||
// If the index already exists and it's the write index for the alias,
|
||||
// something else created it so suppress the error. If it's not the write
|
||||
// index, that's bad, throw an error.
|
||||
if (err?.meta?.body?.error?.type === 'resource_already_exists_exception') {
|
||||
const { body: existingIndices } = await clusterClient.indices.get({
|
||||
index: initialIndexName,
|
||||
});
|
||||
if (!existingIndices[initialIndexName]?.aliases?.[primaryNamespacedAlias]?.is_write_index) {
|
||||
throw Error(
|
||||
`Attempted to create index: ${initialIndexName} as the write index for alias: ${primaryNamespacedAlias}, but the index already exists and is not the write index for the alias`
|
||||
);
|
||||
}
|
||||
} else {
|
||||
throw err;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue