Futurescale, Inc. PureMVC Home

The PureMVC Framework Code at the Speed of Thought


Over 10 years of community discussion and knowledge are maintained here as a read-only archive.

New discussions should be taken up in issues on the appropriate projects at https://github.com/PureMVC

Pages: [1]
Print
Author Topic: Extending a proxy  (Read 16357 times)
albertkang75
Newbie
*
Posts: 7


View Profile Email
« on: September 10, 2009, 04:08:43 »

I would like to extend a Proxy that is calling a webservice; however, I'm not sure if this is advisable.  The scenario is I have 2 webservices that expose the same webmethods; however, they have different return types, i.e. the first service might have methods that return a type "Cat" and the other service have methods that return a type "Striped Cat". 

i.e.
catservice.asmx
getCat():Cat
getOldCats():Cat

stripedCatService.asmx
getCat():StripedCat
getOldCats():StripedCat

Would I have to recreate the exact same proxy twice?
Logged
dihardja
Jr. Member
**
Posts: 17


View Profile Email
« Reply #1 on: September 11, 2009, 06:44:54 »

Hi,

in projects, i often have multiple proxies extending one base proxy. inside the baseproxy i usualy put the authentification values for the webservice, the base url of the service, error handling, etc. in the derived proxies then, the specific task. for example a proxy for user login, a proxy for registration, a proxy for saving specific settings, a proxy for searching etc. in my opinion, it is more maintainable having multiple proxies rather than handling all the conditions iniside one big proxy.
« Last Edit: September 11, 2009, 06:48:23 by dihardja » Logged
albertkang75
Newbie
*
Posts: 7


View Profile Email
« Reply #2 on: September 11, 2009, 06:58:03 »

i have no desire to have one big proxy - what i would like is to have one proxy subclass another proxy but send out different notifications with different payloads/bodies (i.e. Cat vs. StripedCat).
Logged
dihardja
Jr. Member
**
Posts: 17


View Profile Email
« Reply #3 on: September 11, 2009, 11:02:46 »

i see, sorry to missunderstand you. just curious, without knowing the context of your application, is it possible then to have one proxy with the following methods:

getCat():Cat
getOldCats():Cat
getStripedCat():StripedCat
getOldStripedCats():StripedCat

because of the same method names, i assume that the usage of objects of type Cat and StripedCat are in the same context. therefore my opinion is to let one proxy ( e.g. the Cat proxy ) get the data even if more than one service call is required. after the data is ready, the proxy can notify it and can be used by the rest of the system. 


« Last Edit: September 11, 2009, 11:31:00 by dihardja » Logged
albertkang75
Newbie
*
Posts: 7


View Profile Email
« Reply #4 on: September 11, 2009, 11:39:55 »

that's the scenario i'm trying to avoid - writing more code that could ideally be avoided by just extending another class.
Logged
dihardja
Jr. Member
**
Posts: 17


View Profile Email
« Reply #5 on: September 11, 2009, 12:51:43 »

extended or not extended, one proxy is one proxy.
Logged
albertkang75
Newbie
*
Posts: 7


View Profile Email
« Reply #6 on: September 11, 2009, 01:02:59 »

copy and pasting over and over to make a bloated class is definitely not ideal.
Logged
dihardja
Jr. Member
**
Posts: 17


View Profile Email
« Reply #7 on: September 11, 2009, 10:49:45 »

well, one proxy is not the same with one bloated copy paste class. at the first point it means one data interface for a specific context in the application. how the proxy handles and manage to get and store the data internally is up to the developer. is it by extending another proxy, having references to other data objects etc. my thought with this is refering only to the lines of code in your post. therefore, it is of course possible that other constructs may fit better if other parts in the application are considered.
« Last Edit: September 11, 2009, 10:55:57 by dihardja » Logged
puremvc
Global Moderator
Hero Member
*****
Posts: 2871



View Profile WWW Email
« Reply #8 on: September 12, 2009, 09:48:06 »

in projects, i often have multiple proxies extending one base proxy. inside the baseproxy i usualy put the authentification values for the webservice, the base url of the service, error handling, etc. in the derived proxies then, the specific task. for example a proxy for user login, a proxy for registration, a proxy for saving specific settings, a proxy for searching etc. in my opinion, it is more maintainable having multiple proxies rather than handling all the conditions iniside one big proxy.
I don't see the problem with the solution as described in dihardja's first response. The suggestion is not to make one big proxy but instead to extend a base proxy with multiple subclasses. There's no cut/paste/bloat there.

-=Cliff>
Logged
Pages: [1]
Print