Jump to content

GSoC/2018/StatusReports/AbhijeetSharma: Difference between revisions

From KDE Community Wiki
m Added a shorter link for proposal
Added More Contact
 
(10 intermediate revisions by the same user not shown)
Line 1: Line 1:
==Discover: fwupd integration==
==Discover: fwupd integration==


Currently, Discover does most of the general job required for a typical plasma user but it lacks firmware upgrade on devices. This project will integrate firmware upgrade through fwupd in discover. After addition of this feature, Discover will be able to upgrade the firmware of devices attached to the system (via USB/SOC) on Demand.
Currently, Discover does most of the general job required for a typical plasma user but it lacks firmware upgrade on devices. This project will integrate the firmware upgrade through fwupd in discover. After addition of this feature, Discover will be able to upgrade the firmware of devices attached to the system (via USB/SOC) on Demand.


'''Mentors:''' David Edmundson Aleix Pol
'''Mentors:''' David Edmundson Aleix Pol
Line 20: Line 20:


During this period I started by adding a new backend i.e FwupdBackend from a skeleton backend i.e DummyBackend. After adding the skeleton, I had to link the libfwupd with discover via CMake. For Linking, I added a FindLIBFWUPD.cmake so that cmake could find the required libraries. After successfully linking these libraries I proceeded with making the constructor and destructor for making the fwupdclient object to talk to the fwupd daemon. After this, I proceeded with displaying the attached devices discovered via fwupd for checking that client object is able to talk to the fwupd daemon successfully.
During this period I started by adding a new backend i.e FwupdBackend from a skeleton backend i.e DummyBackend. After adding the skeleton, I had to link the libfwupd with discover via CMake. For Linking, I added a FindLIBFWUPD.cmake so that cmake could find the required libraries. After successfully linking these libraries I proceeded with making the constructor and destructor for making the fwupdclient object to talk to the fwupd daemon. After this, I proceeded with displaying the attached devices discovered via fwupd for checking that client object is able to talk to the fwupd daemon successfully.
Discover Displaying attached devices discovered via fwupd daemon
[[File:discover-fwupd-display-devices.png]]
===Coding Period Phase - II (June 11th to July 9th)===
During this period I have implemented the following things:
* Firmware Updates Section is Now Cleaner: I have removed the unnecessary things like review backend, and screenshots which are not applicable for these updates. Also now the icons are decided based on the type of device.
[[File:Discover-fwupd-Install-app.png]]
* Refresh Remotes is now implemented: Now the metadata of enabled remotes are updating. Currently, the frequency is set to 30 days. These refreshing is like apt-get updates in Ubuntu based systems but for fwupd. The metadata is downloaded into cache directory of discover and then these files are sent to fwupd-daemon. In the attached screenshot you can see the downloaded files in the cache directory. The checksum is downloaded first and if it’s unchanged then only the new file is downloaded.
[[File:Discover-fwupd-Remotes-Cache.png]]
* Updates are shown on the updates page: The firmware updates are now shown in the update page of discover with all other updates. These updates are categorizing in “System-Updates”. These changes can be seen in the attached screenshot. (Missing string, please see the note!)
* Added Remotes Setting and EULA: Now the remotes can be enabled and disabled in the setting menu of the discover. If the user is enabling the remote then, he has to accept the EULA provided by LVFS. Additionally, the user also requires the root password to enable/disable it. I have also removed the unnecessary options like adding a new remote. Also, for now, I have disabled deleting the remotes.
[[File:Discover-fwupd-Show-Eula.png]]
[[File:Discover-fwupd-polkit.png]]
[[File:Discover-fwupd-Remote-Removal-Not-Allowed.png ]]
* Testing Installs on Real Devices: Since I haven’t received the device,  I still have to wait to test the code. The code for install is written, but it needs regress testing and improvement.
Note: The Updates shown in the above screenshots are purposely put to visualize the code! I don’t have a device which supports firmware updates by LVFS
===Coding Period Phase - III (July 15th to Aug 6th)===
In this period, I majorly improved the code and got it merged into the master branch of Discover Software Center. The Phabricator request for the merge is (https://phabricator.kde.org/D14050). It Took a lot of changes for getting it merged in master, Thanks to Aleix and plasma-devel team for pointing out mistakes in the code. After getting it merged, The CI build started to fail, the main reason behind that was some error in findLIBFWUPD.cmake file and dependency issue in the CI system. I was amazed, with the power of CI as it caught a genuine mistake in the code. After fixing that, I added the request for installing the fwupd dependency on the CI system (https://phabricator.kde.org/T9305), I violated some community rule, but finally it got fixed thanks to bcooksley, (link: https://phabricator.kde.org/R857:1b0c2d39907a90bf6854fffafdab3d461fe8e69e), also thanks to adridg for pointing out the issue in my License in the cmake file, I fixed that in the (commit: 03aeb5ba2077c344b5de38ec37858a3603b07733) with some other fixes.
==Master Commits==
*[https://cgit.kde.org/discover.git/commit/?id=a30850900bbf9487f08bd43d988267e2ec034fd0 Fwupd-Integration Merge Commit]
*[https://cgit.kde.org/discover.git/commit/?id=a55b13c3f3a5ba4ab081dbf5f0493d35a39a743c Fix Error in CMake to stop CI build fails]
*[https://cgit.kde.org/discover.git/commit/?id=03aeb5ba2077c344b5de38ec37858a3603b07733 Fwupd-Backend Spaces fix and variable uniformity]
*[https://cgit.kde.org/discover.git/commit/?id=f804580adf566cf49a9267c19588159f27b5a745 Fwupd Backend Fwupd-Backend Fix, size, icon information, and cover one corner case]


==Development Branch==
==Development Branch==
*[https://cgit.kde.org/discover.git/log/?h=fwupd-integration Fwupd Integration]
*[https://cgit.kde.org/discover.git/log/?h=fwupd-integration Fwupd Integration]
==Bugs Fixed==
*[https://bugs.kde.org/show_bug.cgi?id=354841 Provide support for fwupd]
*[https://bugs.kde.org/show_bug.cgi?id=397377 Implement Version Checker]
*[https://bugs.kde.org/show_bug.cgi?id=397378 Reduce fwupd library version constraint]


==Important Links==
==Important Links==
===Discussion Links===
*[https://groups.google.com/forum/#!topic/fwupd/TIjwDANwy4w fwupd discussion forum] I recently posted on fwupd discussion forum regarding adding a virtual device to simulate fwupd!


===GSoC Proposal Link===
===GSoC Proposal Link===
Line 30: Line 79:


===Blog Posts===
===Blog Posts===
*[https://blog.abhijeet2096.me/index.php/2018/04/29/gsoc-18-fwupd-integration/  Week-1]
*[https://blog.abhijeet2096.me/index.php/2018/04/29/gsoc-18-fwupd-integration/  Blog-1]
*[https://blog.abhijeet2096.me/index.php/2018/06/10/gsoc-fwupd-integration-in-kde-discover-phase-i/ Blog-2]
*[https://blog.abhijeet2096.me/index.php/2018/07/07/gsoc-fwupd-integration-in-kde-discover-phase-ii/ Blog-3]
*[https://blog.abhijeet2096.me/index.php/2018/08/08/gsoc-fwupd-integration-in-kde-discover-phase-iii/ Blog-4]
 
===Youtube Presentation===
*[https://www.youtube.com/watch?v=Zs4xg0_Wqq0 Fwupd-Integration in Plasma Discover | Akademy Presentation]


==Contact==
==Contact==


'''Email:''' [email protected]
'''IRC:''' SharmaJiKaBeta , SharmaJiKaBeta_M
'''IRC:''' SharmaJiKaBeta , SharmaJiKaBeta_M
'''Github:''' abhijeet2096
 
'''GITHUB:''' abhijeet2096
 
'''WEBSITE:''' https://abhijeet2096.me

Latest revision as of 15:13, 21 August 2018

Discover: fwupd integration

Currently, Discover does most of the general job required for a typical plasma user but it lacks firmware upgrade on devices. This project will integrate the firmware upgrade through fwupd in discover. After addition of this feature, Discover will be able to upgrade the firmware of devices attached to the system (via USB/SOC) on Demand.

Mentors: David Edmundson Aleix Pol

Deliverables

  • On demand firmware upgrades via fwupd from Discover.
  • Notification Support on New firmware updates.
  • Setting UI for new firmware upgrades as per discussion with Discover Team.

Work Report

Community Bonding Period

During the community bonding period, I started with understanding the code base of discover. I found the way to add this functionality of Integrating fwupd via a new Backend i.e FwupdBackend. I then discussed this with my mentor Aleix and I started Working on this new backend. During this period we also discussed ways of communication and finally landed on emails with occasional video calls via opentok.

Coding Period Phase - I (May 14th to June 10th)

During this period I started by adding a new backend i.e FwupdBackend from a skeleton backend i.e DummyBackend. After adding the skeleton, I had to link the libfwupd with discover via CMake. For Linking, I added a FindLIBFWUPD.cmake so that cmake could find the required libraries. After successfully linking these libraries I proceeded with making the constructor and destructor for making the fwupdclient object to talk to the fwupd daemon. After this, I proceeded with displaying the attached devices discovered via fwupd for checking that client object is able to talk to the fwupd daemon successfully.

Discover Displaying attached devices discovered via fwupd daemon

Coding Period Phase - II (June 11th to July 9th)

During this period I have implemented the following things:

  • Firmware Updates Section is Now Cleaner: I have removed the unnecessary things like review backend, and screenshots which are not applicable for these updates. Also now the icons are decided based on the type of device.

  • Refresh Remotes is now implemented: Now the metadata of enabled remotes are updating. Currently, the frequency is set to 30 days. These refreshing is like apt-get updates in Ubuntu based systems but for fwupd. The metadata is downloaded into cache directory of discover and then these files are sent to fwupd-daemon. In the attached screenshot you can see the downloaded files in the cache directory. The checksum is downloaded first and if it’s unchanged then only the new file is downloaded.

  • Updates are shown on the updates page: The firmware updates are now shown in the update page of discover with all other updates. These updates are categorizing in “System-Updates”. These changes can be seen in the attached screenshot. (Missing string, please see the note!)
  • Added Remotes Setting and EULA: Now the remotes can be enabled and disabled in the setting menu of the discover. If the user is enabling the remote then, he has to accept the EULA provided by LVFS. Additionally, the user also requires the root password to enable/disable it. I have also removed the unnecessary options like adding a new remote. Also, for now, I have disabled deleting the remotes.

  • Testing Installs on Real Devices: Since I haven’t received the device, I still have to wait to test the code. The code for install is written, but it needs regress testing and improvement.


Note: The Updates shown in the above screenshots are purposely put to visualize the code! I don’t have a device which supports firmware updates by LVFS

Coding Period Phase - III (July 15th to Aug 6th)

In this period, I majorly improved the code and got it merged into the master branch of Discover Software Center. The Phabricator request for the merge is (https://phabricator.kde.org/D14050). It Took a lot of changes for getting it merged in master, Thanks to Aleix and plasma-devel team for pointing out mistakes in the code. After getting it merged, The CI build started to fail, the main reason behind that was some error in findLIBFWUPD.cmake file and dependency issue in the CI system. I was amazed, with the power of CI as it caught a genuine mistake in the code. After fixing that, I added the request for installing the fwupd dependency on the CI system (https://phabricator.kde.org/T9305), I violated some community rule, but finally it got fixed thanks to bcooksley, (link: https://phabricator.kde.org/R857:1b0c2d39907a90bf6854fffafdab3d461fe8e69e), also thanks to adridg for pointing out the issue in my License in the cmake file, I fixed that in the (commit: 03aeb5ba2077c344b5de38ec37858a3603b07733) with some other fixes.

Master Commits

Development Branch

Bugs Fixed

Important Links

Discussion Links

  • fwupd discussion forum I recently posted on fwupd discussion forum regarding adding a virtual device to simulate fwupd!

GSoC Proposal Link

Blog Posts

Youtube Presentation

Contact

IRC: SharmaJiKaBeta , SharmaJiKaBeta_M

GITHUB: abhijeet2096

WEBSITE: https://abhijeet2096.me