2019-06-25 12:51:51 -04:00
|
|
|
package strings
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"html"
|
|
|
|
|
|
|
|
"github.com/MontFerret/ferret/pkg/runtime/core"
|
|
|
|
"github.com/MontFerret/ferret/pkg/runtime/values"
|
|
|
|
)
|
|
|
|
|
2020-08-07 21:49:29 -04:00
|
|
|
// ESCAPE_HTML escapes special characters like "<" to become "<". It
|
2019-06-25 12:51:51 -04:00
|
|
|
// escapes only five such characters: <, >, &, ' and ".
|
|
|
|
// UnescapeString(EscapeString(s)) == s always holds, but the converse isn't
|
|
|
|
// always true.
|
2020-08-07 21:49:29 -04:00
|
|
|
// @param {String} uri - Uri to escape.
|
|
|
|
// @return {String} - Escaped string.
|
2019-06-25 12:51:51 -04:00
|
|
|
func EscapeHTML(_ context.Context, args ...core.Value) (core.Value, error) {
|
|
|
|
err := core.ValidateArgs(args, 1, 1)
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return values.None, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return values.NewString(html.EscapeString(args[0].String())), nil
|
|
|
|
}
|