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

Issue: New .NET Foundation Project Application #333

Open
16 of 18 tasks
TonyTroeff opened this issue Nov 5, 2023 · 8 comments
Open
16 of 18 tasks

Issue: New .NET Foundation Project Application #333

TonyTroeff opened this issue Nov 5, 2023 · 8 comments
Assignees
Labels
project application project support Use this label to request support for an existing .NET Foundation project

Comments

@TonyTroeff
Copy link
Member

TonyTroeff commented Nov 5, 2023

Project Name

TryAtSoftware.Extensions

License

MIT

Contributor

TonyTroeff

Existing OSS Project?

Yes

Source Code URL

https://github.com/TryAtSoftware/Extensions

Project Homepage URL

No response

Project Transfer Signatories

Description

TryAtSoftware.Extensions is a repository containing many libraries with extension methods and utility components one can use to reduce repetitive code or simplify common tasks.

Name

Tonyslav Troeff

Email

tonyslav_troeff@outlook.com

GitHub Profile URL

https://github.com/TonyTroeff

Committers

No response

Governance Model

In order to propose new changes, the repository should be forked and a Pull Request must be created (from the forked repository) to the original one. The whole process is described within the CONTRIBUTING.md file.

CLA

  • If already an OSS project, was a Contribution License Agreement in place for contributions accepted?

How does the project check who has signed one?

I am willing to make the required changes in order to introduce CLA.

CLA Notification Alias

No response

Select the Project Transfer Agreement model

Contribution

Repository Layout

Currently, within this repository, there are multiple projects from the TryAtSoftware.Extensions.* family. If necessary, each one of them may be separated.

Eligibility Criteria

  • The project is built on the .NET platform and/or creates value within the .NET ecosystem.
  • The project produces source code for distribution to the public at no charge.
  • The project's code is easily discoverable and publicly accessible (preferably on GitHub).
  • The project contains a build script that can produce deployable artifacts that are identical to the official deployable artifacts, with the exception of code signing (Exception may be granted for strong name keys, though strongly encouraged to be committed. Exception relies on OSS signing being in the build script for public builds).
  • When applicable, project must use reproducible build settings in its toolchain.
  • The project uses Source Link.
  • The project uses either embedded PDBs or publish symbol packages to NuGet (if applicable).
  • The project code signs their artifacts as appropriate.
  • The project organization has 2FA enabled. Requiring 2FA must be done as part of onboarding if not already enabled.
  • Libraries that are mandatory dependencies of the project are offered under a standard, permissive open source license which has been approved by the .NET Foundation (exceptions include a dependency that is required by the target platform where no alternative open source dependency is available such as the .NET Framework or a hardware specific library).
  • Committers are bound by a Contributor License Agreement (CLA) and/or are willing to embrace the .NET Foundation's CLA when the project becomes a Member.
  • The copyright ownership of everything that the project produces is clearly defined and documented.
  • The project has a public issue tracker where the status of any defect can be easily obtained.
  • The project has a published Security Policy.
  • The project has a home page which provides high level information about its status and purpose.
  • The project has a public communication channel where community members can engage with maintainers.
  • The project has a publicly available location where members can review and contribute to documentation.

PR Plan Summary

No response

Infrastructure Requirements Summary

There are no requirements - the projects can be consumed as a NuGet package.

Additional Notes

No response

@TonyTroeff TonyTroeff added project application project support Use this label to request support for an existing .NET Foundation project labels Nov 5, 2023
@sbwalker
Copy link
Collaborator

sbwalker commented Nov 7, 2023

@TonyTroeff can you please clarify if you are applying to have your entire open source project https://github.com/TryAtSoftware/Extensions join the .NET Foundation... or if you are only submitting the TryAtSoftware.Extensions.Reflection class.

@TonyTroeff
Copy link
Member Author

I do not know which would be easier. Potentially, I would like to apply with all of them. However, they may consist of multiple separate NuGet packages (and there are more yet to come). I would appreciate your advices.

@sbwalker
Copy link
Collaborator

sbwalker commented Nov 7, 2023

Usually an application includes all of the IP which is grouped under the same open source license. So in your case it appears that the entire repo including all of your extensions is offered under the same MIT-based permissive license. So your application should include the entire repo. If you wanted to only contribute a specific Extension then you would need to manage that extension as an independent piece of IP under its own distinct license. However I don't think that is your intent in this situation. Note that it does not matter if you may have 1 or more Nuget packages depending on your deployment strategy. What matters is that all items in your distribution are licensed under the same open source license. I hope this makes sense.

@TonyTroeff
Copy link
Member Author

Yes, it does, In that case, it makes sense to include everything that is included within the repository. Should I create a new application or edit this one?

@sbwalker
Copy link
Collaborator

sbwalker commented Nov 7, 2023

I would suggest simply editing this application

@TonyTroeff
Copy link
Member Author

Done!
Excuse me for the delayed response. I was sick the last few days...

@sbwalker
Copy link
Collaborator

sbwalker commented Dec 14, 2023

@TonyTroeff the Project Committee reviewed your application and it was noted that the Windows Community Toolkit (https://github.com/CommunityToolkit/WindowsCommunityToolkit) is a "utility" project that is already a member of the .NET Foundation - so perhaps there may be an option to approach its maintainer(s) to determine if there is interest in joining forces. From a maintainers point of view, I completely understand if this does not align with your personal goals for the project... but the Committee thought it would be a good idea to raise the question with you regardless. Please share your thoughts so that we can determine next steps for your application.

@TonyTroeff
Copy link
Member Author

Hello!

From what I know and have seen, the Windows Community Toolkit is mostly focused on the development of UI components. However, the idea of TryAtSoftware.Extensions is to expose extension methods and utility components simplifying common tasks at lower or higher level of abstraction and complexity. It is platform-independent and, moreover, all libraries are developed under .NET Standard.
The two projects just look too different to me.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
project application project support Use this label to request support for an existing .NET Foundation project
Projects
None yet
Development

No branches or pull requests

3 participants