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

Simplify the top level licensing #35

Open
wants to merge 3 commits into
base: main
Choose a base branch
from
Open
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
11 changes: 9 additions & 2 deletions LICENSE
Original file line number Diff line number Diff line change
@@ -1,7 +1,14 @@
AWS JDBC Driver for PostgreSQL and all Amazon modifications to PostgreSQL JDBC Driver
AWS JDBC Driver for PostgreSQL

This driver is based on the existing PostgreSQL JDBC Driver:

https://jdbc.postgresql.org/

The Amazon driver and all Amazon modifications are licensed under the
same license as the PostgreSQL JDBC Driver and are
Copyright Amazon.com Inc. or affiliates. All rights reserved.
Copy link
Contributor

Choose a reason for hiding this comment

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

So the way I read this is: 1) That this is the Amazon driver which it is not, it is the pgjdbc driver with an Aurora connection handler, and 2) That the Amazon Driver and all Amazon modifications are Copyright Amazon, only the last part is true, the Amazon additions are copyrightable, the modifications can add your copyright, but the existing code should maintain the pgjdbc copyright(s)

Copy link
Author

Choose a reason for hiding this comment

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

Interesting. It feels like the debate here is more about naming than licensing.

I don't view this as the pgjdbc driver, if we called it that we would be misrepresenting this as being from the PostgreSQL project. It's absolutely the Amazon Driver (or in more full from the README "the Amazon Web Services (AWS) JDBC Driver for PostgreSQL"). Would the fuller name fix issues here?

I believe the original intent is that "The Amazon driver" is referring as a shorthand to the code within the https://github.com/awslabs/aws-postgresql-jdbc/tree/main/pgjdbc/src/main/java/software/aws/rds/jdbc/postgresql package. Is your objection that the Driver.java there is primarily from pgjdbc and instead you want it to say "The Amazon 'ca'"? [with whatever noun best fits for cluster aware handler code]

Copy link
Author

Choose a reason for hiding this comment

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

(On naming; my background is mostly Apache project based, and we may be more trademark/name sensitive than most)

Copy link
Contributor

Choose a reason for hiding this comment

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

@hyandell To be clear it has never been about licensing.
My issue has always been attribution.
Amazon has added ~4600 lines of code to 60,000 exclusive of tests. I'm having trouble wrapping my head around how one can claim it's Amazon's driver?

Copy link
Author

Choose a reason for hiding this comment

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

I think there are a lot of overlapping issues to discuss here.

My understanding in general Open Source philosophies is that it is fine to say that something is the same product when there are tiny tweaks. Like a Debian package for a project adding backports or tiny build tweaks but still calling it the same name. Larger changes however mean a name change, otherwise the original project suffers from bug reports that don't relate to them at all. Flashbacks to all the arguments over Debian Iceweasel. So namewise, I definitely think we (wearing my AWS OSPO hat) should not be calling this pgjdbc.

On the other hand, I definitely agree that we should not be saying it is all our own work. I hope we're not saying that anywhere and will support feedback to fix any of that. That being core to why we (general permissive community) have attribution requirements in permissive licensing, to make sure that nobody passes off their project as being all their own work.

Do you have some proposed alternative language? (I don't mean that from "Please do my work for me" but just to help me understand your perspective)


PostgreSQL JDBC Driver - https://jdbc.postgresql.org/
The original PostgreSQL JDBC Driver is
Copyright (c) 1997, PostgreSQL Global Development Group
All rights reserved.
Copy link

Choose a reason for hiding this comment

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

The usual way in these things is to leave the original copyright notice at the top and then add

Partial Copyright (c) 2021 Amazon ...

second.

Copy link
Author

Choose a reason for hiding this comment

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

If I was forking a file, I'd agree. Original file's copyright first, then modifications after that; giving a hint to the history of the file.

With a project though, I like to see the project 'owner' first, and then other copyright after that. Helping to identify what the project is and helping to direct communication (be it happy or sad :) ) to the forked project owner instead of to the original project's community.

Just to explain my thinking :) If the Postgresql project would prefer it the other way, then happy to adjust.

Copy link
Contributor

Choose a reason for hiding this comment

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

@hyandell So I'm not quite sure why you would not fork the project?

So my challenge when I see the copyright the way it is written is that it appears that this new project is the copyright owner for the entire codebase. Because of the way the LICENSE file is referred to in all of the existing files you are now exerting copyright over all of the files which I see as being incorrect. I'm not sure how to resolve this at the moment but my understanding is that you own the copyright only on the files that you have added and then partial copyright on anything you have modified.

Copy link

@wieck wieck May 16, 2021

Choose a reason for hiding this comment

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

Henri,

neither Dave nor I can speak for the PostgreSQL project, even though I was for some 10 years a member of the PostgreSQL core team. If broader feedback and community input is desired, we should move this discussion to the appropriate mailing list.

Copy link
Author

Choose a reason for hiding this comment

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

@davecramer how would you expect a forked project to look? My concern with our current approach of a separate license file and third-party-license file is that it's not giving the PostgreSQL licensing enough kudos, so I looked to clarify by bringing them together. Typically I like a license file to cover the main project's core licensing, while any third-party-license filing is more ancillary, be it dependencies or separate contrib packages.

As you said, the copyright on the project is a mix of original PostgreSQL community licensing, and subsequent AWS community changes.

@wieck understood - very happy to have both of your feedback though. I should also point out I'm not a project member of this repo either, just a nosy OSPO team member :)

Copy link
Contributor

Choose a reason for hiding this comment

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

@hyandell I guess I would have expected you to actually fork it on github so that you could do pull requests from it.

Copy link
Author

@hyandell hyandell May 17, 2021

Choose a reason for hiding this comment

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

Ohh. GitHub-fork. I understand now. Sorry, I thought you were using a more generalized 'fork' meaning, such as 'has some code that's unlikely to be accepted upstream'. Which meant I got myself super confused.


Expand Down