I'm at the moment trying to make up a "core" for my multi-device project.
The project is all about a web application, that authenticates the user by facebook login, and then exposes a set of new actions they can do - ex. Get all records in the database thats related to their facebook id etc.
The core should be understood by following devices:
Now how would you make up the core?
Would you make it a WCF service that returns JSON?
Would you make it a bunch of Controllers that returns JSON?
And how would you ensure that the user is who he/she says, when querying the core? Should I pass along the accessToken thats generated by facebook each time?
As you might have noticed, I've absolutely no idea at all how to do this.
Thanks in advance.
Not sure if I understand your question correctly, but...
First, you will have to define, or probably decide, what the "Core" is? or what the Core should be - what will be the functionality that Core
will perform. Ideally, when we say Core, it essentially means, a layer that performs basic or atomic operations.
Over that Core you can spawn the device wrappers(IPhone, PC, etc) that builds a query to be sent to core, for instance.
You can use WCF Data Service to constitute a data layer. And your core can perform business operations/etc, and communicate with the Data Service.
For instance, what I instantly can think of is:
DeviceWrapper
(DeviceAndriod, DeviceIPhone, DeviceWeb, etc), that wraps different devices. For example, a mixture of Factory/Builder pattern. Think about factory of Device
s, and Builder for types of views.TextRenderer
, based upon the device settings, renders the text.One way could be, lets decide:
The Core
, will be a "library" that will perform basic operations:
Therefore,
STEP 1: Write a Controller that will provide authenticate/authorization; for instance, call the Core.Authenticate()
, and Authorize()
;
STEP 2: Based upon the user agent call ICore.RenderView(agentType), this may return you the view/html to be rendered.
User may perform an action, your Controller may call Core.PerformAction()
; which in turn may return the link to the page to be redirected, for instance.
--UPDATED--
This update is in response to your comment.
Now, in this(your comment) case, you are talking about client ends.
Lets clear up a bit. There is server and there are client sides.
Up till now, we were talking about Server side, which primarily is concerned with:
Client ends could be:
Decide what this "client app" will do. For instance, in your case:
Note that, you may want to consider smart clients (using web services, rather than asp.net web pages).
Also, the type hinting in WCF can add a lot of unnecessary overhead in the JSON response for large collections. Therefore, if you even remotely believe that you might want multiple types of end-points (SOAP, etc.) at some point in the time, then WCF is the way to go.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With