Teams Hub
About
- 
                                                    Integration with the Teams application is accomplished by installing the SmartHub Teams application in your tenant or a specific Team. 
- The integration is compatible with both the web and the desktop version of Teams.
- 
                                                    The SmartHub Teams app exposes 3 types of integrations: - Message extension
                                                            - Enables you to run searches and embed results as part of your messages in Chat.
 
- Personal Tab extension
                                                            - Enables you to access the full functionality of the SmartHub center directly from Teams.
 
- Teams Tab extension 
                                                            - Enables all the members of your team to access the full functionality of the SmartHub center directly from the Team tabs.
 
 
- Message extension
                                                            
Prerequisites
- SmartHub must be installed and accessible using HTTPS- This requires a trusted, valid certificate to be configured in the IIS bindings
 
- Supported Authentication: Only "Azure AD" or "Federated authentication" - Windows Authentication is unsupported
 
- 
                                                    If you plan to install the Hub for only someTeams then the Teams external app installation switch needs to be enabled to side-load applications - see Admin settings for apps in Microsoft Teams.  If you do not configure the Teams Hub correctly, it is made available to the entire Organization. Any user will be able to install the Hub for himself or the Teams he is a member of. 
Additional Message Extension Requirements
In Teams, the message extension functionality is based off the Microsoft Bot Framework infrastructure. As a result there are some specific requirements for this feature to work:
- An Office 365 account with permissions to register a Bot service.
- SmartHub needs to be accessible from the internet for the Bot Framework to reach it.
- A bot needs to be registered and configured in the Microsoft Bot Framework Portal. For more information, see the Register the SmartHub Teams Bot section.
How to Register the SmartHub Teams Bot
- Navigate to the Bot Framework Portal.
- Click on the Create button.
- You are redirected to the Azure portal Bot Service Blade.
- Enter a Bot handle.
- Choose the Subscription.
- Select a Resource Group (or create a new one).
- Select a Pricing Tier.
- On the Microsoft App ID field, do the following:- If you do not own an application, create a new Microsoft App ID.
- If you already have a registered application, use an existing app registration- In this scenario, the Existing app ID and Existing app password must be provided. - The App ID can be obtained from an existing registered application. To locate the App ID, click Overview and note the value in the Application (client) ID field. You should also note the Directory ID on this page for later use in the configuration.
- The App password can be obtained by clicking the Certificates & secrets on the left side panel. The existing app should be multi-tenant. The existing app should be multi-tenant.
 
 
- In this scenario, the Existing app ID and Existing app password must be provided. 
 
- Click Review + Create then Create.
- Wait until the deployment is finished, then click Go to resource.
- Click Configuration and enter the Messaging endpoint in the following format: https://smartHubAddress:port/_bai/MSTeams. For example, https://smarthub.contoso.com/_bai/MSTeams. 
- Check Enable Streaming Endpoint.  
- Take note of the Microsoft App ID and Client Secret values which is required later on.
- Click on the Channels section and choose the Microsoft Teams from the Available Channels section.
- Agree to the terms of Service, select Microsoft Teams Commercial (most common) then click Save.
- Configure the bot for Single Sign-on (SSO):- Navigate to the newly created bot.
- Adjacent to Microsoft App ID:- Select Manage.
- From the left pane of your bot resource, Select Authentication. 
 
- If the Web Platform has not been created, choose Add a platform > Web.
- Enter the following Redirect URI: https://token.botframework.com/.auth/web/redirect.
- Check the Access tokens and ID tokens checkboxes.
- Click Configure. 
- If the web platform is already created, add the above URI and select those checkboxes.
 
- The current application should be registered as multi-tenant, otherwise the bot framework is not allowed to access the exposed API that will e created in the following steps. - If the Microsoft App ID was created at the same time with the Azure Bot, the app registration is already set to multi-tenant.  
- If you used an existing app registration, the following changes should be made: - Navigate to the Manifest section. 
- Change the property for signInAudeince to AzureADandPersonalMicrosoftAccount.  A multi-tenant application does not allow custom Application ID URI. For example: A multi-tenant application does not allow custom Application ID URI. For example:- https://localhost:1234, https://my-app-id-URI
- The property must use a verified domain of the organization or its sub-domain.
 
