Interactor that maintains state cleanly

95 views
Skip to first unread message

Lee

unread,
Mar 14, 2014, 4:06:40 PM3/14/14
to clean-code...@googlegroups.com
Hi

Sorry for all the questions :-)

In a clean solution; how would you tackle a scenario whereby an interactor needs to maintain a value between calls? for example; the interactor receives a request, processes it, then sends back the response, but the data in the response involves some sort of sequence numbering and the numbering needs to be maintained for the next time the interactor is used.

I can think of a couple of possibilities and i'm leaning towards persisting it through the database gateway or more likely a more local caching mechanism, but i'm not sure if it's ok for an interactor to mainstate state or whether that's considered dirty.

cheers
Lee

James Green

unread,
Mar 14, 2014, 5:10:59 PM3/14/14
to clean-code...@googlegroups.com
Definitely store in database - particularly if it's a client/server system - no guarantee the second call will occur in the same instance of the interactor as the first.

Database holds state, that is its job.

Sent from my iPad
--
The only way to go fast is to go well.
---
You received this message because you are subscribed to the Google Groups "Clean Code Discussion" group.
To unsubscribe from this group and stop receiving emails from it, send an email to clean-code-discu...@googlegroups.com.
To post to this group, send email to clean-code...@googlegroups.com.
Visit this group at http://groups.google.com/group/clean-code-discussion.

Michel Henrich

unread,
Mar 14, 2014, 5:13:19 PM3/14/14
to clean-code...@googlegroups.com
Hello Lee,

I've faced a similar issue before, and I used the solution of "persisting through the gateway", as you proposed. I do not think of it as dirty, because the application does not know which implementation of the gateway interface is actually being used. It could be an "in-memory cache", or an actual database persistence implementation.

My experience was implementing a sales application. A sales order has lots of information to be filled in the "header" alone, and also carries a collection of items, each with lots of information as well.
I decided to break the process of filling all this information into small use-cases, most of which produced an "invalid" or "transient" state in the system, because some of the required would be filled by the next use-case, until the final use-case "approves" the complete sales order and persists it in the database.
This means that I had an "in-memory cache" gateway implementation that would be sent to the "transient" use-cases, and an actual persistence gateway that was sent to the final use-case of "sales order approval".

Personally, I like the solution because the application only has to know of one way to deal with keeping information between use-cases, and that is the gateway.
However, we can argue that it adds complexity to the consumer of the application-core (delivery mechanism), because now the consumer has to decide which gateway to use for which use-case.
I believe, however, that this is indeed the responsibility of the application consumer. I'd rather add this decision-making process to the consumer, than force my application to use concepts like transient and persistent data.

Lee

unread,
Mar 15, 2014, 3:55:04 AM3/15/14
to clean-code...@googlegroups.com
Thanks guys

Very informative and helpful replies.

cheers
Lee

Reply all
Reply to author
Forward
0 new messages