Commit 4c26d60
Add CLI command
## Why make this change?
- #2964
Implements CLI command to configure autoentities definitions via command
line. Previously, users had to manually edit the config file to add or
modify autoentities entries.
## What is this change?
Added `auto-config` command that upserts autoentities definitions with
support for:
- Pattern matching rules (`--patterns.include`, `--patterns.exclude`,
`--patterns.name`)
- Template configuration for REST, GraphQL, MCP, Health, Cache endpoints
- Permissions using standard `role:actions` format
**Implementation:**
- `AutoConfigOptions.cs` - Command options class following existing CLI
patterns
- `ConfigGenerator.TryConfigureAutoentities()` - Main handler with
builder methods for patterns, template, and permissions
- Registered command in `Program.cs` parser
**Bug fixes:**
- `AutoentityConverter` and `AutoentityTemplateConverter` - Added
missing MCP options serialization logic that prevented MCP settings from
persisting to config file
- `AutoentityTemplateConverter` - Fixed GraphQL template serialization
to only write `enabled` property, excluding `type` object
(singular/plural) which is determined by generated entities
**Improvements:**
- Enhanced error messages to display all valid parameter values using
`EnumExtensions.GenerateMessageForInvalidInput<T>()` pattern
- Cache level errors now show: "Invalid Source Type: {value}. Valid
values are: L1,L1L2"
- MCP dml-tool errors now show: "Invalid value for
template.mcp.dml-tool: {value}. Valid values are: true, false"
- **Permissions validation**: Added runtime validation that requires
`--permissions` only when creating a new autoentity definition. When
updating an existing definition, permissions are optional and preserved
from the existing configuration.
## How was this tested?
- [x] Unit Tests
- [ ] Integration Tests
Added 8 unit tests covering:
- Create/update operations with patterns and template options
- Permission parsing with multiple actions
- Error handling for invalid enum values
- Multiple coexisting definitions
- Permissions validation for new vs. existing definitions
## Sample Request(s)
```bash
# Create new definition with patterns and permissions (permissions required for new definitions)
dab auto-config my-def \
--patterns.include "dbo.%" "sys.%" \
--patterns.exclude "dbo.internal%" \
--patterns.name "{schema}_{table}" \
--permissions "anonymous:read"
# Configure template options (GraphQL now only writes 'enabled', not 'type')
dab auto-config my-def \
--template.rest.enabled true \
--template.graphql.enabled true \
--template.cache.enabled true \
--template.cache.ttl-seconds 30 \
--template.cache.level L1L2
# Update existing definition without permissions (permissions optional for updates)
dab auto-config my-def \
--template.mcp.dml-tool false \
--template.cache.ttl-seconds 60
```
**Result in config:**
```json
{
"autoentities": {
"my-def": {
"patterns": {
"include": ["dbo.%", "sys.%"],
"exclude": ["dbo.internal%"],
"name": "{schema}_{table}"
},
"template": {
"rest": { "enabled": true },
"graphql": { "enabled": true },
"mcp": false,
"cache": {
"enabled": true,
"ttl-seconds": 60,
"level": "l1l2"
}
},
"permissions": [
{
"role": "anonymous",
"actions": [
{ "action": "read" }
]
}
]
}
}
}
```
**Notes:**
- GraphQL template now correctly serializes as `"graphql": { "enabled":
true }` without the empty `type` object that was previously being
written.
<!-- START COPILOT ORIGINAL PROMPT -->
<details>
<summary>Original prompt</summary>
>
> ----
>
> *This section details on the original issue you should resolve*
>
> <issue_title>Add CLI command `dab autoentities
configure`</issue_title>
> <issue_description>New CLI commands need to be added in order to allow
the users to change the autoentities properties inside of the config
file.
> Introduce a new autoentities configure subcommand that operates like
an upsert.
> These commands need to follow the existing coding pattern that we have
for the other CLI commands
>
> ```
> dab autoe-config {definition-name} --patterns.include value
> dab autoe-config {definition-name} --patterns.exclude value
> dab autoe-config {definition-name} --patterns.name value
>
> dab autoe-config {definition-name} --template.mcp.dml-tool value
> dab autoe-config {definition-name} --template.rest.enabled value
> dab autoe-config {definition-name} --template.graphql.enabled value
> dab autoe-config {definition-name} --template.cache.enabled value
> dab autoe-config {definition-name} --template.cache.ttl-seconds value
> dab autoe-config {definition-name} --template.cache.level value
> dab autoe-config {definition-name} --template.health.enabled value
>
> dab autoe-config {definition-name} --permissions role:actions
> ```</issue_description>
>
---------
Co-authored-by: copilot-swe-agent[bot] <198982749+Copilot@users.noreply.github.com>
Co-authored-by: RubenCerna2079 <32799214+RubenCerna2079@users.noreply.github.com>
Co-authored-by: Ruben Cerna <rcernaserna@microsoft.com>
Co-authored-by: Jerry Nixon <1749983+JerryNixon@users.noreply.github.com>
Co-authored-by: Aniruddh Munde <anmunde@microsoft.com>dab auto-config (#3086)1 parent e1e4359 commit 4c26d60
File tree
6 files changed
+683
-3
lines changed- src
- Cli.Tests
- Cli
- Commands
- Config/Converters
6 files changed
+683
-3
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
| 92 | + | |
| 93 | + | |
| 94 | + | |
| 95 | + | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
| 105 | + | |
| 106 | + | |
| 107 | + | |
| 108 | + | |
| 109 | + | |
| 110 | + | |
| 111 | + | |
| 112 | + | |
| 113 | + | |
| 114 | + | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
| 119 | + | |
| 120 | + | |
| 121 | + | |
| 122 | + | |
| 123 | + | |
| 124 | + | |
| 125 | + | |
| 126 | + | |
| 127 | + | |
| 128 | + | |
| 129 | + | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
| 141 | + | |
| 142 | + | |
| 143 | + | |
| 144 | + | |
| 145 | + | |
| 146 | + | |
| 147 | + | |
| 148 | + | |
| 149 | + | |
| 150 | + | |
| 151 | + | |
| 152 | + | |
| 153 | + | |
| 154 | + | |
| 155 | + | |
| 156 | + | |
| 157 | + | |
| 158 | + | |
| 159 | + | |
| 160 | + | |
| 161 | + | |
| 162 | + | |
| 163 | + | |
| 164 | + | |
| 165 | + | |
| 166 | + | |
| 167 | + | |
| 168 | + | |
| 169 | + | |
| 170 | + | |
| 171 | + | |
| 172 | + | |
| 173 | + | |
| 174 | + | |
| 175 | + | |
| 176 | + | |
| 177 | + | |
| 178 | + | |
| 179 | + | |
| 180 | + | |
| 181 | + | |
| 182 | + | |
| 183 | + | |
| 184 | + | |
| 185 | + | |
| 186 | + | |
| 187 | + | |
| 188 | + | |
| 189 | + | |
| 190 | + | |
| 191 | + | |
| 192 | + | |
| 193 | + | |
| 194 | + | |
| 195 | + | |
| 196 | + | |
| 197 | + | |
| 198 | + | |
| 199 | + | |
| 200 | + | |
| 201 | + | |
| 202 | + | |
| 203 | + | |
| 204 | + | |
| 205 | + | |
| 206 | + | |
| 207 | + | |
| 208 | + | |
| 209 | + | |
| 210 | + | |
| 211 | + | |
| 212 | + | |
| 213 | + | |
| 214 | + | |
| 215 | + | |
| 216 | + | |
| 217 | + | |
| 218 | + | |
| 219 | + | |
| 220 | + | |
| 221 | + | |
| 222 | + | |
| 223 | + | |
| 224 | + | |
| 225 | + | |
| 226 | + | |
| 227 | + | |
| 228 | + | |
| 229 | + | |
| 230 | + | |
| 231 | + | |
| 232 | + | |
| 233 | + | |
| 234 | + | |
| 235 | + | |
| 236 | + | |
| 237 | + | |
| 238 | + | |
| 239 | + | |
| 240 | + | |
| 241 | + | |
| 242 | + | |
| 243 | + | |
| 244 | + | |
| 245 | + | |
| 246 | + | |
| 247 | + | |
| 248 | + | |
| 249 | + | |
| 250 | + | |
| 251 | + | |
| 252 | + | |
| 253 | + | |
| 254 | + | |
| 255 | + | |
| 256 | + | |
| 257 | + | |
| 258 | + | |
| 259 | + | |
| 260 | + | |
| 261 | + | |
| 262 | + | |
| 263 | + | |
| 264 | + | |
| 265 | + | |
| 266 | + | |
| 267 | + | |
| 268 | + | |
| 269 | + | |
| 270 | + | |
| 271 | + | |
| 272 | + | |
| 273 | + | |
| 274 | + | |
| 275 | + | |
| 276 | + | |
| 277 | + | |
| 278 | + | |
| 279 | + | |
| 280 | + | |
| 281 | + | |
| 282 | + | |
| 283 | + | |
| 284 | + | |
| 285 | + | |
| 286 | + | |
| 287 | + | |
| 288 | + | |
| 289 | + | |
| 290 | + | |
| 291 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
| 92 | + | |
| 93 | + | |
| 94 | + | |
| 95 | + | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
0 commit comments