Search code examples
androidandroid-serviceandroid-mvp

What role an Android Service should play in the MVP pattern?


I am developing an Android app that does Human Activity Recognition.

It basically works like that - Service constantly reads the accelerator data and stores the recognized activity (i.e. Walking, running) in a database. The user can see all of the recognized activities in an ListView in activity (accesses the database). Every User table in the database has a pa_goal (physical activity goal) field which the Service reads from the database and does some checks.

The user, of course, can change this goal from an activity. Since I will be implementing the MVP architectural pattern.

I am unsure where to put the Service? It surely isn't View. Any advice?


Solution

  • In a clean architecture, which is what I am assuming you are using MVP for, there is the idea of separating the framework from the business logic. This is essentially what a normal presenter allows you to do.

    In this case its not a view you are dealing with but the principle is similar. You don't want all your business or application logic mixed in the Android code when you can separate them out for nicer, more single responsibility classes. So I would say that while it isn't a view you should still have a presenter type class (probably better to be called controller or manager maybe).

    This class would be a POJO that controls how your service behaves which is easily testable with standard junit tests and service mocks. This class and the service could then be put into its own feature package and interact with the back end models the same way as your presenters.

    So, in summary, the role is of another feature of your app that sites alongside the other features (which are usually just views in my experience).

    Hope that helps