-
Notifications
You must be signed in to change notification settings - Fork 63
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
Consider removing mongo-db-driver dependency #91
Comments
Previously https://github.com/go-mgo/mgo was an alternative, but it has been deprecated. I am not aware of any replacement. |
The driver package and the associated BSON implementation are maintained by MongoDB, Inc. I think it would be better to use the one instead of alternatives. That being said, the entire MongoDB driver is too much for what this package needs. It would be great if they can separate BSON from the MongoDB driver. Another alternative may be making BSON part separate from this package, but this wouldn't straightforward. |
I wonder if the MongoDB folks would be willing to separate out their BSON functionality into a different package. That way, strfmt and the Mongo driver packages could both prereq it as needed. |
I'm not in favor of using alternative packages except for the official ones. Unofficial implementations tend to bitrot as people move on, so to ensure compatibility it's safer to depend on the official package for longer term. The reason mgo got removed was for this exact reason. However if mongodb folks could split off bson or just even put a go.mod file in that directory we should be good. |
Quick update regarding separation of the bson package. There is a ticket in the MongoDB jira tracking this feature. |
This project is a dependency of our dependency. At one point it stopped working, because mongodb driver moved a tag which destroyed the checksums. This suprised us, because we are not using mongo db. I followed the trail here. Basically, yeah, it would be greatly appriciated if the BSON project split from Mongo DB driver. :) Also, thank you for your time and effort working on Go-OpenAPI projects. They work woderfully. |
I've also had a lot of issues with this dependency. Here is what I could do (@youyuanwu , @casualjim please advise):
Also this would break go-swagger, so here is the suggested update:
|
Not necessary. We can just depend on the bson module and get rid of the heavy dependency. We amongst others asked them to split bson off from the rest. I am definitely not in favor for any kind of breaking change. |
This PR should be enough to get people going again I think: #110 |
Another option instead of a different package is using build tags so that the MongoDB stuff is only included if you build with |
Yes I thought about this one too. This is a bit tedious for user, but apart from some extra documentation, this is indeed the simplest way to go. I can give this idea a try, so we may discuss on actual code |
@casualjim I've quickly materialized your idea with the build tag. I am not sure it really cuts the dependency: sure, it will not build this code, but the chain of dependencies is resolved like all build tags are resolved (exception: "build ignore"). Seems to me that this is not enough. |
Here is a quick sample for build tag solution: https://github.com/fredbi/strfmt/tree/feat/mongo-build-tag |
In #90, I reported a vulnerability that strfmt users have started to see reports of, due to the strfmt->mongo-db-driver->packr dependency chain. As soon as a new version of mongo-db-driver is available that bumps its packr dependency, we should change this project to use the newer mongo-db-driver version in order to avoid the vulnerability.
However, while looking for alternate ways to address the vulnerability, I noticed that the only real dependency that the strfmt project has on mongo-db-driver is its "bson" package. So, I was wondering about the feasibility of removing the mongo-db-driver dependency altogether. Is there perhaps an alternate implementation of the "bson" functionality that would suffice? Perhaps there's a way to extract out the mongo-db-driver "bson" package into its own module so that strfmt can depend on just that by itself?
Removing the mongo-db-driver dependency would also significantly reduce the dependency drag currently associated with the project.
The text was updated successfully, but these errors were encountered: