bindings... allowing unescaped urls, but not html tags

This commit is contained in:
Michael Shanks 2020-08-11 14:12:05 +01:00
parent 9474184f2f
commit 9e6f6c5292
4 changed files with 25 additions and 7 deletions

View File

@ -1,4 +1,4 @@
import mustache from "mustache" import renderTemplateString from "../../state/renderTemplateString"
import appStore from "../../state/store" import appStore from "../../state/store"
import Orchestrator from "./orchestrator" import Orchestrator from "./orchestrator"
import clientActions from "./actions" import clientActions from "./actions"
@ -17,7 +17,7 @@ export const clientStrategy = ({ api }) => ({
if (typeof argValue !== "string") continue if (typeof argValue !== "string") continue
// Render the string with values from the workflow context and state // Render the string with values from the workflow context and state
mappedArgs[arg] = mustache.render(argValue, { mappedArgs[arg] = renderTemplateString(argValue, {
context: this.context, context: this.context,
state: appStore.get(), state: appStore.get(),
}) })

View File

@ -1,4 +1,4 @@
import mustache from "mustache" import renderTemplateString from "../state/renderTemplateString"
import appStore from "../state/store" import appStore from "../state/store"
import hasBinding from "../state/hasBinding" import hasBinding from "../state/hasBinding"
@ -46,7 +46,7 @@ export const prepareRenderComponent = ({
const toSet = {} const toSet = {}
for (let prop of storeBoundProps) { for (let prop of storeBoundProps) {
const propValue = initialProps._bb.props[prop] const propValue = initialProps._bb.props[prop]
toSet[prop] = mustache.render(propValue, state) toSet[prop] = renderTemplateString(propValue, state)
} }
thisNode.component.$set(toSet) thisNode.component.$set(toSet)
} }

View File

@ -0,0 +1,17 @@
import mustache from "mustache"
// this is a much more liberal version of mustache's escape function
// ...just ignoring < and > to prevent tags from user input
// original version here https://github.com/janl/mustache.js/blob/4b7908f5c9fec469a11cfaed2f2bed23c84e1c5c/mustache.js#L78
const entityMap = {
"<": "&lt;",
">": "&gt;",
}
mustache.escape = text =>
String(text).replace(/[&<>"'`=/]/g, function fromEntityMap(s) {
return entityMap[s]
})
export default mustache.render

View File

@ -4,7 +4,7 @@ import {
EVENT_TYPE_MEMBER_NAME, EVENT_TYPE_MEMBER_NAME,
} from "./eventHandlers" } from "./eventHandlers"
import { bbFactory } from "./bbComponentApi" import { bbFactory } from "./bbComponentApi"
import mustache from "mustache" import renderTemplateString from "./renderTemplateString"
import appStore from "./store" import appStore from "./store"
import hasBinding from "./hasBinding" import hasBinding from "./hasBinding"
@ -64,7 +64,7 @@ const _setup = ({ handlerTypes, getCurrentState, bb }) => node => {
if (isBound) { if (isBound) {
const state = appStore.getState(node.contextStoreKey) const state = appStore.getState(node.contextStoreKey)
initialProps[propName] = mustache.render(propValue, state) initialProps[propName] = renderTemplateString(propValue, state)
if (!node.stateBound) { if (!node.stateBound) {
node.stateBound = true node.stateBound = true
@ -83,7 +83,8 @@ const _setup = ({ handlerTypes, getCurrentState, bb }) => node => {
const resolvedParams = {} const resolvedParams = {}
for (let paramName in handlerInfo.parameters) { for (let paramName in handlerInfo.parameters) {
const paramValue = handlerInfo.parameters[paramName] const paramValue = handlerInfo.parameters[paramName]
resolvedParams[paramName] = () => mustache.render(paramValue, state) resolvedParams[paramName] = () =>
renderTemplateString(paramValue, state)
} }
handlerInfo.parameters = resolvedParams handlerInfo.parameters = resolvedParams