3828 Commits

Author SHA1 Message Date
Daniel Martí
a0b56b23ca gradle: bump plugin and wrapper version
Since the new plugin requires 2.14.1 for security reasons.

Also re-run `gradle wrapper` to update the scripts and the jar.
2016-10-25 11:54:40 +03:30
Daniel Martí
3a1c6612c0 CI: bump image 2016-10-25 11:54:40 +03:30
Daniel Martí
f26768a77c Bump to 0.101-alpha5 2016-10-25 11:54:40 +03:30
F-Droid Translatebot
6b89201d93 Pull translation updates from Weblate
Translators:

Kristjan Räts    Estonian
Marko            Finnish
tacsipacsi       Hungarian
2016-10-25 11:54:40 +03:30
Peter Serwylo
c76c920397 Move code causing verify error into separate helper class
I'm not 100% sure on how the `@TargetApi` and `VerifyError` work
together. However it is something along the lines of:
 * Class loader needs `CleanCacheService`.
 * At this point, it loads the bytecode for that class and verifies
   that it all makes sense.
 * The bytecode within the method targeted at API 21 is not understood
   by earlier APIs, because the entire `Os` class was introduced in 21.
 * By putting it into a different class, that class is only loaded
   at runtime on devices with API of 21 or higher.

Previously, `@TargetApi` + the relevant guard condition to check
the build version at runtime suffices to prevent this. However it seems
that if the entire class does not even exist on earlier APIs, then it
is no longer good enough.
2016-10-25 11:54:40 +03:30
Peter Serwylo
c02cc41c2f Ensure that description is not null when parsing index.
At time of writing (and for some time before), fdroidserver has forced
a description of "No description available" for apps which don't have
descriptions at all:

 * https://gitlab.com/fdroid/fdroidserver/blob/0.6.0/fdroidserver/metadata.py#L876

However, if the description is not set for whatever reason, it should not
crash the client.
2016-10-25 11:54:40 +03:30
Hans-Christoph Steiner
fe35343a36 document processes in CleanCacheService
This breaks out each separate process into its own utility method, and adds
javadoc to describe them.
2016-10-25 11:54:40 +03:30
Hans-Christoph Steiner
3944747766 delete cached icons that have not been accessed in over a year
The icon files are downloaded for each version of the app.  Over time, old
versions will pile up.  This cleans out the ones that have not been used in
over a year.

On < android-21, this will delete icons that were downloaded over a year
ago even if they are still in use because it is only possible to check
mtime, not atime.
2016-10-25 11:54:40 +03:30
Hans-Christoph Steiner
d1eb5b5fb3 avoid deleting cached files while they are being used
If CleanCacheService runs while an APK is being installed, it should not
delete the APK that is in the process of being installed.  This does that
by only deleting those files if they are older than an hour. Same goes for
the index files.

#738
2016-10-25 11:54:40 +03:30
Hans-Christoph Steiner
6046af5328 fix bug where files were never deleted from cache
It was passing the wrong time value in the recursion, which made for a
really old "olderThan" time.  This also then flipped the logic on the
next round through the recursion, causing files to be deleted even if
"Keep Cache Time" was set to "Forever".

closes #719
closes #736
2016-10-25 11:54:40 +03:30
Hans-Christoph Steiner
aa39d7bc7f if the "Keep Cache Time" pref changes, reschedule CleanCacheService
Before, CleanCacheService was only scheduled at app start for once a day.
If the user selects a time less than a day, then CleanCacheService should
run more frequently.

closes #719
2016-10-25 11:54:40 +03:30
Hans-Christoph Steiner
bb0e84c509 clearOldFiles() test must run on the emulator
It seems that Robolectric does not implement android.system.Os so the
atime checking code cannot be tested there.  Works fine on the emulator.
2016-10-25 11:54:40 +03:30
Hans-Christoph Steiner
db6214dcc5 switch "Keep Cache Time" units to milliseconds
Both the Android task scheduler and the Java File operations want millis.
For "Forever", Long.MAX_VALUE is used.
2016-10-25 11:54:40 +03:30
Hans-Christoph Steiner
91b4072c1a move clearOldFiles() to CleanCacheService to be used on other files
Now that there is the ability to remove files based on last access time, it
makes sense to use this on all cached files, including icons, etc.
2016-10-25 11:54:40 +03:30
Hans-Christoph Steiner
5911e34b43 use access time to remove old cache files >= android-21
In android-21, they exposed the formerly internal method for getting stat
structs of files.  From that, we can get the last access time, which is a
much better way to determine which files to delete rather than last
modified time.

