Commit b8cfa45
[Search][WIP] Move ai.prompt, ai.summarize, ai.classify workflows to inference plugin (elastic#269392)
## Summary
Resolves elastic/search-team#14019
Moves the three AI workflow steps (`ai.prompt`, `ai.summarize`,
`ai.classify`) from the `workflowsExtensions` plugin to a new
`inferenceWorkflows` plugin owned by `@elastic/search-kibana`.
- Created new `inferenceWorkflows` plugin at
`x-pack/platform/plugins/shared/inference_workflows/`
- Steps are registered via the external
`workflowsExtensions.registerStepDefinition()` API (same pattern as
`agent_builder`)
- Registers workflows AI features with `searchInferenceEndpoints` so
admins can configure model restrictions per step on the Inference
Endpoints settings page
- Removed AI step code from `workflows_extensions` — it now only
contains data.* steps
- Updated CODEOWNERS, i18n config, optimizer limits, and README
### Why a new plugin?
The `inference` plugin cannot depend on `workflowsExtensions` (circular
dependency — `workflowsExtensions` already depends on `inference`). A
dedicated plugin keeps dependencies flowing in the right direction and
gives the search team clear ownership.
### What changed
| Area | Before | After |
|------|--------|-------|
| AI step registration | Internal in `workflowsExtensions` | External
via `inferenceWorkflows` plugin |
| License | SSPL triple-license (`src/`) | Elastic License 2.0
(`x-pack/`) |
| i18n prefix | `workflowsExtensionsExample.*` |
`xpack.inferenceWorkflows.*` |
| Inference feature registration | `workflowsExtensions` (stale after
merge) | `inferenceWorkflows` plugin setup |
| Step logic | **Unchanged** | **Unchanged** |
### Checklist
Check the PR satisfies following conditions.
Reviewers should verify this PR satisfies this list as well.
- [ ] Any text added follows [EUI's writing
guidelines](https://elastic.github.io/eui/#/guidelines/writing), uses
sentence case text and includes [i18n
support](https://github.com/elastic/kibana/blob/main/src/platform/packages/shared/kbn-i18n/README.md)
- [ ]
[Documentation](https://www.elastic.co/guide/en/kibana/master/development-documentation.html)
was added for features that require explanation or tutorials
- [x] [Unit or functional
tests](https://www.elastic.co/guide/en/kibana/master/development-tests.html)
were updated or added to match the most common scenarios
- [ ] If a plugin configuration key changed, check if it needs to be
allowlisted in the cloud and added to the [docker
list](https://github.com/elastic/kibana/blob/main/src/dev/build/tasks/os_packages/docker_generator/resources/base/bin/kibana-docker)
- [x] This was checked for breaking HTTP API changes, and any breaking
changes have been approved by the breaking-change committee. The
`release_note:breaking` label should be applied in these situations.
- [ ] [Flaky Test
Runner](https://ci-stats.kibana.dev/trigger_flaky_test_runner/1) was
used on any tests changed
- [x] The PR description includes the appropriate Release Notes section,
and the correct `release_note:*` label is applied per the
[guidelines](https://www.elastic.co/guide/en/kibana/master/contributing.html#kibana-release-notes-process)
- [x] Review the [backport
guidelines](https://docs.google.com/document/d/1VyN5k91e5OVumlc0Gb9RPa3h1ewuPE705nRtioPiTvY/edit?usp=sharing)
and apply applicable `backport:*` labels.
## Test plan
- [x] 160 unit tests pass in the new location
- [ ] Verify AI steps appear in the workflow editor UI
- [ ] Verify connector-id selection works for all three steps
- [ ] Verify AI steps appear under Workflows AI on the Inference
Endpoints settings page
- [ ] Verify in serverless mode
- [ ] Update `approved_step_definitions.ts` handler hashes after CI
build
🤖 Generated with [Claude Code](https://claude.com/claude-code)
---------
Co-authored-by: kibanamachine <42973632+kibanamachine@users.noreply.github.com>1 parent d9f99cd commit b8cfa45
54 files changed
Lines changed: 413 additions & 344 deletions
File tree
- .github
- docs/extend
- packages
- kbn-optimizer
- kbn-rspack-optimizer
- x-pack
Some content is hidden
Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1190 | 1190 | | |
1191 | 1191 | | |
1192 | 1192 | | |
| 1193 | + | |
1193 | 1194 | | |
1194 | 1195 | | |
1195 | 1196 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
173 | 173 | | |
174 | 174 | | |
175 | 175 | | |
| 176 | + | |
176 | 177 | | |
177 | 178 | | |
178 | 179 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
762 | 762 | | |
763 | 763 | | |
764 | 764 | | |
| 765 | + | |
765 | 766 | | |
766 | 767 | | |
767 | 768 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
91 | 91 | | |
92 | 92 | | |
93 | 93 | | |
| 94 | + | |
94 | 95 | | |
95 | 96 | | |
96 | 97 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
90 | 90 | | |
91 | 91 | | |
92 | 92 | | |
93 | | - | |
| 93 | + | |
| 94 | + | |
94 | 95 | | |
95 | 96 | | |
96 | 97 | | |
| |||
Lines changed: 0 additions & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
7 | 7 | | |
8 | 8 | | |
9 | 9 | | |
10 | | - | |
11 | 10 | | |
Lines changed: 0 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
11 | 11 | | |
12 | 12 | | |
13 | 13 | | |
14 | | - | |
15 | 14 | | |
16 | 15 | | |
17 | 16 | | |
18 | | - | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
25 | 25 | | |
26 | 26 | | |
27 | 27 | | |
28 | | - | |
29 | 28 | | |
30 | 29 | | |
31 | 30 | | |
| |||
35 | 34 | | |
36 | 35 | | |
37 | 36 | | |
38 | | - | |
39 | 37 | | |
40 | 38 | | |
41 | 39 | | |
| |||
Lines changed: 0 additions & 7 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
29 | 29 | | |
30 | 30 | | |
31 | 31 | | |
32 | | - | |
33 | | - | |
34 | | - | |
35 | | - | |
36 | | - | |
37 | | - | |
38 | | - | |
39 | 32 | | |
40 | 33 | | |
41 | 34 | | |
| |||
Lines changed: 1 addition & 6 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
25 | 25 | | |
26 | 26 | | |
27 | 27 | | |
28 | | - | |
29 | 28 | | |
30 | 29 | | |
31 | 30 | | |
| |||
78 | 77 | | |
79 | 78 | | |
80 | 79 | | |
81 | | - | |
| 80 | + | |
82 | 81 | | |
83 | 82 | | |
84 | | - | |
85 | | - | |
86 | | - | |
87 | | - | |
88 | 83 | | |
89 | 84 | | |
90 | 85 | | |
| |||
0 commit comments