GuyWithOCD
GuyWithOCD

Reputation: 51

UCMA vs UCWA - User vs Application Endpoint

I need to develop a chatbot with these properties:

Platform - Skype for Business On-Premise

Function - Replies to user queries by looking in various knowledgebases (Multiple Platforms - Databases, Web APIs, etc.)

Basic textual conversation to begin with and will gradually evolve to send attachments

No calls/videos, just chat

Will be hosted on an external server with organisation VPN

A simple sip will be created for the chatbot which can be pinged by any user. I should be able to get this through to our IT dept.

Limited time for development

Scalability is an essential requirement but the organisation is fairly new to this, so they might be patient and allow me to make mistakes

My research has led me to these possible approaches:

  1. SfB SDK - I have rejected this approach because it requires the client to be running at all times and doesn't seem to be scalable

  2. UCMA with Application Endpoint - Haven't rejected this approach, but seems like I'll not go ahead with this because creation of Application Platforms seems tedious and requires me to make a lot of SfB server related IT requests

  3. UCMA with User Endpoint - Great affinity towards this. I have experimented Tom Morgan's (thoughtstuff.co.uk) stuff and this seems like something I can start off right away

  4. UCWA with Application Endpoint - Rejected this approach, because UCWA (from my research) appears unsuitable for On-premise and the setup also seems time consuming

  5. UCWA with User Endpoint - Haven't rejected this approach, but I'm not sure if the Web API way is really a good approach for On-premise platform

I'd like to ask how am I doing so far, but that seems too vague

What would you suggest is a good way to achieve this?

Also, can someone be patient enough to reply the drawbacks and advantages of each approach for my use case. I'd like to make an informed decision and not reject any approach, just because of a misunderstood overhead

Upvotes: 3

Views: 720

Answers (1)

GuyWithOCD
GuyWithOCD

Reputation: 51

I have been asking around in my organisation and other circles.

And since I am not receiving any quick responses, I'll keep adding what I have learnt. This way a person in the dev community will have a log of how I went with this.

UCWA is better suited for S4B online (compared to on premise) and is generally used by people who are comfortable with RESTful and have low familiarity with .NET development

UCMA is apparently THE WAY to go and for any on-premise bot requirements, preferably with an application endpoint.

So for our development, we are starting with UCMA user endpoint so that we can deliver a basic start as a version-one And meanwhile we shall also get in touch with the IT department and Lync administrators for creation of Application Endpoints Once we have this the same functionality that we had with the user endpoint will be copied over to the Application Endpoint version

Keep watching this space for further updates

Upvotes: 2

Related Questions