- Ensure the config item is set to "accessTokenAcceptedVersion": 2. If not, change it's value to 2. 
- Click Save.  
 
 
- Select Expose an API from the left pane and select Set for the Application ID URI.- If the newly created application was used, use the Application ID URI shown and append api://botid- at the beginning of the URI. 
- If an existing app was used, set the Application ID URI as follows: api://botid-<MicrosoftAppId>. 
  You must use the exact Application ID URI template as described above, otherwise the SSO process will fail. 
- Click Save. Take a note of Application ID URI value which are required later on.
- On the Scopes defined by this API section, create a new scope with the following configuration:- Scope name: Enter a scope name.
- Who can consent?: Select Admins and users.
- Admin consent display name: Enter a consent display name.
- Admin consent description: Enter a description for the Admin consent.
- State: Select Enabled.
  
- Save the newly created scope.
- Add the following IDs as Authorized client applications and select the checkbox for Authorized scopes:- 1fec8e78-bce4-4aaf-ab1b-5451cc387264 (Teams mobile or desktop application) 
- 5e3ce6c0-2b1f-4285-8d4b-75ee78787346 (Teams web application) 
- Your MicrosoftAppId. If you have been following these steps, you would have noted this in step 13.' 
 
- Select Token configuration from the left-side panel and do the following:- Click Add optional claim. Select Access as *Token type.
- Select upn under Claim and click Add.
- Click Add optional claim. Select ID as *Token type.
- Select upn under Claim and click Add.
 
- Navigate to API Permissions > Add a permission > Microsoft Graph > Delegated permissions and select all OpenId permissions:- offline_access
- openid
- profile
 
- Navigate to API Permissions > Add a permission > My APIs > Select your app that you use for authentication in SmartHub > Select the scope that your configured in step 20. In this example, we set up a scope named SH.ALL. 
- Open the Azure Bot and go to Configuration > Add OAuth Connection Settings.- In the New Connection Setting, enter the following details:- Name: Enter a name for the new connection string. Take a note of the connection name.
- Service Provider: Select Azure Active Directory V2 from the drop-down list.
- Client id: Enter the Microsoft App Id that you noted in step 13.
- Client secret: Enter the Client Secret value that you noted in step 13.
- Token Exchange URL: Enter the Application ID URI that you noted in step 19.
- Tenant ID: Enter the Tenant ID that you noted in step 8.
- Scopes: enter email offline_access openid profile smarthub-auth-app-scope/SH.ALL.
  
 
- In the New Connection Setting, enter the following details:
- Click Save.
- After the OAuth connection is saved, select it and click Test Connection.
- On the permissions pop-up, click Approve.
- If the configuration is correct, a token will be generated. You can close this tab.
How to Configure the App
To install the app you must first update the manifest with your own configuration details:
- Navigate to the installation directory of your SmartHub website.
- Open the integrations\msteams\SmartHubApp folder.
- Edit the manifest.json, SmartHub Security Settings and web.config files as instructed in the following sections.You must change the version from "version": "1.0.0.0" to "version": "1.0.0".
Personal Tab Settings
This is used for configuring what page the Personal tab of the users that install the Hub will display.
- To fully disable this functionality remove the entire staticTabs node and its children from the manifest.
- Look for staticTabs property and change the contentUrl and websiteUrl to point to your SmartHub address
"contentUrl": "https://smartHubAddress:port/Index.html#pn=msteams"
"websiteUrl": "https://smartHubAddress:port/Index.html#pn=msteams"
Messaging Extension Settings
This is used for configuring what bot the Messaging extension communicates with. To fully disable this functionality, remove the entire composeExtensions node and its children from the manifest.
- Look for composeExtensions and change the botId property by replacing it with Microsoft App ID that you noted down during the Bot Service creation.
- Look for webApplicationInfo and do the following:- Replace the id property with the Microsoft App ID.
- Replace the resource property with the Application ID URI.
 
- From your SmartHub rooot folder, open the web.config file for editing.
- Change the following keys:- TeamsBotConnectionName with connection name that you noted. 
- TeamsBotSiteURL with the smarthub address in the following format: https://smartHubAddress:port. 
- TeamsBotClientId with the Client ID that you noted. 
 
- Navigate to the SmartHub Admin page > Security Settings > Trusted app registration and expand the section.- Add Trusted App Registrations.
- Add the Client ID of the Azure bot app.
- Add the Client Secret of the Azure bot app.
- Click OK. 
 
