-
-
Notifications
You must be signed in to change notification settings - Fork 465
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
Non-FOSS in F-Droid build - io.objectbox:objectbox-gradle-plugin #3091
Comments
hi @kelson42 , If we are about to remove objectbox as database then we might need to switch core database like SQLite or room database. There is also new database exits called RealM. this will require lots of refracting of code. |
If you're looking for an alternative, I've considered
And ended up with SQLDelight. All commits related to this can be found in LeoColman/Petals@b00f1e4...3.0.2 I tried to keep the history as clean and clear as possible to facilitate migration for others. |
@licaon-kter is that the reason why F-Droid has basically removed all the recent versions of kiwix from F-Droid? I see now that version 2.4 in place of 3.6;is delivered. If yes, i can only say that suchmove without temporising and informing is really problematic and hardly acceptable as fair. |
@MohitMaliFtechiz Îm not in favour of removing objectbox. Not as long as Indon’t fully understand the problem. I don’t understand the rational why part of the compilation script is closed source. |
@kelson42 not sure what's unclear, I've informed you and removed tainted versions so users don't install non-FOSS apps. |
@licaon-kter I have not been informed that you will removed all kiwix versions since years, back to a super old version. This move is anyway unfear, after these has been accepted during years. You basically come back on your own decision without giving time to us to find a situation, so we are basically in a hard and urgent situation because of your lack of ability to enforce your own rules. Finaly, this is wrong to say that the app is not FOSS because kiwix compilation relies on non FOSS software to compile; if you follow this logic, any software compiled on windows with microsoft cl.exe won't be free, which is non-sense. So, I really wonder if I'm missing one our two important points and I'm OK to revise my assessment of the situation if necessary... but for the moment I can only re-iterate my strong disagreement and disappointment of what is currently going one at F-Droid, even the Play store is more correct: at least when thy change the rules, this is not retroactive on already published apps! |
You did read objectbox/objectbox-java#560 , yes?
Also, at the moment, what's the issue with the current version available? F-Droid does not retroactively uninstall the app from users devices, those still work. /LE: see my post below |
The F-Droid policy is clear: only FOSS Devs choose what libs they use, right? Devs check libs licenses, yes? Devs check licenses of dependencies of said libs, we hope. Oh, this did not happen? This does not happen regularly? Yes, and we deal with the flack from both sides, users and devs, just scroll https://gitlab.com/fdroid/fdroidserver/-/issues/1004 |
Who says that? Sorry I can not see the source of your citation. To the contrary I read objectbox/objectbox-java#560 (comment) which stated exactly the contrary. |
We did have this discussion over on Nonononoki/Hendroid#70 The plugin is proprietary, and if you skip it you'll need to download a proprietary library. I've opened both objectbox/objectbox-java#1102 and objectbox/objectbox-java#1100, which was outright closed. Quoting objectbox/objectbox-java#1100 (comment)
|
Me, but I'm wrong, mixed issues in my head. Sorry. Anyway, the issue still stands. It's like google play services is needed at compile time, same idea, not acceptable. |
I have no problem to admit there is an issue and F-Droid is legitimate to regulate things like they/you want. We are all FOSS supporters and doers and we know why this is important that as much as possible software pieces are FOSS. Regarding the F-Droid regulation to forbid non-FOSS in the toolchain, I'm not sure to fully understand the rationals behind them. But I would be really glad to hear them, just out of curiosity. My critic is how to handle the situation. Now that we agree that F-Droid does not distribute non-FOSS softwares because of this problem, can we agree to continue to distribute version 3.6.0 of Kiwix? On our side, we would work to fix the problem in 3.7.0. Like you can see, if Objectbox does not free their plugin, this is going to be serious work for us. |
I don't see a reason to distribute it if not-FOSS. If you want to avoid F-Droid distributing the older version in the mean time, I guess we can disable all versions until 3.7.0 is out. |
We've discussed an upgrade path too, but that is done under specific rules and timing: https://gitlab.com/fdroid/fdroiddata/-/issues/2776 |
This is exactly where you mix things IMO, beetween build dependences and runtime dependences. You only distribute the runtime, and this is perfectly FOSS. What is none FOSS here are the build dependences which you run once in compilation farm, but that does not impact end users because none of this is included in the APK. You don't have answered about then constraints F-Droid has on the build toolchain. I have read the doc and I don't have seen something telling that build toolchain should be FOSS as well. It's only written that the software itself should be free software. I strongly recommend to clarify that point |
@LeoColman Thank you very much for your inputs. It seems we share the same lot. For the moment, I just try to understand fully the problem and see how to make damage control. I was angry after the play store and now after F-Droid, which is far more painful for me. Nice start in the WE! |
https://f-droid.org/en/docs/Inclusion_Policy/
etc. Also note that everything mentioned there is FOSS, either if F-Droid builds it, or Debian, or it's a maven repo or it's pulled from upstream. |
@MohitMaliFtechiz @gouri-panda if we should consider an alternative to objectbox. Which of the alternatives proposed by @LeoColman would fit the best for us? And why? |
@kelson42 We should consider Room for our database. Google officially recommends this.
According to the official documentation
|
@LeoColman @licaon-kter @gouri-panda Is Room FOSS?! Pretty unclear to me. |
@kelson42 I don't think we should worry about license here. It comes with Android SDK package. I think we are good to go. |
@gouri-panda Firebase is part of the SDK as well right? |
@kelson42 Yes, but it's hosting service for database, content and authentication etc. |
Firebase is forbidden by F-Droid... so we should always be careful about licenses. |
Honestly, I don't know much about licenses. |
https://mvnrepository.com/artifact/androidx.room/room-runtime/2.4.3 looks fine Firebase (except like 1 lib) is not FOSS licensed afaik. And if it is then it depends on other Google proprietary lib like GMS |
hi @kelson42 , I also vote for ROOM db since its google official now. |
F-Droid's policies on free software come from Free Software Foundation, Open Source Initiative, Debian, etc. They have clearly defined what free software is, so we don't need to. (In fact, F-Droid is a bit looser than all of those, we currently allow non-free assets, though that might change). An easy way to think about what free software is: can the user customize it using only free software? If the user needs to use non-free software to build the source code, then the user does not have the freedom to modify the software in any way they want to. They cannot change the proprietary build tool.
Firebase is not forbidden by F-Droid, non-free software is. If Firefbase is free software, then it is allowed.
F-Droid did not make this policy, this is the definition of free software followed by RedHat, Ubuntu, FSF, FSFE, OSI, Debian, etc. etc. Here's a good post on that topic: |
Superseeded by #3101 |
ref:
kiwix-android/buildSrc/src/main/kotlin/Libs.kt
Line 216 in 754252d
Ref: objectbox/objectbox-java#560
Ref: https://gitlab.com/fdroid/fdroidserver/-/merge_requests/1150
/LE: At least since 2.5.0
The text was updated successfully, but these errors were encountered: