<div dir="ltr">Hello Mr. Matthias,<br><br>No worries about that email, but let me answer some of the questions. Currently, AppRecommender only works for Debian and Ubuntu distros because the data it uses to create an user profile is dependent on the .deb package format, specially on the control file of a debian package, since it uses info such as the package section, description and debtags. <br><br>About app-install-data, it is ancient indeed. AppRecommender was originally thought as an online project and used the application to provide screenshots of some application, but when I started working on it, we have decided to run it only locally and via terminal, because of some user privacy issues we would like to avoid, since the online approach required the user a list containing all of the installed packages to the server. So we are no longer using app-install-data on the project, but I just realized I have forgot to remove it from the Readme file, but I will fix this right away and thanks for pointing it out :)<br><br>Now, considering PackageKit, yes it makes sense that it would be difficult to make AppRecommender work on it, specially considering the fact that this application is not cross-platform. But the C/C++ library seems like a really good option. AppRecommender is currently a python application, but creating an C/C++ API for it would be a fun thing to do. I will speak with my mentors about this idea and I will answer you back once he answer it.<br><br>Thanks so much for the answer and support.<br><br>Best regards,<br>Lucas Moura</div><div class="gmail_extra"><br><div class="gmail_quote">On Tue, Apr 26, 2016 at 4:14 PM, Matthias Klumpp <span dir="ltr"><<a href="mailto:matthias@tenstral.net" target="_blank">matthias@tenstral.net</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span class="">2016-04-26 20:51 GMT+02:00 Lucas Moura <<a href="mailto:lucas.moura128@gmail.com">lucas.moura128@gmail.com</a>>:<br>
> Hello,<br>
><br>
> My name is Lucas Moura and I am Google Summer of Code Student working for<br>
> the Debian project. My summer project is related to AppRecommender, a Debian<br>
> package recommender system:<br>
><br>
> <a href="https://github.com/TCC-AppRecommender/AppRecommender" rel="noreferrer" target="_blank">https://github.com/TCC-AppRecommender/AppRecommender</a><br>
><br>
> This application works by creating an user profile based on the user<br>
> installed packages, this profile is basically the most significant terms on<br>
> all user packages. With this profile built, AppRecommender uses Xapian to<br>
> query for Debian packages and display the closest ones with the query.<br>
<br>
</span>Hi there!<br>
First of all, sorry for not-replying to your initial mail you sent<br>
about a month ago.... I read it on a train and then it completely<br>
vanished from my head afterwards, since there was so much stuff going<br>
on... This was my fault, but next time feel free to send a reminder<br>
email in such cases :-)<br>
Anyway, I'm glad you got into this year's GSoC!<br>
<span class=""><br>
> Currently, this application can only be used via terminal access. However,<br>
> my gsoc project is to change that, and allow AppRecommender to be integrated<br>
> into graphical package managers:<br>
><br>
> <a href="https://wiki.debian.org/SummerOfCode2016/StudentApplications/LucasMoura" rel="noreferrer" target="_blank">https://wiki.debian.org/SummerOfCode2016/StudentApplications/LucasMoura</a><br>
><br>
> I originally thought about integrating it with PackageKit, since this would<br>
> allow some famous graphical package managers to actually show the<br>
> recommendations, such as Gnome-software.<br>
><br>
> However, since AppRecommender only works for Debian and Ubuntu distros, I<br>
> would like to ask what would be the best approach to integrate<br>
> AppRecommender with PackageKit and the opinion of the application<br>
> maintainers with this idea.<br>
<br>
</span>First of all, that tool should get off app-install-data and use<br>
AppStream instead ;-) The app-install-data stuff is ancient and is no<br>
longer maintained or even updated, while AppStream is the new shiny<br>
thing (I am obviously biased as AppStream maintainer, but you can<br>
trust me on that).<br>
Is there *any* reason why this just works on Debian/Ubuntu? I haven't<br>
looked at the code yet, but I can't think of any reason at time why<br>
this feature should be restricted to the Debian world.<br>
<br>
Adding it to PackageKit is something which will be very hard, since PK<br>
has a different, package-centric scope and I am not sure if Richard<br>
wants new API added to the core for this feature (which you would<br>
highly likely need, since no plugins are supported anymore).<br>
<br>
Adding a feature like this to the AppStream libraries, however, would<br>
be most welcome! We even discussed about this at the GNOME Software<br>
hackfest. The problem there is that we would need this feature as a<br>
nice C library, or need it to be added to one of the existing C<br>
libraries.<br>
Richard is maintaining libappstream-glib[1], which is mainly used by<br>
GNOME Software and contains lots of helper routines GS needs. I<br>
maintain libappstream, which is used by some web-stores, Elementary<br>
and KDE for their AppStream stuff. The libappstream library also uses<br>
a Xapian database internally.<br>
I could definitely imagine adding API to libappstream to support a<br>
"suggest me apps I would like to use" feature, but a precondition<br>
would be that this feature is available on more distributions, ideally<br>
all.<br>
<br>
As a last option, you could always create your own C/C++ library, and<br>
we could add a vendor-specific plugin for this feature to GNOME<br>
Software and KDE Discover.<br>
<br>
I'll read a bit more about your project, at time I can't make any<br>
recommendation on what is best (I can only say for sure that PK is<br>
likely not the right place for this).<br>
<br>
Cheers,<br>
    Matthias<br>
<br>
<br>
[1]: <a href="https://github.com/hughsie/appstream-glib" rel="noreferrer" target="_blank">https://github.com/hughsie/appstream-glib</a><br>
[2]: <a href="https://github.com/ximion/appstream" rel="noreferrer" target="_blank">https://github.com/ximion/appstream</a><br>
<span class="HOEnZb"><font color="#888888"><br>
--<br>
Debian Developer | Freedesktop-Developer<br>
I welcome VSRE emails. See <a href="http://vsre.info/" rel="noreferrer" target="_blank">http://vsre.info/</a><br>
_______________________________________________<br>
PackageKit mailing list<br>
<a href="mailto:PackageKit@lists.freedesktop.org">PackageKit@lists.freedesktop.org</a><br>
<a href="https://lists.freedesktop.org/mailman/listinfo/packagekit" rel="noreferrer" target="_blank">https://lists.freedesktop.org/mailman/listinfo/packagekit</a><br>
</font></span></blockquote></div><br></div>