Team Tab Extension Settings
This is used for configuring what page should be opened when users navigate to the SmartHub tab in their Team. To fully disable this functionality, remove the entire configurableTabs node and its children from the manifest.
- Look for configurableTab and modify the configurationUrl to point to your SmartHub address - make sure you leave the following relative path in the URL: /integrations/msteams/ConfigPage.html
- If you want to point the Team Tab to a custom page that is based on the default Index and Results pages from Teams, you must append the following to the end of the URL:
 ?address=<address to the page that should be opened by the tab>
- By default, it automatically opens the built-in /integrations/msteams pages.
After Settings Are Complete
- Save the changes and go to the parent directory: integrations\msteams.
- Go to SmartHubApp directory and select all (CTRL + A) files inside. - Right-click the files and choose the option Send To → Compressed (zipped) folder. 
 
- Right-click the files and choose the option Send To → Compressed (zipped) folder.
- After the archive is created, copy it to the environment where you have the Teams desktop client installed.
How to Install the SmartHub Teams App
The SmartHub Teams App can be installed at 3 levels:
- Me or My Teams → Personal (Add for you)
                                                    - The Messaging extension is installed only for you
- The Personal Tab extension is installed to your account
- The Team Tab extension is not installed
 
- Me or My Teams → Team (Add to a team)
                                                    
 - The Messaging extension is installed for all of your team members
- The Personal tab extension is only installed to your account
- The Team Tab extension is installed for the Teams you select
 
- Organization
                                                    - The app is uploaded and made available for all of your users but is not automatically installed to any user or team.
 
The app needs to be installed individually for each team that is planing to use it.
How to Install the Teams App for a Specific User or Team
Navigate to the Store and click on Upload a custom app > Upload for me or my teams and select the ZIP file created in step 2 in After Settings Are Complete.
                                                 
                                            
How to Make the Teams App Available to Your Organization
Navigate to the Store and click on Upload a custom app > Upload for [OrganizationName] and select the ZIP file created in step 2 in After Settings Are Complete.
This does not install the application but makes it available under the Store → [Organization Name] subsection.
                                                 
                                                
                                                
                                            
Now you and everyone from your organization can select the Teams app and install it personally or to any Team the user owns.
How to Uninstall the SmartHub Teams App
The SmartHub Teams App must be uninstalled from 4 sections, or tabs, listed here:
- Personal tab
- Team tab
- Conversations tab
- <Your Custom Named> SmartHub tab
Personal Tab
- Select Teams from the right side menu. 
- From the menu, select SmartHub.
- Click the dots icon "..." and select Uninstall. 
Team Tab
- Click the icon More options.
- Click Manage team. 
- On the top, horizontal menu, select Apps.
- Click the trash can icon to delete your (custom) Smart Hub app. 
How to Change the Results Icon from the Bot
- Navigate to the installation directory of your SmartHub website.
- Open the integrations\msteams\image folder.
- Add your custom icons, using as name of the file the expected extension.- Example: for results with a PDF extension, the icon name is "pdf.png"
 
How to Use Open In Tab
TheOpen in tabbutton allows to user to open a Smart Hub teams tab directly from the messaging extension.
The button can be found by clicking on theActionsbutton and selectingOpen in tab.
                                                 
                                            
- 
                                                    The URL from theOpen in tabbutton can be changed by modifying the value of theTeamsTabDeepLinkin theSmartHub web configfile. 
- 
                                                    The default value is https://teams.microsoft.com/l/entity/a3a08585-d711-4b52-822d-37bef774d077/MainTab 
How to Track Queries from Bot in SmartAnalytics
To see reports about queries from Bot, go to http://ReportingPageAddress/Pages/QueryAnalytics/QueriesBySource.aspx
Conversations Tab
- Go to your team's General page.
- Go to the Conversations tab.
- Click on the Messagingextensions icon.
- Go to the Smart Hub App and click "Uninstall."
                                                
                                                 
                                            
Remove <YourCustomNamed> SmartHub
Remove "SmartHub Enterprise Search" (or the name of your SmartHub) Tab:
- Go to your team's General page.
- Select your SmartHub from the top horizontal menu.
- Click Remove.
                                                