Simple email application for Android. Original source code: https://framagit.org/dystopia-project/simple-email
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

68 lines
2.2 KiB

  1. package eu.faircode.email;
  2. /*
  3. This file is part of FairEmail.
  4. FairEmail is free software: you can redistribute it and/or modify
  5. it under the terms of the GNU General Public License as published by
  6. the Free Software Foundation, either version 3 of the License, or
  7. (at your option) any later version.
  8. NetGuard is distributed in the hope that it will be useful,
  9. but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. GNU General Public License for more details.
  12. You should have received a copy of the GNU General Public License
  13. along with NetGuard. If not, see <http://www.gnu.org/licenses/>.
  14. Copyright 2018 by Marcel Bokhorst (M66B)
  15. */
  16. import java.util.List;
  17. import androidx.lifecycle.LiveData;
  18. import androidx.room.Dao;
  19. import androidx.room.Insert;
  20. import androidx.room.Query;
  21. import androidx.room.Update;
  22. @Dao
  23. public interface DaoIdentity {
  24. @Query("SELECT identity.*, account.name AS accountName FROM identity" +
  25. " JOIN account ON account.id = identity.account")
  26. LiveData<List<TupleIdentityEx>> liveIdentities();
  27. @Query("SELECT identity.* FROM identity" +
  28. " JOIN account ON account.id = identity.account" +
  29. " WHERE account.synchronize = :synchronize" +
  30. " AND identity.synchronize = :synchronize")
  31. LiveData<List<EntityIdentity>> liveIdentities(boolean synchronize);
  32. @Query("SELECT * FROM identity")
  33. List<EntityIdentity> getIdentities();
  34. @Query("SELECT * FROM identity WHERE id = :id")
  35. EntityIdentity getIdentity(long id);
  36. @Query("SELECT * FROM identity WHERE id = :id")
  37. LiveData<EntityIdentity> liveIdentity(long id);
  38. @Insert
  39. long insertIdentity(EntityIdentity identity);
  40. @Update
  41. void updateIdentity(EntityIdentity identity);
  42. @Query("UPDATE identity SET state = :state WHERE id = :id")
  43. int setIdentityState(long id, String state);
  44. @Query("UPDATE identity SET error = :error WHERE id = :id")
  45. int setIdentityError(long id, String error);
  46. @Query("UPDATE identity SET `primary` = 0")
  47. void resetPrimary();
  48. @Query("DELETE FROM identity WHERE id = :id")
  49. void deleteIdentity(long id);
  50. }