Tech Casualties of Russia's War in Ukraine: Open Source and the Cloud? (github.io) 93
Long-time Slashdot reader theodp writes: In On the Weaponisation of Open Source, software engineering consultant Gerald Benischke examines how the Russian invasion of Ukraine has spilled over into areas of software development, with some unintended consequences. In particular, Benischke looks at the decision by MongoDB to cut off services in Russia, the destructive change in a node library that deleted files on Russian IPs, and even a change in the code/licence in a community terraform module to assert that Putin is a 'dickhead.'
Benischke concludes, "My problem is that this weaponisation is killing off trust. I think the temptation of using open source projects as weapons against Russia should be resisted because it sets a dangerous precedent and may ultimately set back the open source movement and push organisations back into seeking refuge in commercial software with all its opaqueness and obscurity. It's not about sitting on the fence or taking sides in a war. It's about what open source has achieved over the last 30 years and I think that's now at risk of become collateral damage."
Meanwhile, the war is also being fought on the Cloud front, with Microsoft halting all new sales in Russia. In fact, all of the major U.S. cloud providers have stepped back from doing business in Russia. "You basically have Russia becoming a commercial pariah," explained economist Mary Lovely. "Pretty much no company, no multinational, wants to be caught on the wrong side of U.S. and Western sanctions."
Benischke concludes, "My problem is that this weaponisation is killing off trust. I think the temptation of using open source projects as weapons against Russia should be resisted because it sets a dangerous precedent and may ultimately set back the open source movement and push organisations back into seeking refuge in commercial software with all its opaqueness and obscurity. It's not about sitting on the fence or taking sides in a war. It's about what open source has achieved over the last 30 years and I think that's now at risk of become collateral damage."
Meanwhile, the war is also being fought on the Cloud front, with Microsoft halting all new sales in Russia. In fact, all of the major U.S. cloud providers have stepped back from doing business in Russia. "You basically have Russia becoming a commercial pariah," explained economist Mary Lovely. "Pretty much no company, no multinational, wants to be caught on the wrong side of U.S. and Western sanctions."
Re: (Score:1)
Yes, these guys need stop this nonsense and put their sausages back in their pants, as mentioned it will damage trust.
what has not happened in the open as it is now is the question of developers not wanting their efforts to go to this upstream or that based on bias. the question is easily answered either way by forks. and open source developers hijack projects all the time "for the greater good" no doubt.
Re: (Score:2)
The reputation of Open Source is built on the reputation of the benevolent dictatorship of maintainers. When maintainers start putting backdoors (it does not f*cking matter in the name of what), the reputation is out the window.
There will be no easy way of fixing it too. It will be rubbed up the open source community nose for years to come.
Ditto for the cloud - cloud reputation is built on its neutrality. The only company/organization which remained truly neutral in this i
Re: (Score:2)
Couldn't agree more. They're acting like televangelists.
Trust No One (Score:4, Insightful)
Re: (Score:1)
Operating on a system of least trust, where, at a minimum, your dependencies are all explicitly pinned, and, more realistically, where any bit of critical kit gets its dependencies from an internally managed mirror--with new versions being screened as they're published--this should be standard operating procedure....
you have just described 80% of closed source work. and i suspect closed source has never been actually as closed as people complain about, more likely the discussion from the beginning is very exclusive.
Re: (Score:2)
And I don't really trust closed source. It's quite popular these days to send "usage statistics" to some home server and you can't opt out unless you first run the program and it has shared data with the home server already.
Re: (Score:2)
So you're saying Satisfactory is sharing "usage data" with Coffestain already which is your implication unless there's some other data that they shouldn't have. Oh like say I'm a customer and bought their product.
Re: (Score:2)
If they get data about you then you aren't a customer, you are a victim.
Re: (Score:1)
It's more than that. If you let them, they'll copy all your contacts, and for bonus points use the microphone to listen to your conversation so they can make targeted ads.
More than once, I've merely *talked* to people about an unusual subject and shortly afterwards I'm getting targeted ads about those subjects.
Plus they've been caught multiple times using a lot more bandwidth than metric would require (multiple megabytes of data per day).
Re: (Score:2)
Since I rarely see ads due to adblocker I don't know if they recognize my voice.
This is already the modus operandi in many places (Score:2)
Operating on a system of least trust, where, at a minimum, your dependencies are all explicitly pinned, and, more realistically, where any bit of critical kit gets its dependencies from an internally managed mirror--with new versions being screened as they're published--this should be standard operating procedure
In many bigger software shops, this is already the norm. They have the extra money and headcount to support complex dependency systems that easily catch justice warrior shenanigans. They'll just skip the broken versions and switch to the eventual replacement once the community selects one.
This is more of an issue for smaller companies, where headcounts are low, budgets are tight, and deadlines are always looming. Those poor chaps are quite reliant on their dependencies to do no evil, not by choice but by ci
Small companies need not be dependent either (Score:2)
This is more of an issue for smaller companies, where headcounts are low, budgets are tight, and deadlines are always looming. Those poor chaps are quite reliant on their dependencies to do no evil, not by choice but by circumstance.
Not necessarily. Many commercial libraries offer both binary and source+binary licenses. A licensee gets access to the source code in the latter, however they may only distribute binaries to their customers. This allows them to have their own fork and control their destiny. At small companies I have successfully convinced management to buy the more expensive source licenses, and in both cases it saved our asses. If the bug was in a library would could fix and patch and deliver a fix to our customers at the
Re: (Score:2)
My view is that if you don't have the head count to dedicate someone to supporting the package dependencies then if package is not in the distribution that you are using repo's then you should not be using it.
That is the value that a LTS distro brings. The problem is what I call the "Java boys" who think they have to be using latest greatest at all times, and rewriting everything in the latest fashionable language (which historically was Java) is the solution to world peace.
Re: (Score:2)
It's not even about malice or activism. Pinning is the only sensible thing to do: otherwise you will get random breakage. You might for example unwittingly be depending on behavior that is a bug and gets fixed in a minor point release (every observable behavior is a feature).
Three options not two, FOSS not only source option (Score:2)
(1) FOSS license
(2) Commercial Source license
(3) Commercial Binary license
FOSS and Commercial Source licensing are nearly identical for direct licensees. A licensee has the source code to the application or library, they may make changes or additions, they may freely distribute binaries with their changes. The difference is largely that source code only goes one generation, to the direct licensee and not to their customers too.
So as a developer you have two options w
Re: (Score:2)
Sure, you can (and should) pin your dependencies versions. But when the time comes to upgrade them, how do you do it? Upgrade them on your dev machine and test? Bam, random files were deleted on your dev machine.
This is not a random bug, it's a targeted attack against devs machines.
Unless you dev in a VM or a container (which has its own problems) you're going to get hit.
Re: Trust No One (Score:2)
Re: (Score:2)
Usually you test first on a sandboxed test machine *before* testing on your dev machine? That's odd.
Or do you use a VM as a test machine ?
continuous integration and deployment (Score:4, Insightful)
Modern practices of continuous integration and deployment are the real issue here. If you are using your own copy of the source and pay attention then this is a non-issue. If you just pull the latest from a public repo and start using it then you are asking for trouble. It should be obvious in 2022 that software security is not a matter of the type of license.
Re: (Score:3)
If you just pull the latest from a public repo and start using it then you are asking for trouble.
This. So much this. As a certified Old Guy who comes from an embedded world where step 1 of validating a build environment is "from scratch, create the build environment. Pull in the source from the most recent known good version. Verify that the binaries CRC-check with the binary that was qualified" - the number of commercial products (not at my employers, but just in talking to people) that pull random latest components down directly from the Internet is chilling. It would be like Ford saying "We make our
Re: (Score:3)
That's certainly how the US Navy does it.
https://www.defensenews.com/na... [defensenews.com]
Re: (Score:2)
Re: (Score:2)
Actually, I've had two gcc's with the same version number and options give different results, and not just because of the difference in build date. And not even with the MPC stuff, it was a simple operation that was 2 instructions versus on, as if the optimization was ever so slightly better in one. A head scratcher.
Re: (Score:2)
Re: (Score:2)
I'm desperately trying to get us to a newer compiler. It will change all the bytes...
Re: (Score:2)
If you just pull the latest from a public repo and start using it then you are asking for trouble.
This. So much this.
So how do you do it when you want to upgrade? Do you read changelogs and diff of all libs you upgrade? Remember that this thing also target dev machines.
Re: (Score:2)
So how do you do it when you want to upgrade? Do you read changelogs and diff of all libs you upgrade?
As part of updating the SBOM - the short answer is "yes, and if there are changes, they will trigger a security assessment and other qualification steps which is why I try to be very conscious of WHEN to consume library upgrades".
Re: (Score:1)
But the issue is while you are validating the software, your competitors are already selling product.
Once a decade, your due diligence saves your ass.
But after three years, your company went bankrupt.
Validating software costs money and time. When the software is literally reliable for *years*, that cost of time and money becomes a competitive disadvantage.
And in cases like log4j, it doesn't even buy you anything compared to your competitors.
I certainly understand the U.S. navy and even a fortune 500 compa
Re: (Score:2)
Re: (Score:2)
Wear clothes and practice self-defense to avoid getting raped.
Break things, and fix them, before you get to production.
Who was Facebook ever in a race with and did they win by moving fast and breaking things? Did they ever treat security concerns in a 'move fast and break things' manner?
Open Source is not a permit to evade sanctions (Score:2, Interesting)
Yes and no (Score:3)
Interestingly enough, this same defence can be used to justify the malicious changes to peacenotwar as much as it can be used to defend peopl
Re: (Score:2)
Source code is not software, it is speech.
Why can't it be both?
I mean, we can also say the same thing about binary programs, if we encode them in ASCII and then scan or recite (for those masochistic enough) letter-by-letter the resultant "text".
Re: (Score:2)
Yes, and even speech can be made illegal in wartime. Even morally incorrect, such as speech that helps the enemy ("here's where our troops will be located tomorrow at 3am").
When war is involved, it stops being mere politics because lives are being lost. Granted, politicians always get involved, as is their way. Saying one doesn't want to get involved in politics here is like using politics to say why you don't want to be serve on a jury trial for a murderer because you don't want to get involved in polit
Re: (Score:2)
here you go: https://www.bbc.com/news/world... [bbc.com]
Or were you trying to make some 'clever' point that because much of Europe still depends on Russian gas to keep civilians warm and, yknow, not die, everything else that is being done is somehow pointless?
Interesting, but ultimately retarded, point. Thanks for trying.
Re: (Score:2)
Re: (Score:2)
The active choice to commit of crimes against humanity [un.org] by Russian soldiers under approval of its leadership necessarily dictates that the state be punished. It is a fact that actions against the state must also apply to the individuals the state represents.
I think you have it backwards. Most of the actions done by a soldier, when done individually and in isolation, can't be considered crimes against humanity. It's when these actions are done systematically by a group that they become crimes against humanity. Far from merely approving the actions of their subordinates, the leaders in the chain of command are the masterminds. Without Putin ordering the invasion of Ukraine, none of these Russian soldiers can commit any of these heinous crimes.
Re: (Score:2)
Any EU/US/AUS programmer supporting Russia is violating sanctions, and claiming that contributing to a project not exclusively designed for Russia does not absolve that responsibility.
Stop making stuff up. By and large its not true at all. OSS is mostly legally considered to be 'speech' and not illegal to publish. Its also mostly not illegal to sell software to Russians OR even directly to Putin's government. A lot of big names are opting to do that including Microsoft but they are not legally obligated to do so.
So now that were past the strait up bullshit here some other realities. Russia is not technically speaking the 'they enemy' we are not at war with Russia. Ours and other governme
Re: (Score:2)
Comment removed (Score:3)
Re: (Score:2)
When I see PIP I'm thinking of that old CP/M command.
CP/M's PIP was a knockoff (Score:2)
Re: (Score:2)
With the ASR33 it was 110bps and with null feeds at the carriage return to ensure that it didn't lose characters.
Re: (Score:2)
Thankyou! I'm not the only one!
Here's what happened: 2 good things (Score:4, Insightful)
1/ Killing off the cloud: not a minute too soon! Russia's action forced a practical demonstration of what everybody with 2 working brain cells has known for years: when a cloud operated by someone other than you goes down for any reason, you're fucked.
2/ Killing the trust in open-source: yeah, that's sad. But you know what? The whole premise of open-source is that you didn't have to trust anyone, and you could assess what the code does for yourself. You know, if enough eyeballs... This "killing of trust" only underlines something else everybody has known for years also: there are no eyeballs reviewing open-source code. If there were, revenge code would never get deployed in the first place.
In short, open-source is mostly composed of nice guys, and lazy companies rely on that to cut corners. When some of the nice guys stop being nice, bad things happen to said lazy companies.
Re: (Score:3)
2/ Killing the trust in open-source: yeah, that's sad. But you know what? The whole premise of open-source is that you didn't have to trust anyone, and you could assess what the code does for yourself.
What? Nope.
The premise of Open Source code is that the Source is Open so anyone can look at it. That's it, full stop, END OF LINE. This has both positive and negative repercussions when it comes to security.
You know, if enough eyeballs...
Right. IF, ENOUGH. Some projects receive that level of scrutiny, and some don't. In fact, most don't. However... well, let me circle back.
This "killing of trust" only underlines something else everybody has known for years also: there are no eyeballs reviewing open-source code. If there were, revenge code would never get deployed in the first place.
There are eyeballs reviewing open source code. There are not competent eyeballs surveying all code, and there are not enough eyeballs to catch every problem. But when
Re: (Score:2)
The idea that proprietary software is higher quality than open source is wholly unsubstantiated.
Maybe, but there's one thing proprietary has that open-source never will. Legal liability. That's a force unto itself in enforcing standards including quality.
Re: (Score:3)
That's entirely theoretical. If it was a thing, a lot of Microsoft employees would have been thrown into the slammer over the decades.
Re: (Score:2)
Maybe, but there's one thing proprietary has that open-source never will. Legal liability.
What? Absolutely not. Licenses always absolve the publisher (etc.) from any liability. If they had liability then there would be [almost] no software.
Re: (Score:2)
Of course it is done better at commercial outfits, after all they have Corporate Mission Statements and Slogans, even posters on the wall, all proclaiming that quality is their chief goal! The idea that someone might create bad code and or review it too quickly because of looming deadlines is absurd! :-) (this is a joke of course)
Re: (Score:1)
plenty of Russian major social media and other sites still up, because they use cloud from nations not marching to USA tune. Expect more Russian business and military alliances with China, India, Iran, certain South America and East Asian countries because of this. yay?
Re: (Score:1)
There are many eyes looking at open source- but they are often focused on active areas of the code and don't review apparently stable areas of the code.
Re: (Score:2)
Bullshit.
When some dude slips "if IP in Russia then delete files" in the code and commits it, that's actively changed code, not stable stuff that's been there unchanged forever.
People happily pull the stuff and use it, and then go all surprised because the code does something nasty. The truth is, nobody looks at the diffs, amd that's how open-source can come with malware despite the code being readable. And even if they looked at the changes before rolling out a new version, all it takes is a little obfusca
Re: (Score:1)
We work with open source and we have about 20 open source projects. And we actually do use winmergeu, look at the change logs, and so on to look at the diffs. Maybe other areas of opensource aren't as careful.
Re: (Score:1)
(but we don't spend days doing it. It's hard enough to keep everything updated as it is. So we focus on the hotspots. And test before promoting to production.
Re: (Score:2)
Back when I had a simpler system I used to look at the diffs for a lot of things just updating my system. But now I have a massive raft of stuff since my system does so much more, and that's simply not practical. I just have to hope that someone is looking at code. But then, that's how commercial software is, too. I have to hope that no rogue employee or infiltrator of their network (possibly even an automated one) has inserted something malicious into their code.
Re: (Score:2)
Closed source is similar, not enough eyeballs reviewing code.
I am utterly embarrassed at times when we find a terrible bug, bad enough that the CEO of the customer company calls up our CEO to complain about it and there's an all-hands-on-deck to fix things, then I find the obvious bug and proclaim "what idiot failed to review this code properly!" and it turns out to be me...
Re:Well (Score:4, Insightful)
I suppose NATO has never sinned. I suppose there are absolutely zero Not-sees in Ukraine. Up until the recent invasion no Russian blood has been spilled. No US Democrats has had ANY involvement in Voldemort's goon squads. It's a fine thing it's such a black and white issue with a clear moral line on which side to stand. The "whole" world coming together to punish Russia is EXACTLY what would happen if say China or Israel committed some hypothetical atrocity, because, of course - - you all always follow the same unwavering standards of morality.
1) There's a small handful of far right groups in Ukraine, they have zero influence. There's way more far right groups in Russia, and they're arguably in power. You should look at what Putin has been doing in Ukrainian territories he already controls [aljazeera.com]. You wanna tell me that doesn't remind you of Nazis? Him controlling the rest of Ukraine is an unacceptable outcome.
2) The US has done nasty stuff, not nearly this nasty. False equivalencies do not a compelling argument make.
3) Ukrainians are certainly benefiting from being white European victims when it comes to international support. But still, what Putin is doing is pretty much unprecedented since WWII.
Re: (Score:1)
Re: (Score:2)
Not as documented or widely known is not the same as not happening. Think all the Wikileaks pressure for releasing just a tiny bit of what was happening. And happened for more time and in far more countries.
And for measures that affects mostly the Russian population, it is argued that they didn't have fair elections, they may not be responsible about what a non democratic government does. While
Re: (Score:2)
> 2) The US has done nasty stuff, not nearly this nasty. False equivalencies do not a compelling argument make.
Not as documented or widely known is not the same as not happening.
You think the US secretly invaded and annexed part of another country? You think they invaded with a policy of flattening cities and blowing up bomb shelters?
Say I figured out that you punched someone once, that doesn't mean you don't get to complain about someone on a shooting spree.
And for measures that affects mostly the Russian population, it is argued that they didn't have fair elections, they may not be responsible about what a non democratic government does. While in US Bush was reelected even after was known what they had been doing in Middle East. And still the whole western world didn't lift a finger about that.
It is not so difficult to stop the asymmetries,
It's regrettable that the Russian population is one of the only available sanction targets, but given the choice of potentially forcing Putin to stop and letting him turn Ukraine into a police state with roaming kill squads I'm
Re: (Score:1)
Actually, the U.S. preferred method is to attack the currency/financial system and then buy up the country's assets.
The U.S. (esp business interests) are no saints. And the U.S. has killed civilians (and likely children).
That said, there is a difference in degree. And the U.S. as a whole is usually reacting to being attacked. One issue is that when attacked in a significant way, U.S. citizens get really bloodthirsty for a while. You don't want to be in a total war with the U.S. They will violate the
Re: (Score:2)
Re: (Score:2)
"Russia wants peace..."
Russia want piece of this country, Russia want piece of that country. Russia want piece of *your* country.
Re: (Score:2)
0 influence??? So you think ethnic Russians should have to live under the threat of constant shelling for years, and no one should ever do anything about it. It's only a problem when Russia fights back? Russia has the right to defend itself.
There are two possibilities to explain the continuing war in Donbass.
1) Ukrainians were trying to re-take the territories.
2) Russian/"Separatist" forces from Donbass were firing into Ukraine and Ukrainian forces were returning fire.
Given that it's been clear from 2014 that the Russian army would prevent #1 what possible motive would Ukraine have for unprovoked shelling?
Re: (Score:2)
Why did the Ukrainian government still consider the breakaway territories to be part of Ukraine? Why did they not recognize their sovereignty?
Because they're not real breakaway territories. Russia invaded them, installed a puppet government, ran sham elections, and declared them breakaways.
Very few of those people actually wanted to separate from Ukraine. Even Crimea would still be Ukrainian if it were up to the Crimeans.
that's why they were conducting a campaign of terrorism and ethnic cleansing, because they consider Russian people to be their enemies. That's why they legitimized neo-nazi groups which were on the front lines conducting what they called this "civil war".
Were are you getting this from? Russian media directly? Fringe western websites? Ukrainians have nothing against ethnic Russians. Yes there's some far ight groups like Azov fighting because Ukraine is desperate for any help it ca
Re: (Score:1)
Only that Russian-speaking folks in the Donbas region are not necessarily Russians. Many Ukrainians speak Russian as their primary language and this does not make them Russian â" just like speaking English does not make the Scots Englishmen.
Also, Russia is defending neither itself nor the the Donbas region. They have actually invaded a country, from another side altogether, trying to take the capital and multiple civilian centers by force. You have overdosed on Russian propaganda, I am afraid.
Re: (Score:2)
Re: (Score:2)
Finally! (Score:2)
This is great news. Perhaps now people learn not to include 3rd party repos in their projects, or if they must, first clone said repos to their own git servers, thus never be suprised by upstream doing stupid things.
Most important law, your app must be able to be compiled on a build server that doesn't have connection to the internet and said app much be able to launch without network connectivity.
Re: (Score:2)
Re: (Score:2)
Re: (Score:2)
After Angular fiasco, Is mixed usage really bad? (Score:2)
Should Ukrainians update Russian militarysoftware? (Score:1)
Should Ukrainians update open source software that the Russian military is using?
The answer is: OF COURSE NOT.
If you have any other answer than that, you are mental.
Should Ukrainians update open source software that Russian business is using?
The answer again is: OF COURSE NOT.
---
Russia is currently an enemy to the world. I think that makes it a valid exception to normal open source philosophy.
People who are killing pregnant women, children, toddlers, and babies can't expect updates to their open source so
koch brothers are doing business in russia (Score:2)