-
-
Notifications
You must be signed in to change notification settings - Fork 805
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
Warnings with latest version from SponsorLink #1370
Comments
I tried to suppress the warning using
But then I get the following empty warning. If this SponsorLink is going to be a requirement then Moq will no longer will pass our acceptance criterea. Our company GDPR rules won't allow leaking all developer internal email addresses, meaning we will be forced to switch an alternative mocking framework. |
I'm likely in the same boat. I've made an issue on the sponsorlink repo too highlighting some potential issues, devlooped/SponsorLink#16, but I'd hate to have projects basically become unusable in company environments over something like this, which I really do believe is a genuinely noble thing. |
This is just unacceptable, free or not. It is not even mentioned on the release notes. Suddenly having a proprietary blob DLL added that sends data to a cloud service is big no and we will avoid Moq in the future. |
The MSBuild target in this GitHub gist may work around the issue with 4.20.0 and 4.20.1 (I'm not conclusive of that from my experimentation in Visual Studio, and given caveat emptor) until a solution that's broadly acceptable to the community is reached. I'm supportive of Moq getting sponsorship for the value it brings, but the implementation added here is disruptive and raises privacy concerns, particularly for non-corporate sponsored usage of Moq in other FOSS. |
Additionally, the library being used to do this has now licence. As such, Moq will be unusable for most (if not all) business/commercial uses. |
Some deeper discussion in #1372. As it turns out, SponsorLink also gets it's config from a remote location, and hides itself for the first few days... |
so just like a virus |
Malware in a dependency is in no way acceptable. |
Heya folks: added a note to get you at ease with this change: https://github.com/devlooped/SponsorLink/blob/main/readme.md#privacy-considerations At no point is the email sent to anyone, unless you EXPLICITLY authorize so on GitHub itself. Would making the SponsorLink analyzer itself opensource change things at all? Also, wouldn't NOTE: there is NOTHING done on CLI / CI, there is no run-time dependency, it's just an IDE |
Dependencies that can't be easily audited are inherently a security risk, especially when they have the ability to perform network communications.
Can't it already be bypassed by doing something like #1373?
Potentially compromising an IDE is still a significant security risk. |
Source: trust me bro |
It doesn't really solve the problem though: we can only trust that the DLL is safe and works as advertised.
And all of this just to nag developers to sponsor the library? It is unfortunate that so many companies don't contribute back to open source libraries, that should definitely change, but this is not the solution. |
Hey @kzu, thank you for the reply! I was very surprised yesterday when I noticed that new behavior. As I said, I get your reasoning for this, but I think it went way too far. With just doing a package upgrade, there was suddenly code running during build time that analyzed my local computers configuration. Additionally, it seems that there are web requests being sent to a command & control server. This, combined with the fact that SponsorLink is not only closed source but even obfuscated, makes it just look very untrustworthy. Analyzers are supposed to locally analyze the code, as @sharwell made you aware of in April: devlooped/SponsorLink#10 I can not imagine a scenario where any company would allow such a behavior. Personally, I don't believe there was malicious intent on your side, but the whole behavior is so close to malware. And, additionally, we're introducing a whole new attack vector by allowing SponsorLink outside communication during build times. |
…sed source that has exhibited behavior resembling that of malware:�https://github.com/moq/moq/issues/1370
Regardless of the privacy and security concerns that have been raised, I don't believe using the error list is an appropriate method for conveying sponsorship information. The purpose of the error list is to highlight problems or potential issues with the code you're writing, not for advertisement. I agree that open source maintainers deserve financial support, as I'm sure do many other developers, but this is not the right way to go about it. |
True, if all open source transient dependencies used by a project were to exhibit similar behavior it would cause serious usability issues as everyone would be inundated with spurious warnings/errors. |
to be fair he wouldn't be the first one to do so, I've seen it several times with some extensions or libraries, but definitely not a way to go BTW you can report the library at nuget for its doubtful privacy standards: https://www.nuget.org/packages/Devlooped.SponsorLink/1.0.0/ReportAbuse |
Are there any plans to change this behaviour? This is a massive problem for me right now because I've just updated all our packages to conform to our company's new security mandate and I've got to report on progress to the SecOps team tomorrow. |
The release notes for Moq 4.20.2 seem to suggest, that this version does not contain this dubious mechanism, although it may be temporary, as the reason is that it breaks builds on MacOS, so if they manage to address this for MacOS, then the mechanism may be put back into Moq. |
@saliej Version 4.20.2 is free of this crap. At least for now. Consider change to NHibernate or other library. |
@kzu what is the decision on this? is the removal temporary or permanent? |
Dang, removing Moq is definitely gonna be an expensive refactor of our corporate codebase... better start writing some technical debt items... |
I know how it feels when you work hard without valuable sign of appreciation. This hurts, really. But installing any extra package without clear consent is not an option, really. It burns the trust to the package and, what even worse to the Open Software, to all of us who doing Open Source. This hurts even worse :'( Stay safe and strong, the package is great and very well known across the world. I believe you will find the funding in another way |
In case anyone is interested in my long-form thoughts on this, figured I'd write it up as a blog post rather than fracture it across GitHub threads: https://seankilleen.com/2023/08/on-moq-and-our-part-in-the-oss-sustainability-social-contract/ |
@kzu I'm sure sure you know this already, but I would like to offer more context. |
I've sponsored but also will be making sure to specifically remove this during builds. |
Out of curiosity, I hopped over to check out how many new forks popped up since yesterday. At least five new forks were created removing SponsorLink. I'm not a lawyer but I think the license would preclude that. However, that alone isn't going to stop people from doing it. In the future, I might consider avoiding dependencies on OSS libraries whose license does preclude simply forking away from undesired additions. In the meantime, I'm content to pin to 4.18 until this all gets sorted out |
Inserting compiler warnings almost as an advert? Game over man, game over. |
The road to bleak dystopia is paved with good intentions. Pausing our build until we install a binary ad blob is just another stone. Don’t think for one moment that closed-source suppliers won’t adopt this.
|
Next time, don't collect people's information without making it incredibly clear in advance exactly what you are going to do. Our org is done with Moq as is every other org that cares about security. I'll miss using this great library, but I'm going to comb through our codebase and remove every reference to it. Goodbye. |
Does it matter? I have no reason to trust them. |
I operate with zero trust in this or the possible replacement. It doesn't matter anymore because of the lack of response here and his attitude in other threads already decided for me. |
Perfect example of how to completely kill an open source project. Well done. Open source culture and values:
I'm pretty sure you nailed all three (as in, destroyed). There's a simple way out though - own the mistake, and reverse the mistake. The community can be forgiving. Anything less and you're sunk. |
Hello folks. Now that SponsorLink itself is OSS, please head over to the repo and follow/comment on the issue of warnings specifically: devlooped/SponsorLink#32 |
Moq = sadly zero trust from now on |
@MrRosendahl was this comment, which sent an email to all 27 people attached to this 8 month old closed issue, entirely necessary? (yes I see the hypocrisy). |
Hey team,
I appreciate the effort, and really like Moq, thank you for creating it!
In one project, I just did a dependency update and noticed that I get
MOQ101
warnings when building in Visual Studio, along with a behavior that seems to block the build for a few hundred milliseconds:It looks like this was introduced in in https://github.com/moq/moq/releases/tag/v4.20.0 with #1363.
Is there a way to disable the warnings, e.g. via a setting in the
*.csproj
file of the test projects or similar?The text was updated successfully, but these errors were encountered: