Security News
New Python Packaging Proposal Aims to Solve Phantom Dependency Problem with SBOMs
PEP 770 proposes adding SBOM support to Python packages to improve transparency and catch hidden non-Python dependencies that security tools often miss.
botbuilder-lg
Advanced tools
Bot Builder Language Generation is a library to help build sophisticated bot responses with multiple phrases and context-based expressions.
Learning from our customers experiences and bringing together capabilities first implemented by Cortana and Cognition teams, we are introducing Language Generation; which allows the developer to extract the embedded strings from their code and resource files and manage them through a Language Generation runtime and file format. Language Generation enable customers to define multiple variations on a phrase, execute simple expressions based on context, refer to conversational memory, and over time will enable us to bring additional capabilities all leading to a more natural conversational experience.
At the core of language generation lies template expansion and entity substitution. You can provide one-of variation for expansion as well as conditionally expand a template. The output from language generation can be a simple text string or multi-line response or a complex object payload that a layer above language generation will use to construct a full blown activity.
Language generation is achieved through:
# greetingTemplate
- Hello ${user.name}, how are you?
- Good morning ${user.name}. It's nice to see you again.
- Good day ${user.name}. What can I do for you today?
You can use language generation to:
The type of LG output could be string or object, string is by default. But LG could generate a json object by Structured LG feature.
Example here:
# HeroCardTemplate(buttonsCollection)
[Herocard
title=${TitleText())}
subtitle=${SubText())}
text=${DescriptionText())}
images=${CardImages())}
buttons=${buttonsCollection}
]
# TitleText
- Here are some ${TitleSuffix()}
# TitleSuffix
- cool photos
- pictures
- nice snaps
# SubText
- What is your favorite?
- Don't they all look great?
- sorry, some of them are repeats
# DescriptionText
- This is description for the hero card
# CardImages
- https://picsum.photos/200/200?image=100
- https://picsum.photos/300/200?image=200
- https://picsum.photos/200/200?image=400
the result could be:
{
"lgType": "Herocard",
"title": "Here are some pictures",
"text": "This is description for the hero card",
"images": "https://picsum.photos/200/200?image=100",
"buttons": [
"click to see",
"back"
]
}
the structured name would be placed into property 'lgType'. See more tests here : structured LG test
By this, You can use the ActivityFactory.fromObject(lgResult)
method to transform the lg output into a Bot Framework activity to post back to the user.
see more samples here: Structured LG to Activity
When building a bot, you can use language generation in several different ways. To start with, examine your current bot's code (or the new bot you plan to write) and create .lg file to cover all possible scenarios where you would like to use the language generation sub-system with your bot's replies to user.
Then make sure you include the platform specific language generation library.
For C#, add Microsoft.Bot.Builder.LanguageGeneration. For NodeJS, add botbuilder-lg
Load the template manager with your .lg file
let templates = new Templates.parseFile(filePath, importResolver?, expressionParser?);
When you need template expansion, call the templates and pass in the relevant template name
await turnContext.sendActivity(templates.evaluate("<TemplateName>", entitiesCollection));
If your template needs specific entity values to be passed for resolution/ expansion, you can pass them in on the call to evaluateTemplate
await turnContext.sendActivity(templates.evaluate("WordGameReply", { GameName = "MarcoPolo" } ));
If you changed the g4 file, please use antlr-build-expression
and antlr-build-commonregex
to generate latest lexer/parser. By the way, You will need to have a modern version of Java (>= JRE 1.6) to use it.
FAQs
Bot Builder Language Generation is a library to help build sophisticated bot responses with multiple phrases and context-based expressions.
The npm package botbuilder-lg receives a total of 606 weekly downloads. As such, botbuilder-lg popularity was classified as not popular.
We found that botbuilder-lg demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
PEP 770 proposes adding SBOM support to Python packages to improve transparency and catch hidden non-Python dependencies that security tools often miss.
Security News
Socket CEO Feross Aboukhadijeh discusses open source security challenges, including zero-day attacks and supply chain risks, on the Cyber Security Council podcast.
Security News
Research
Socket researchers uncover how threat actors weaponize Out-of-Band Application Security Testing (OAST) techniques across the npm, PyPI, and RubyGems ecosystems to exfiltrate sensitive data.