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

tools: update clang-format to v19 #55201

Open
wants to merge 3 commits into
base: main
Choose a base branch
from

Conversation

avivkeller
Copy link
Member

@avivkeller avivkeller commented Sep 30, 2024

The previous attempt to update clang-format used a WASM compiled library, which unfortunately had it's issues, and was reverted.

This attempt uses the direct binaries instead of the WASM compiled library, so it can be ensured that they are identical to what is expected.

@nodejs-github-bot nodejs-github-bot added the tools Issues and PRs related to the tools directory. label Sep 30, 2024
@avivkeller
Copy link
Member Author

The issue with the WASM was that it wasn't writing the files correctly. I've confirmed that is not this case with this setup.

CC @nodejs/cpp-reviewers

@avivkeller avivkeller added the c++ Issues and PRs that require attention from people who are familiar with C++. label Sep 30, 2024
Copy link
Member

@anonrig anonrig left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There is no way to validate the correctness, capability and security of a binary. If we are going to do this, it should be maintained by the Node.js organization, or it should be a package thats well known to the ecosystem.

@targos
Copy link
Member

targos commented Oct 1, 2024

FWIW I still have an experimental repo that builds clang-format on GitHub actions in my computer (I deleted it from GitHub when the wasm-based tool landed), if you want to start from something.

@avivkeller
Copy link
Member Author

FWIW I still have an experimental repo that builds clang-format on GitHub actions in my computer (I deleted it from GitHub when the wasm-based tool landed), if you want to start from something.

Interesting. I was using @muttleyxd's built binaries, but I'd be happy to take a look at your builds.

@targos
Copy link
Member

targos commented Oct 1, 2024

https://github.com/targos/clang-format
With test build: https://github.com/targos/clang-format/actions/runs/11124135962

@avivkeller
Copy link
Member Author

Thanks! I'll incorporate that workflow

@avivkeller avivkeller marked this pull request as draft October 1, 2024 12:04
@avivkeller avivkeller changed the title tools: update clang-format to v18 tools: update clang-format to v19 Oct 2, 2024
@avivkeller
Copy link
Member Author

@avivkeller avivkeller marked this pull request as ready for review October 2, 2024 20:31
@avivkeller avivkeller requested a review from anonrig October 2, 2024 20:31
@avivkeller
Copy link
Member Author

avivkeller commented Oct 2, 2024

