<table><tr><td style="">jgrulich created this revision.<br />Restricted Application added a project: Plasma.<br />Restricted Application added a subscriber: plasma-devel.
</td><a style="text-decoration: none; padding: 4px 8px; margin: 0 8px 8px; float: right; color: #464C5C; font-weight: bold; border-radius: 3px; background-color: #F7F7F9; background-image: linear-gradient(to bottom,#fff,#f1f0f1); display: inline-block; border: 1px solid rgba(71,87,120,.2);" href="https://phabricator.kde.org/D6298" rel="noreferrer">View Revision</a></tr></table><br /><div><strong>REVISION SUMMARY</strong><div><p>I've made few improvements which should help and make installation or update <br />
process with flatpak backend a bit better experience:</p>

<ol class="remarkup-list">
<li class="remarkup-list-item">Properly cancel flatpak transactions, it now calls proper g_cancellable to cancel running transactions in FlatpakTransactionJob</li>
</ol>

<ol class="remarkup-list" start="2">
<li class="remarkup-list-item">Pass FlatpakTransaction as a parent of FlatpakTransactionJob so it gets deleted together with parent</li>
</ol>

<ol class="remarkup-list" start="3">
<li class="remarkup-list-item">Make difference between finished transaction, whether it finished successfuly or finished with an error, with this when we finish a flatpak transaction we can update app metadata accordingly, because when the transaction fails, we shouldn't do that, because failed updates will be marked as installed instead of updatable and the user would think that the app has been updated even though they see an error</li>
</ol>

<ol class="remarkup-list" start="4">
<li class="remarkup-list-item">When installing an application which don't have required runtime installed we should care only about state of the application and not of the runtime. I.e imagine installing application requiring a runtime, it will start downloading both together, the app will be installed first and waiting for runtime to finish, but when the installation of runtime fails, we call transactionFinished(false) and that would cause the app marked as not installed, while only runtime failed, also we would set transaction status to DoneWithError status also ending up with up not being updated in FlatpakBackend</li>
</ol></div></div><br /><div><strong>REPOSITORY</strong><div><div>R134 Discover Software Store</div></div></div><br /><div><strong>BRANCH</strong><div><div>Plasma/5.10</div></div></div><br /><div><strong>REVISION DETAIL</strong><div><a href="https://phabricator.kde.org/D6298" rel="noreferrer">https://phabricator.kde.org/D6298</a></div></div><br /><div><strong>AFFECTED FILES</strong><div><div>libdiscover/Transaction/Transaction.h<br />
libdiscover/backends/FlatpakBackend/FlatpakTransaction.cpp<br />
libdiscover/backends/FlatpakBackend/FlatpakTransaction.h<br />
libdiscover/backends/FlatpakBackend/FlatpakTransactionJob.cpp<br />
libdiscover/backends/FlatpakBackend/FlatpakTransactionJob.h</div></div></div><br /><div><strong>To: </strong>jgrulich, apol<br /><strong>Cc: </strong>plasma-devel, ZrenBot, spstarr, progwolff, lesliezhai, ali-mohamed, jensreuterberg, abetts, sebas, apol, mart, lukas<br /></div>