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

Remove BinaryFormatter usage from System.Resources.Extensions #39292

Closed
GrabYourPitchforks opened this issue Jul 14, 2020 · 14 comments
Closed

Remove BinaryFormatter usage from System.Resources.Extensions #39292

GrabYourPitchforks opened this issue Jul 14, 2020 · 14 comments
Labels
area-System.Resources binaryformatter-migration Issues related to the removal of BinaryFormatter and migrations away from it enhancement Product code improvement that does NOT require public API changes/additions
Milestone

Comments

@GrabYourPitchforks
Copy link
Member

Ref:

private object ReadBinaryFormattedObject()
{
if (_formatter == null)
{
_formatter = new BinaryFormatter()
{
Binder = new UndoTruncatedTypeNameSerializationBinder()
};
}
return _formatter.Deserialize(_store.BaseStream);
}

This issue tracks the removal and replacement of this code per the BinaryFormatter obsoletion plan.

@ghost
Copy link

ghost commented Jul 14, 2020

Tagging subscribers to this area: @tarekgh, @buyaa-n, @krwq
Notify danmosemsft if you want to be subscribed.

@Dotnet-GitSync-Bot Dotnet-GitSync-Bot added the untriaged New issue has not been triaged by the area owner label Jul 14, 2020
@tarekgh tarekgh added enhancement Product code improvement that does NOT require public API changes/additions and removed untriaged New issue has not been triaged by the area owner labels Jul 14, 2020
@tarekgh
Copy link
Member

tarekgh commented Jul 14, 2020

CC @ericstj

@danmoseley
Copy link
Member

Per the plan, this could maybe have the 6.0 milestone?

@ericstj
Copy link
Member

ericstj commented Jul 14, 2020

Actually it's not clear to me from this doc why this code is removed or replaced. Why wouldn't we just let this be controlled by "disable BinaryFormatter" feature switch?

@GrabYourPitchforks
Copy link
Member Author

BinaryFormatter is eventually going to be disabled by default across all project types, and for all new project types (wasm, etc.) it's permanently disabled with no way to re-enable it. Per the doc our eventual goal is that no aspect of the .NET runtime or first-party libraries should require developers to re-enable BinaryFormatter within their applications. Requiring users to re-enable it runs counter to our goal of improving the ecosystem. It's also going to be infeasible for certain code bases to re-enable support for BinaryFormatter since it will be perma-disabled for compliance reasons, regardless of project type.

@ericstj
Copy link
Member

ericstj commented Oct 9, 2020

I see. The real work here would be to get @dotnet/dotnet-winforms and @dotnet/project-system to migrate off of using BinaryFormatter for types and move to one of the other supported formats (TypeConverter or Stream). We may also need to add some API (Stream ctors) or TypeConverters to support this scenario for types we own that don't currently work well in this scenario. We probably also need an migration tool that would convert binary-formatted payloads folks have checked into their source resx files and converts to a one of the new formats.

@GrabYourPitchforks maybe we should start by getting these teams to move to a new method and update the components which are producing BinaryFormatted payloads?

Here's a rough sketch of the order I'd see this happening:

  1. Update ResXResourceWriter (and any other code in WinForms designer / project-system) to ensure that it gives precedence to safe formats, and fails rather than using BinaryFormatter.
  2. Produce a migration tool that converts existing BinaryFormatted payloads -> safe formats, ideally just roundtripping through code updated in 1.
  3. Introduce some type of warning/failure in MSBuild when it encounters these payloads and instructs folks to run tool from 2.
  4. For any types which require work (TypeConverters or API) we add it based on feedback / discovery of errors after doing 3. We could probably proactively do some of this based on our existing data. Note that anything we do here wouldn't work on older frameworks if we just added the converters to the types. TypeConverters could be OOB-able if we register them on the consumption side (via TypeDesicriptor). We'd need to decide if it was important for this change to work on older frameworks, and if so we could do this registration in the DeserializingResourceReader.
  5. Remove the use of BinaryFormatter in DeserializingResourceReader.

@merriemcgaw
Copy link
Member

@dreddy-work . FYI. We need to start planning for this.

@ericstj
Copy link
Member

ericstj commented Oct 9, 2020

cc @rainersigwald as well

@rainersigwald
Copy link
Member

I believe there's also implication on the VS designers for .resx files.

@tmeschter
Copy link

Yep. I've pinged @jjmew so we can get updates to the Resource Editor into the planning for (hopefully) .NET 6 but I can't offer any guarantees.

We're going to have interesting problems with projects that multi-target versions of .NET that have BinaryFormatter and those that don't.

@jjmew
Copy link

jjmew commented Oct 13, 2020

@rainersigwald and @tmeschter I think we need PM involved to help us with what experience we want for multi-targeting. Cc: @mckennabarlow @cartermp

@ericstj
Copy link
Member

ericstj commented Oct 13, 2020

We're going to have interesting problems with projects that multi-target versions of .NET that have BinaryFormatter and those that don't.

I think we can make it work if we transition everyone, and include type-converters out-of-band in the Resources.Extensions assembly on older platforms.

There will certainly be some projects which don't want to transition: VS shouldn't break/change build of existing projects. Assuming Security doesn't claim priority here, we'll need to make sure that they can continue to work the way they used to by suppressing some warning.

@merriemcgaw
Copy link
Member

@OliaG might be interested in this discussion too.

@jkotas jkotas added the binaryformatter-migration Issues related to the removal of BinaryFormatter and migrations away from it label May 29, 2024
@bartonjs
Copy link
Member

Addressed by #102379.

@github-actions github-actions bot locked and limited conversation to collaborators Jul 11, 2024
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
area-System.Resources binaryformatter-migration Issues related to the removal of BinaryFormatter and migrations away from it enhancement Product code improvement that does NOT require public API changes/additions
Projects
No open projects
Development

No branches or pull requests