@anonrig the binaries are now built from a workflow (https://github.com/RedYetiDev/node-core-clang-format/blob/main/.github/workflows/build.yml) directly from llvm, so it can be assured that they are safe and correct.

it should be maintained by the Node.js organization

I'm happy to transfer the repo into the org if needed.

@anonrig
Copy link
Member

anonrig commented Oct 3, 2024

cc @nodejs/security-wg

@targos
Copy link
Member

targos commented Oct 3, 2024

So you took my idea and work to your own repository and are now suggesting to transfer that to Node.js. Not nice...

@avivkeller
Copy link
Member Author

avivkeller commented Oct 3, 2024

I didn't mean for it to come off like that, however I don't believe this is taking your idea or work.

While you created a workflow similar, and it was a starting point (for checkout and artifact uploading), I drew inspiration from various sources, such as https://github.com/angular/clang-format/blob/master/build.sh (for MacOS + Linux Building) and https://github.com/muttleyxd/clang-tools-static-binaries/blob/master/.github/workflows/clang-tools-amd64.yml (for Windows Building) when drawing up this method of creating binaries. I wouldn't say I "took [your] idea and work".

Even so, the original "idea" still comes from Angular's clang-format, and the "work" is my own, but as with many OSS projects, it has inspiration from various sources.

OSS is a collaborative ecosystem. Bits and peices from all over help to contribute to the bigger picture.

@avivkeller
Copy link
Member Author

@anonrig are you still blocking? Thank you!

@anonrig
Copy link
Member

anonrig commented Oct 11, 2024

@anonrig are you still blocking? Thank you!

@redyetidev I tried to answer it before, but I'll repeat myself once again. Yes, there is no way to validate the correctness of the distributed binaries. Asking the same question over and over again does not change the fact that this creates a significant security concern.

@avivkeller
Copy link
Member Author

Apologies, I understand now.

@avivkeller
Copy link
Member Author

The way I see it is there is a few things that can be done:

  1. Do nothing, leave our clang-format outdated
  2. Use a prebuilt binary (Whether it be from the package I created, or another package, such as https://github.com/ssciwr/clang-format-wheel or something)
  3. Use the WASM version, which didn't work last time, but has been patched since then.

@lumirlumir
Copy link

lumirlumir commented Oct 23, 2024

Hello @redyetidev,

I recently came across this by chance and wanted to reach out.

I've developed a package succeding angular/clang-format called lumirlumir/clang-format-node, which has grown to over 10,000 users per week.

The entire build process for this package is open and transparent, with all actions and code available for review. It also includes testing across various platforms to ensure maximum stability.

If Node.js would like to manage this package officially, I can give Node.js member or collaborator access to ensure security and ongoing maintenance.

Please feel free to take a look at the package. It would be a great honor If I can collaborate with Node.js on its maintenance.

@avivkeller
Copy link
Member Author

avivkeller commented Oct 23, 2024

Funny thing, I just noticed your package yesterday, and I was planning to switch this to using it later today. If @anonrig is okay with it, seeing as it seems fit the "package thats well known to the ecosystem" claim.

I can't speak on behalf of the organization, but I don't Node.js will need special privileges to that repository

@lumirlumir
Copy link

@redyetidev Great thing. If you need any help from me, feel free to mention me. I’m always on GitHub.

@mhdawson
Copy link
Member

After some discussion in the private section in the TSC meeting today, I'm going to block until we have a discussion in the security wg on a policy/direction/requirements in terms of pulling in new tools into the build process.

@mhdawson
Copy link
Member

Also tagged for discussion in the next security wg meeting.

@avivkeller
Copy link
Member Author

avivkeller commented Nov 8, 2024

Thanks! Just a note for the security team: Dependabot PRs, while they are created from internal branches, run pull_request checks without the same additional access. They run in a "dependabot" context.

Copy link

codecov bot commented Nov 9, 2024

Codecov Report

All modified and coverable lines are covered by tests ✅

Project coverage is 87.91%. Comparing base (58a8eb4) to head (5484ac9).
Report is 2 commits behind head on main.

Additional details and impacted files
@@            Coverage Diff             @@
##             main   #55201      +/-   ##
==========================================
- Coverage   88.40%   87.91%   -0.50%     
==========================================
  Files         654      654              
  Lines      187815   187815              
  Branches    36136    35829     -307     
==========================================
- Hits       166045   165113     -932     
- Misses      15001    15892     +891     
- Partials     6769     6810      +41     

see 92 files with indirect coverage changes

@lumirlumir
Copy link

Hello @redyetidev,

First of all, I apologize if my question is somewhat unrelated to the current PR.

I have a question: would it be possible to transfer the clang-format-node package I created to the Node.js group, so it could be managed collaboratively by the Node.js community?

I read through the contribution guidelines, and it seems this might be possible with the approval of collaborators, so I wanted to reach out and ask. (If posting this question in the discussion section for the Node.js group would be more appropriate, I’d be happy to move it there.)

As I continue developing this package, I believe transferring it to the Node.js group could improve security, especially with regards to binary files, and help ensure stable and robust maintenance. For these reasons, I wanted to explore the idea of working together on it.

Similar to how Google’s Angular team manages their own clang-format package, I feel that having the Node.js group maintain clang-format-node would allow users to trust and adopt it more confidently.

Additionally, since I’m still developing my skills and recognize that my name alone may not yet inspire confidence for a broad user base, I think it would be beneficial to manage the package within a larger community.

Thank you for considering this, and please let me know if there’s a more appropriate way to move forward!

@avivkeller
Copy link
Member Author

Hi! I'm not a core collaborator, so I'm not the person to ask. The security working group will meet sometime in the future, and I'm sure they'll take this into account. (Although someone can always correct me)

@lumirlumir
Copy link

@redyetidev Thank you for your response!

I’ll wait until a decision is made.

@mhdawson
Copy link
Member

mhdawson commented Dec 5, 2024

We discussed in the security wg meeting today.

  1. We agreed that we should not be pulling in tools build/stored in somebodies personal repos
  2. It's not clear how important getting an update to clang format is.

@targos what do you think the priority is on this and what is the right way to do it?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
c++ Issues and PRs that require attention from people who are familiar with C++. tools Issues and PRs related to the tools directory.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

7 participants