closes #644
2016-10-25 11:54:40 +03:30
Hans-Christoph Steiner
926c3a6c01 set default for "keep cached apps"
There was no default set in the XML, so it just showed the default as blank

closes #719
2016-10-25 11:54:40 +03:30
Daniel Martí
4d67298f38 values-et: fix format errors from weblate 2016-10-25 11:54:40 +03:30
F-Droid Translatebot
2a1fba445f Pull translation updates from Weblate
Translators:

Danial Behzadi    Persian
Kristjan Räts     Estonian
tacsipacsi        Hungarian
2016-10-25 11:54:40 +03:30
Hans-Christoph Steiner
fe7e299df9 Utils.getBinaryHash() should not catch exceptions
By catching the exception here and returning null, the problem is then
passed on further down the line where it is harder to debug.  The hash is
required wherever this method is called, so this should fail immediately.

#699
2016-10-25 11:52:49 +03:30
Hans-Christoph Steiner
d174ea8d3e standardize on lowercase SHA-256 hashes
fdroidserver produces lowercase hashes, so its easiest to just mimic
that.  This makes hash comparisons easy.
2016-10-25 11:52:49 +03:30
Hans-Christoph Steiner
bc19a72de5 standardize priv-app install name as FDroidPrivilegedExtension
This syncs up the name the root install method uses with what is used by
the ROM integration and update.zip.  It also uses the full name for
consistency, with non-alpha and spaces removed following priv-app naming
conventions.

https://gitlab.com/fdroid/privileged-extension/merge_requests/3
https://gitlab.com/fdroid/privileged-extension/merge_requests/5
2016-10-25 11:52:49 +03:30
Hans-Christoph Steiner
9eaf601f61 remove scripts for creating update.zip, moved to priv-ext
https://gitlab.com/fdroid/privileged-extension/merge_requests/5
2016-10-25 11:52:49 +03:30
Hans-Christoph Steiner
f55e5480cf gitlab-ci: another gradle bit to delete for good caching
recommended here, seems like it can't hurt:
https://docs.travis-ci.com/user/languages/java/#Caching
2016-10-25 11:52:49 +03:30
Peter Serwylo
b50321515a Remove dead code
AS picked up that the statement is always false, so the body of the if is
never executed. This is indeed the case, because the constructor assigns
the object which is being checked for null.
2016-10-25 11:52:49 +03:30
Peter Serwylo
d60a7311a6 Close cursors which previously were left dangling. 2016-10-25 11:52:49 +03:30
Peter Serwylo
ee848e6c14 Clean up switch statements with only a single option. 2016-10-25 11:52:49 +03:30
Peter Serwylo
ffd04dd777 Remove unused code.
The code only existed so that it could be used in a test. Subsequently,
a further test was written to test this code (used by the first test).
Since none of the code is actually used in the app, it has been removed.
2016-10-25 11:52:49 +03:30
Peter Serwylo
237be6752d Renamed AppTable to AppMetadataTable
See #511 for details. This is in prepration for having an even more normalized
`fdroid_package` table. That table will be the authoritative reference of what
"packages" are known about in the client. The "app" table (now thought of as "app metadata") will
be specific to each repository which provides different metadata about that app.
2016-10-25 11:52:49 +03:30
Dominik Schürmann
edb11a6778 Tests for ApkVerifier 2016-10-25 11:52:49 +03:30
numb95
37124bce80 release 0.2 2016-10-25 10:37:55 +03:30
numb95
7f2d62cea6 fix merges in persion strings 2016-10-18 15:24:11 +03:30
Amir Hossein Goodarzi (Numb)
61b96c9093 fix strings fa 2016-08-15 15:19:10 +04:30
Amir Hossein Goodarzi (Numb)
26cfdb53b2 color and name editing 2016-08-15 15:14:24 +04:30
Danial Behzadi
1e8d7655bc Update AndroidManifest.xml
rebrand fdroid to belmarket
2016-08-10 15:36:49 +00:00
Amir Hossein Goodarzi (Numb)
8a375357ed change logo 2016-08-10 18:42:30 +04:30
Amir Hossein Goodarzi (Numb)
05be26d507 fix names and color 2016-08-10 18:31:48 +04:30
Hans-Christoph Steiner
2837a235b4 Merge branch 'fix-511--move-user-specified-data-to-separate-table' into 'master'
Move user specified data to separate table

Right now, the "Ignore update for version X" and "Ignore all updates for this app" are stored in `fdroid_app`. This means that if a repo is disabled then re-enabled, these preferences are lost. This MR separates out the user specified metadata from the metadata provided by the repository, such that one can change without affecting the other.

For convenience sake, this drops the `fdroid_app` and `fdroid_apk` tables rather than migrating them, and then sets a flag in preferences that forces F-Droid to do an index update when started. This is done _after_ migrating already existing user preferences out of `fdroid_app` and into `fdroid_appPrefs`.

See merge request !372
2016-08-08 08:59:40 +00:00
Peter Serwylo
203bcda695 Cleanup in response to CR comments 2016-08-04 21:35:46 +10:00
Peter Serwylo
bb88be9403 Further tests for AppPrefs.equals() which is used by AppDetails. 2016-08-04 11:15:42 +10:00
Peter Serwylo
9637de5e4c Make ignored app tests actually test code in use.
The test was using a `findIgnored` method in `AppProvider`, which only
existed for the purpose of testing. The test has been changed to instead
check for apps which would end up in the "can update" list (which is really
where the "ignored" apps are useful).
2016-08-04 09:53:25 +10:00
Peter Serwylo
125acd6276 Migrate app preferences to different table.
In the process, realised that using appId as a foreign key is worse than
packageName, because appId can get removed and added again, but it will
be different when the same app is inserted a second time. In order to
maintain the association of which apps have preferences stored against
them, they need to be stored against something with a bit more semantic
meaning. Thus, join onto package name instead.
db-version/60
2016-08-04 09:53:25 +10:00
Peter Serwylo
4b5481b8f2 Appese checkstyle + pmd 2016-08-04 09:53:25 +10:00
Peter Serwylo
5e263c0e0f Use "COALESCE(x, 0)" instead of "x = 0 OR x IS NULL"
This is a more concise syntax to say the same thing, and avoids an
OR clause in the where - which is often the cause of slowness in
many queries. Not sure if it was problematic in these cases, however
this COALESCE syntax is still more consise.
2016-08-04 09:53:25 +10:00
Peter Serwylo
004c86bc42 Notify content observers correctly 2016-08-04 09:53:25 +10:00
Peter Serwylo
903048ffe4 Add covering indexes for main queries.
With no indexes at all, a join between X and Y tables would require a full
table scan of Y for each row in X. With an index on the relevant field in
Y, it would require an index lookup on the join field in Y for each row in
X, which contains a pointer to the row of interest in Y. This row is then
looked up and the relevant value extracted. By using a covering index (one
which includes all fields required to satisfy the query, with the first field
being the one which is looked up in the join), then once the index has been
searched, there is no need to then go to table Y because all the relevant
data is already in the index.

This offers a marginal performance improvement.
2016-08-04 09:53:25 +10:00
Peter Serwylo
3e3af3bbf3 Completely removed preferences from app table. 2016-08-04 09:53:25 +10:00
Peter Serwylo
d47967e03d Added new table to store user preferences.
Haven't yet migrated data from the old location in the app table yet.
2016-08-04 09:53:25 +10:00
Daniel Martí
3c5f8756f4 Bump to 0.101-alpha4 v0.101-alpha4 2016-08-02 11:25:30 +02:00
Daniel Martí
ba51536b88 Merge branch 'move-priv-extension' into 'master'
Move Privileged Extension to separate repo

Removes all files of the Privileged Extension app except the aidl files.

See merge request !371
2016-08-02 09:24:31 +00:00
Dominik Schürmann
0fd1d5ae4c Move Privileged Extension to separate repo 2016-08-01 23:02:57 +02:00