Files
Messenger/android/CHANGELOG.md
Codex 5a0add4d5c
Some checks are pending
CI / test (push) Has started running
android: add message api contracts and repository usecases
2026-03-08 23:06:30 +03:00

5.0 KiB

Android Changelog

2026-03-08

Step 1 - Build and app wiring

  • Added Android project plugin configuration for Hilt and Kotlin serialization.
  • Added dependency repositories and explicit app module include in settings.
  • Added app dependencies for Retrofit/OkHttp, DataStore, coroutines, Hilt, and unit testing.
  • Enabled INTERNET permission and registered MessengerApplication in manifest.
  • Added MessengerApplication with HiltAndroidApp.

Step 2 - Network/data core + DI

  • Fixed DTO/Auth API serialization annotations and endpoint declarations for /api/v1/auth/login, /api/v1/auth/refresh, /api/v1/auth/me.
  • Implemented DataStore-based token persistence with a corrected getTokens() read path.
  • Added auth network stack: bearer interceptor, 401 authenticator with refresh flow and retry guard.
  • Added clean-layer contracts and implementations: domain/common, domain/auth, data/auth/repository.
  • Wired dependencies with Hilt modules for DataStore, OkHttp/Retrofit, and repository bindings.

Step 3 - Minimal auth UI and navigation

  • Replaced Phase 0 placeholder UI with Compose auth flow (AuthViewModel + login screen).
  • Added loading/error states for login and startup session restore.
  • Added navigation graph: AuthGraph (login) to placeholder Chats screen after successful auth.
  • Implemented automatic session restore on app start using stored tokens.

Step 4 - Unit tests

  • Added DataStoreTokenRepositoryTest for token save/read and clear behavior.
  • Added NetworkAuthRepositoryTest for login success path and 401 -> InvalidCredentials error mapping.

Step 5 - Chat Room models and persistence core

  • Added domain chat model (ChatItem) for chat list rendering concerns.
  • Added Room entities: chats, users_short with sort-friendly indices.
  • Added ChatDao with observeChats(), upsertChats(), and transactional clearAndReplaceChats().
  • Added MessengerDatabase and Hilt database wiring (DatabaseModule).

Step 6 - Chat API and repository sync

  • Added chat REST API client for /api/v1/chats and /api/v1/chats/{chat_id}.
  • Added chat DTOs and remote/local mappers (ChatReadDto -> ChatEntity/UserShortEntity -> ChatItem).
  • Implemented NetworkChatRepository with cache-first flow strategy (Room first, then server sync).
  • Added chat domain contracts/use-cases (ChatRepository, observe/refresh use-cases).
  • Wired chat API/repository via Hilt modules.

Step 7 - Realtime manager and chat list updates

  • Added a unified realtime manager abstraction and WebSocket implementation for /api/v1/realtime/ws?token=....
  • Implemented auto-reconnect with exponential backoff and max cap.
  • Added realtime event parser for receive_message, message_updated, message_deleted, chat_updated, chat_deleted, user_online, user_offline.
  • Added use-case level realtime event handling that updates Room and triggers repository refreshes when needed.
  • Wired realtime manager into DI.

Step 8 - Chat list UI and navigation

  • Added Chat List screen with tabs (All / Archived), local search filter, pull-to-refresh, and state handling (loading/empty/error).
  • Added chat row rendering for unread badge, mention badge (@), pinned/muted marks, and message preview by media type.
  • Added private chat presence display (online / last seen recently fallback).
  • Connected Chat List to ViewModel/use-cases with no business logic inside composables.
  • Added chat click navigation to placeholder ChatScreen(chatId).

Step 9 - Tests and checklist updates

  • Added unit test for chat cache-first sync strategy (NetworkChatRepositoryTest).
  • Added unit test for realtime event parsing (RealtimeEventParserTest).
  • Added DAO test (ChatDaoTest) using in-memory Room + Robolectric.
  • Updated Android checklist status in docs/android-checklist.md.

Step 10 - Build stabilization fixes

  • Switched Android API base URL to https://chat.daemonlord.ru/.
  • Added cleartext traffic flag in manifest for local/dev compatibility.
  • Fixed Hilt dependency cycle by separating refresh AuthApiService with a dedicated qualifier.
  • Added CoroutineDispatcher DI provider and qualifier for repositories.
  • Fixed Material3 experimental API opt-in and removed deprecated StateFlow.distinctUntilChanged() usage.

Step 11 - Sprint A / 1) Message Room + models

  • Added message domain model (MessageItem) for chat screen rendering.
  • Added Room entities messages and message_attachments with chat-history indexes.
  • Added MessageDao with observe/pagination/upsert/delete APIs.
  • Updated MessengerDatabase schema to include message tables and DAO.
  • Added Hilt DI provider for MessageDao.

Step 12 - Sprint A / 2) Message API + repository

  • Added message REST API client for history/send/edit/delete endpoints.
  • Added message DTOs and mappers (MessageReadDto -> MessageEntity -> MessageItem).
  • Added MessageRepository contracts/use-cases for observe/sync/pagination/send/edit/delete.
  • Implemented NetworkMessageRepository with cache-first observation and optimistic text send.
  • Wired message API and repository into Hilt modules.