Welcome to mirror list, hosted at ThFree Co, Russian Federation.

NotesImportTask.java « persistence « notes « owncloud « niedermann « it « java « main « src « app - github.com/stefan-niedermann/nextcloud-notes.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 38172b94d14097c58c94b196cd16c41f81d45720 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
package it.niedermann.owncloud.notes.persistence;

import android.content.Context;
import android.util.Log;

import androidx.annotation.NonNull;
import androidx.lifecycle.LiveData;
import androidx.lifecycle.MutableLiveData;

import com.nextcloud.android.sso.AccountImporter;
import com.nextcloud.android.sso.exceptions.NextcloudFilesAppAccountNotFoundException;

import java.util.concurrent.CountDownLatch;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

import it.niedermann.owncloud.notes.persistence.entity.Account;
import it.niedermann.owncloud.notes.persistence.sync.NotesAPI;
import it.niedermann.owncloud.notes.shared.model.IResponseCallback;
import it.niedermann.owncloud.notes.shared.model.ImportStatus;
import it.niedermann.owncloud.notes.shared.util.ApiVersionUtil;


public class NotesImportTask {

    private static final String TAG = NotesImportTask.class.getSimpleName();

    private final NotesAPI notesAPI;
    @NonNull
    private final NotesRepository repo;
    @NonNull
    private final Account localAccount;
    @NonNull
    private final ExecutorService executor;
    @NonNull
    private final ExecutorService fetchExecutor;

    NotesImportTask(@NonNull Context context, @NonNull NotesRepository repo, @NonNull Account localAccount, @NonNull ExecutorService executor, @NonNull ApiProvider apiProvider) throws NextcloudFilesAppAccountNotFoundException {
        this(context, repo, localAccount, executor, Executors.newFixedThreadPool(20), apiProvider);
    }

    private NotesImportTask(@NonNull Context context, @NonNull NotesRepository repo, @NonNull Account localAccount, @NonNull ExecutorService executor, @NonNull ExecutorService fetchExecutor, @NonNull ApiProvider apiProvider) throws NextcloudFilesAppAccountNotFoundException {
        this.repo = repo;
        this.localAccount = localAccount;
        this.executor = executor;
        this.fetchExecutor = fetchExecutor;
        this.notesAPI = apiProvider.getNotesAPI(context, AccountImporter.getSingleSignOnAccount(context, localAccount.getAccountName()), ApiVersionUtil.getPreferredApiVersion(localAccount.getApiVersion()));
    }

    public LiveData<ImportStatus> importNotes(@NonNull IResponseCallback<Void> callback) {
        final var status$ = new MutableLiveData<ImportStatus>();
        Log.i(TAG, "STARTING IMPORT");
        executor.submit(() -> {
            Log.i(TAG, "… Fetching notes IDs");
            final var status = new ImportStatus();
            try {
                final var remoteIds = notesAPI.getNotesIDs().blockingSingle();
                status.total = remoteIds.size();
                status$.postValue(status);
                Log.i(TAG, "… Total count: " + remoteIds.size());
                final var latch = new CountDownLatch(remoteIds.size());
                for (long id : remoteIds) {
                    fetchExecutor.submit(() -> {
                        try {
                            repo.addNote(localAccount.getId(), notesAPI.getNote(id).blockingSingle().getResponse());
                        } catch (Throwable t) {
                            Log.w(TAG, "Could not import note with remoteId " + id + ": " + t.getMessage());
                            status.warnings.add(t);
                        }
                        status.count++;
                        status$.postValue(status);
                        latch.countDown();
                    });
                }
                try {
                    latch.await();
                    Log.i(TAG, "IMPORT FINISHED");
                    callback.onSuccess(null);
                } catch (InterruptedException e) {
                    callback.onError(e);
                }
            } catch (Throwable t) {
                final Throwable cause = t.getCause();
                if (t.getClass() == RuntimeException.class && cause != null) {
                    Log.e(TAG, "Could not fetch list of note IDs: " + cause.getMessage());
                    callback.onError(cause);
                } else {
                    Log.e(TAG, "Could not fetch list of note IDs: " + t.getMessage());
                    callback.onError(t);
                }
            }
        });
        return status$;
    }
}