- 
                Notifications
    You must be signed in to change notification settings 
- Fork 450
Feature: make ecs more flexible #2019
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
base: main
Are you sure you want to change the base?
Conversation
…ed but not loaded
77dfe53    to
    46968b0      
    Compare
  
    | This PR is stale because it has been open for 60 days with no activity. | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM, though I'm not a user of this tool, so I'm possibly missing something.
| def generate( | ||
| ecs_nested: Dict[str, FieldNestedEntry], | ||
| ecs_version: str, | ||
| ecs_component_name_prefix: str, | ||
| out_dir: str, | ||
| mapping_settings_file: str, | ||
| template_settings_file: str | ||
| ) -> None: | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Not really having context for this tool, adding a new argument like this in the middle seems like it might not be the most compatible way of doing this.. Usually I'd expect new arguments to show up in the kwargs section of the list and then have a reasonable default, which in this case looks like it should be ecs:
| def generate( | |
| ecs_nested: Dict[str, FieldNestedEntry], | |
| ecs_version: str, | |
| ecs_component_name_prefix: str, | |
| out_dir: str, | |
| mapping_settings_file: str, | |
| template_settings_file: str | |
| ) -> None: | |
| def generate( | |
| ecs_nested: Dict[str, FieldNestedEntry], | |
| ecs_version: str, | |
| out_dir: str, | |
| mapping_settings_file: str, | |
| template_settings_file: str, | |
| ecs_component_name_prefix: str = "ecs", | |
| ) -> None: | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Moved to kwarg
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It would be useful to detail what improvements you made from a user's perspective, as this is not detailed on the PR description. The individual commit messages do give a short indication, but also per the contribution guide, could you please add to CHANGELOG.next.md?
| This pull request allows users to 
 This allows ECS tooling to be utilized by more organizations for generating their component templates, and documentation. | 
| This PR is stale because it has been open for 60 days with no activity. | 
| Hi! We just realized that we haven't looked into this PR in a while. We're We're labeling this PR as  Thank you for your contribution! | 
| 👍 | 
    
      
        1 similar comment
      
    
  
    | 👍 | 
| Hi! We just realized that we haven't looked into this PR in a while. We're We're labeling this PR as  Thank you for your contribution! | 
| ❌ Author of the following commits did not sign a Contributor Agreement: Please, read and sign the above mentioned agreement if you want to contribute to this project | 
| Hi @jkb-axios, if you're willing, could you sign the CLA agreement from the cla-checker-service comment above? | 
| TEMPLATE_DIR = path.join(local_dir, '../templates') | ||
| CUR_TEMPLATE_DIR = path.join(cur_dir, 'templates') | ||
| LOCAL_TEMPLATE_DIR = path.join(local_dir, '../templates') | ||
| if path.exists(CUR_TEMPLATE_DIR): | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If these conditions both evaluate to false, this will exit with a TypeError. It would be better to catch this and print a friendly error message
| help='enforce strict checking at schema cleanup') | ||
| parser.add_argument('--intermediate-only', action='store_true', | ||
| help='generate intermediary files only') | ||
| parser.add_argument('--no-ecs', action='store_true', | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could add more documentation to help for the new arguments, to explain more about how these are intended to be used, and to mention they are for custom use cases. It's fine to use multiline strings here, so the help message can be longer.
| FieldNestedEntry, | ||
| ) | ||
|  | ||
| BEATS_DEFAULT_FIELDS = join(dirname(ecs_helpers.__file__), "beats_default_fields_allowlist.yml") | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If this file is intended to be customized, I think it would be better to add a generator.py argument that can be used to specify the file location used
| #### Added | ||
|  | ||
| #### Improvements | ||
| * Allow ECS from any directory #2019 | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could you move these into the "Tooling and Artifact Changes" -> Improvements section?
| Hi! We just realized that we haven't looked into this PR in a while. We're We're labeling this PR as  Thank you for your contribution! | 
| There is still a need for this!  :)
Thanks
Marcial Villegas
Principal Solutions Architect
+1 202.930.3812
<https://www.elastic.co/>… On Tue, Apr 8, 2025 at 8:32 PM github-actions[bot] ***@***.***> wrote:
 Hi!
 We just realized that we haven't looked into this PR in a while. We're
 sorry!
 We're labeling this PR as Stale to make it hit our filters and
 make sure we get back to it as soon as possible. In the meantime, it'd
 be extremely helpful if you could take a look at it as well and confirm its
 relevance. A simple comment with a nice emoji will be enough :+1.
 Thank you for your contribution!
 —
 Reply to this email directly, view it on GitHub
 <#2019 (comment)>, or
 unsubscribe
 <https://github.com/notifications/unsubscribe-auth/ANONDQSEN2FCVWC3T7N5QPD2YRTDPAVCNFSM55BULTS2U5DIOJSWCZC7NNSXTN2JONZXKZKDN5WW2ZLOOQ5TENZYG44TGNZYGQ4Q>
 .
 You are receiving this because you are subscribed to this thread.Message
 ID: ***@***.***>
 *github-actions[bot]* left a comment (elastic/ecs#2019)
 <#2019 (comment)>
 Hi!
 We just realized that we haven't looked into this PR in a while. We're
 sorry!
 We're labeling this PR as Stale to make it hit our filters and
 make sure we get back to it as soon as possible. In the meantime, it'd
 be extremely helpful if you could take a look at it as well and confirm its
 relevance. A simple comment with a nice emoji will be enough :+1.
 Thank you for your contribution!
 —
 Reply to this email directly, view it on GitHub
 <#2019 (comment)>, or
 unsubscribe
 <https://github.com/notifications/unsubscribe-auth/ANONDQSEN2FCVWC3T7N5QPD2YRTDPAVCNFSM55BULTS2U5DIOJSWCZC7NNSXTN2JONZXKZKDN5WW2ZLOOQ5TENZYG44TGNZYGQ4Q>
 .
 You are receiving this because you are subscribed to this thread.Message
 ID: ***@***.***>
 | 
| Hi! We just realized that we haven't looked into this PR in a while. We're We're labeling this PR as  Thank you for your contribution! | 
| 👍 | 
| Hi! We just realized that we haven't looked into this PR in a while. We're We're labeling this PR as  Thank you for your contribution! | 
When using the ECS tooling for custom projects, there are a few minor changes that make would make the tooling more flexible, especially in cases where the ECS schema itself might be minimally used. I appreciate that the primary use case for ECS tooling is the ECS schema, but given that changes are minor and their is value of increased utility for the tooling I hope they could be considered for inclusion in the baseline.
I welcome discussion on the proposed changes.