當前位置: 首頁>>代碼示例>>Java>>正文


Java UnsafeSanitizedContentOrdainer類代碼示例

本文整理匯總了Java中com.google.template.soy.data.UnsafeSanitizedContentOrdainer的典型用法代碼示例。如果您正苦於以下問題:Java UnsafeSanitizedContentOrdainer類的具體用法?Java UnsafeSanitizedContentOrdainer怎麽用?Java UnsafeSanitizedContentOrdainer使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


UnsafeSanitizedContentOrdainer類屬於com.google.template.soy.data包,在下文中一共展示了UnsafeSanitizedContentOrdainer類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: getTemplateData

import com.google.template.soy.data.UnsafeSanitizedContentOrdainer; //導入依賴的package包/類
static SoyMapData getTemplateData(String canonicalURL, String cdnPath, String faviconPath)
    throws URISyntaxException {
  String canonicalPath = computeCanonicalPath(canonicalURL);

  String staticPath = "";
  if (cdnPath != null) {
    staticPath = cdnPath;
  } else if (canonicalPath != null) {
    staticPath = canonicalPath;
  }

  // The resource path must be typed as safe for use in a script src.
  // TODO(wyatta): Upgrade this to use an appropriate safe URL type.
  SanitizedContent sanitizedStaticPath =
      UnsafeSanitizedContentOrdainer.ordainAsSafe(
          staticPath, SanitizedContent.ContentKind.TRUSTED_RESOURCE_URI);

  return new SoyMapData(
      "canonicalPath", canonicalPath,
      "staticResourcePath", sanitizedStaticPath,
      "faviconPath", faviconPath);
}
 
開發者ID:gerrit-review,項目名稱:gerrit,代碼行數:23,代碼來源:IndexServlet.java

示例2: strictContinuation

import com.google.template.soy.data.UnsafeSanitizedContentOrdainer; //導入依賴的package包/類
/**
 * Return a {@link SanitizedContent} valued continuation. Rendering logic is delegated to the
 * {@link WriteContinuation}, but it is assumed that the builder is the render target.
 */
static Continuation<SanitizedContent> strictContinuation(
    WriteContinuation delegate,
    final StringBuilder buffer,
    OutputAppendable appendable,
    final ContentKind kind) {
  if (delegate.result().isDone()) {
    return new ResultContinuation<>(
        UnsafeSanitizedContentOrdainer.ordainAsSafe(buffer.toString(), kind));
  }
  return new AbstractContinuation<SanitizedContent>(delegate, appendable) {
    @Override
    Continuation<SanitizedContent> nextContinuation(WriteContinuation next) {
      return strictContinuation(next, buffer, appendable, kind);
    }
  };
}
 
開發者ID:google,項目名稱:closure-templates,代碼行數:21,代碼來源:Continuations.java

示例3: render

import com.google.template.soy.data.UnsafeSanitizedContentOrdainer; //導入依賴的package包/類
@Override
public RenderResult render(LoggingAdvisingAppendable appendable, RenderContext context)
    throws IOException {
  RenderResult result = delegate.render(buffer, context);
  if (result.isDone()) {
    SoyValue resultData =
        kind == null
            ? StringData.forValue(buffer.toString())
            : UnsafeSanitizedContentOrdainer.ordainAsSafe(buffer.toString(), kind);
    for (SoyJavaPrintDirective directive : directives) {
      resultData = directive.applyForJava(resultData, ImmutableList.<SoyValue>of());
    }
    appendable.append(resultData.coerceToString());
  }
  return result;
}
 
開發者ID:google,項目名稱:closure-templates,代碼行數:17,代碼來源:JbcSrcRuntime.java

示例4: getResolvedValue

import com.google.template.soy.data.UnsafeSanitizedContentOrdainer; //導入依賴的package包/類
private SoyString getResolvedValue() {
  SoyString local = resolvedValue;
  if (local == null) {
    if (buffer != null) {
      String string = buffer.toString();
      // This drops logs, but that is sometimes necessary.  We should make sure this only happens
      // when it has to by making sure that renderAndResolve is used for all printing usecases
      if (contentKind != null) {
        local = UnsafeSanitizedContentOrdainer.ordainAsSafe(string, contentKind);
      } else {
        local = StringData.forValue(string);
      }
      resolvedValue = local;
    } else {
      throw new AssertionError("getResolvedValue() should only be called if the value isDone.");
    }
  }
  return local;
}
 
開發者ID:google,項目名稱:closure-templates,代碼行數:20,代碼來源:DetachableContentProvider.java

示例5: renderStrict

import com.google.template.soy.data.UnsafeSanitizedContentOrdainer; //導入依賴的package包/類
@Override
public SanitizedContent renderStrict() {
  StringBuilder sb = new StringBuilder();
  TemplateNode template =
      baseTofu.renderMain(
          sb,
          templateName,
          data,
          ijData,
          activeDelPackageNames,
          msgBundle,
          idRenamingMap,
          cssRenamingMap,
          debugSoyTemplateInfo);
  enforceContentKind(template);
  // Use the expected instead of actual content kind; that way, if an HTML template is rendered
  // as TEXT, we will return TEXT.
  return UnsafeSanitizedContentOrdainer.ordainAsSafe(sb.toString(), expectedContentKind);
}
 
開發者ID:google,項目名稱:closure-templates,代碼行數:20,代碼來源:BaseTofu.java

示例6: escapeHtml

import com.google.template.soy.data.UnsafeSanitizedContentOrdainer; //導入依賴的package包/類
public static SanitizedContent escapeHtml(SoyValue value) {
  if (value == null) {
    // jbcsrc uses null as null.
    value = NullData.INSTANCE;
  }
  Dir valueDir = null;
  if (value instanceof SanitizedContent) {
    SanitizedContent sanitizedContent = (SanitizedContent) value;
    if (sanitizedContent.getContentKind() == SanitizedContent.ContentKind.HTML) {
      return (SanitizedContent) value;
    }
    valueDir = sanitizedContent.getContentDirection();
  }
  return UnsafeSanitizedContentOrdainer.ordainAsSafe(
      EscapingConventions.EscapeHtml.INSTANCE.escape(value.coerceToString()),
      SanitizedContent.ContentKind.HTML,
      valueDir);
}
 
開發者ID:google,項目名稱:closure-templates,代碼行數:19,代碼來源:CoreDirectivesRuntime.java

示例7: changeNewlineToBr

import com.google.template.soy.data.UnsafeSanitizedContentOrdainer; //導入依賴的package包/類
public static SoyString changeNewlineToBr(SoyValue value) {
  String result = NEWLINE_PATTERN.matcher(coerceToString(value)).replaceAll("<br>");

  // Make sure to transmit the known direction, if any, to any downstream directive that may need
  // it, e.g. BidiSpanWrapDirective. Since a known direction is carried only by SanitizedContent,
  // and the transformation we make is only valid in HTML, we only transmit the direction when we
  // get HTML SanitizedContent.
  // TODO(user): Consider always returning HTML SanitizedContent.
  if (value instanceof SanitizedContent) {
    SanitizedContent sanitizedContent = (SanitizedContent) value;
    if (sanitizedContent.getContentKind() == ContentKind.HTML) {
      return UnsafeSanitizedContentOrdainer.ordainAsSafe(
          result, ContentKind.HTML, sanitizedContent.getContentDirection());
    }
  }
  return StringData.forValue(result);
}
 
開發者ID:google,項目名稱:closure-templates,代碼行數:18,代碼來源:BasicDirectivesRuntime.java

示例8: insertWordBreaks

import com.google.template.soy.data.UnsafeSanitizedContentOrdainer; //導入依賴的package包/類
public static SoyString insertWordBreaks(SoyValue value, int maxCharsBetweenWordBreaks) {
  String result =
      new InsertWordBreaks(maxCharsBetweenWordBreaks).processString(coerceToString(value));

  // Make sure to transmit the known direction, if any, to any downstream directive that may need
  // it, e.g. BidiSpanWrapDirective. Since a known direction is carried only by SanitizedContent,
  // and the transformation we make is only valid in HTML, we only transmit the direction when we
  // get HTML SanitizedContent.
  // TODO(user): Consider always returning HTML SanitizedContent.
  if (value instanceof SanitizedContent) {
    SanitizedContent sanitizedContent = (SanitizedContent) value;
    if (sanitizedContent.getContentKind() == ContentKind.HTML) {
      return UnsafeSanitizedContentOrdainer.ordainAsSafe(
          result, ContentKind.HTML, sanitizedContent.getContentDirection());
    }
  }

  return StringData.forValue(result);
}
 
開發者ID:google,項目名稱:closure-templates,代碼行數:20,代碼來源:BasicDirectivesRuntime.java

示例9: testEscapeJsValue

import com.google.template.soy.data.UnsafeSanitizedContentOrdainer; //導入依賴的package包/類
@Test
public void testEscapeJsValue() {
  assertEquals( // Adds quotes.
      "'Don\\x27t run with \\x22scissors\\x22.\\n'",
      Sanitizers.escapeJsValue("Don't run with \"scissors\".\n"));
  assertEquals( // SoyValue version does the same as String version.
      "'Don\\x27t run with \\x22scissors\\x22.\\n'",
      Sanitizers.escapeJsValue(StringData.forValue("Don't run with \"scissors\".\n")));
  assertEquals(" 4.0 ", Sanitizers.escapeJsValue(IntegerData.forValue(4)));
  assertEquals(" 4.5 ", Sanitizers.escapeJsValue(FloatData.forValue(4.5)));
  assertEquals(" true ", Sanitizers.escapeJsValue(BooleanData.TRUE));
  assertEquals(" null ", Sanitizers.escapeJsValue(NullData.INSTANCE));
  assertEquals(
      "foo() + bar",
      Sanitizers.escapeJsValue(
          UnsafeSanitizedContentOrdainer.ordainAsSafe(
              "foo() + bar", SanitizedContent.ContentKind.JS)));
  // Wrong content kind should be wrapped in a string.
  assertEquals(
      "'foo() + bar'",
      Sanitizers.escapeJsValue(
          UnsafeSanitizedContentOrdainer.ordainAsSafe(
              "foo() + bar", SanitizedContent.ContentKind.HTML)));
}
 
開發者ID:google,項目名稱:closure-templates,代碼行數:25,代碼來源:SanitizersTest.java

示例10: testCleanHtml

import com.google.template.soy.data.UnsafeSanitizedContentOrdainer; //導入依賴的package包/類
@Test
public void testCleanHtml() {
  assertEquals(
      UnsafeSanitizedContentOrdainer.ordainAsSafe("<em>foo</em>", ContentKind.HTML),
      Sanitizers.cleanHtml("<em>f<object>oo</em>"));
  assertEquals(
      UnsafeSanitizedContentOrdainer.ordainAsSafe("<em>foo</em>", ContentKind.HTML),
      Sanitizers.cleanHtml(StringData.forValue("<em>f<object>oo</em>")));
  assertEquals(
      UnsafeSanitizedContentOrdainer.ordainAsSafe("<em>foo</em>", ContentKind.HTML, Dir.LTR),
      Sanitizers.cleanHtml(
          UnsafeSanitizedContentOrdainer.ordainAsSafe("<em>f<object>oo</em>", ContentKind.CSS)));

  // Input of ContentKind.HTML is left alone.
  assertEquals(
      UnsafeSanitizedContentOrdainer.ordainAsSafe("<script>notevil()</script>", ContentKind.HTML),
      Sanitizers.cleanHtml(
          UnsafeSanitizedContentOrdainer.ordainAsSafe(
              "<script>notevil()</script>", ContentKind.HTML)));
}
 
開發者ID:google,項目名稱:closure-templates,代碼行數:21,代碼來源:SanitizersTest.java

示例11: testApplyForTofu

import com.google.template.soy.data.UnsafeSanitizedContentOrdainer; //導入依賴的package包/類
@Test
public void testApplyForTofu() {

  NoAutoescapeDirective noAutoescapeDirective = new NoAutoescapeDirective();
  assertTofuOutput("", "", noAutoescapeDirective);
  assertTofuOutput("identName", "identName", noAutoescapeDirective);
  assertTofuOutput("<b>rich text</b>", "<b>rich text</b>", noAutoescapeDirective);
  assertTofuOutput(
      "not.html { font-name: \"Arial\" 'Helvetica' }",
      "not.html { font-name: \"Arial\" 'Helvetica' }",
      noAutoescapeDirective);
  // Explicitly reject "text".
  assertTofuOutput(
      "zSoyz",
      UnsafeSanitizedContentOrdainer.ordainAsSafe("xyz", SanitizedContent.ContentKind.TEXT),
      noAutoescapeDirective);
}
 
開發者ID:google,項目名稱:closure-templates,代碼行數:18,代碼來源:NoAutoescapeDirectiveTest.java

示例12: testEscapeUri

import com.google.template.soy.data.UnsafeSanitizedContentOrdainer; //導入依賴的package包/類
@Test
public final void testEscapeUri() {
  BasicEscapeDirective escapeUri = new BasicEscapeDirective.EscapeUri();
  assertTofuOutput("", "", escapeUri);
  assertTofuOutput("a%25b%20%3E%20c", "a%b > c", escapeUri);
  assertTofuOutput(
      "a%25bc%20%3E%20d",
      UnsafeSanitizedContentOrdainer.ordainAsSafe("a%bc > d", SanitizedContent.ContentKind.HTML),
      escapeUri);
  // NOTE: URIs are not treated specially (e.g. /redirect?continue={$url} should not allow $url
  // to break out and add other query params, and would be unexpected.)
  assertTofuOutput(
      "a%25bc%20%3E%20d",
      UnsafeSanitizedContentOrdainer.ordainAsSafe("a%bc > d", SanitizedContent.ContentKind.URI),
      escapeUri);

  new JsSrcPrintDirectiveTestBuilder()
      .addTest("", "''", escapeUri)
      .addTest("a%25b%20%3E%20c", " 'a%b > c' ", escapeUri)
      .addTest(
          "a%25bc%20%3E%20d", "soydata.VERY_UNSAFE.ordainSanitizedHtml('a%bc > d')", escapeUri)
      .addTest(
          "a%25bc%20%3E%20d", "soydata.VERY_UNSAFE.ordainSanitizedUri('a%bc > d')", escapeUri)
      .runTests();
}
 
開發者ID:google,項目名稱:closure-templates,代碼行數:26,代碼來源:BasicEscapeDirectiveTest.java

示例13: cleanHtml

import com.google.template.soy.data.UnsafeSanitizedContentOrdainer; //導入依賴的package包/類
/**
 * Normalizes the input HTML of a given directionality while preserving "safe" tags.
 *
 * @param optionalSafeTags to add to the basic whitelist of formatting safe tags
 * @return the normalized input, in the form of {@link SanitizedContent} of {@link
 *     ContentKind#HTML}
 */
public static SanitizedContent cleanHtml(
    String value, Dir contentDir, Collection<? extends OptionalSafeTag> optionalSafeTags) {
  return UnsafeSanitizedContentOrdainer.ordainAsSafe(
      stripHtmlTags(value, TagWhitelist.FORMATTING.withOptionalSafeTags(optionalSafeTags), true),
      ContentKind.HTML,
      contentDir);
}
 
開發者ID:google,項目名稱:closure-templates,代碼行數:15,代碼來源:Sanitizers.java

示例14: filterImageDataUri

import com.google.template.soy.data.UnsafeSanitizedContentOrdainer; //導入依賴的package包/類
/** Makes sure that the given input is a data URI corresponding to an image. */
public static SanitizedContent filterImageDataUri(String value) {
  if (EscapingConventions.FilterImageDataUri.INSTANCE.getValueFilter().matcher(value).find()) {
    // NOTE: No need to escape.
    return UnsafeSanitizedContentOrdainer.ordainAsSafe(value, ContentKind.URI);
  }
  logger.log(Level.WARNING, "|filterImageDataUri received bad value ''{0}''", value);
  return UnsafeSanitizedContentOrdainer.ordainAsSafe(
      EscapingConventions.FilterImageDataUri.INSTANCE.getInnocuousOutput(),
      SanitizedContent.ContentKind.URI);
}
 
開發者ID:google,項目名稱:closure-templates,代碼行數:12,代碼來源:Sanitizers.java

示例15: filterTelUri

import com.google.template.soy.data.UnsafeSanitizedContentOrdainer; //導入依賴的package包/類
/** Makes sure that the given input is a tel URI. */
public static SanitizedContent filterTelUri(String value) {
  if (EscapingConventions.FilterTelUri.INSTANCE.getValueFilter().matcher(value).find()) {
    // NOTE: No need to escape. Escaping for other contexts (e.g. HTML) happen after this.
    return UnsafeSanitizedContentOrdainer.ordainAsSafe(value, ContentKind.URI);
  }
  logger.log(Level.WARNING, "|filterTelUri received bad value ''{0}''", value);
  return UnsafeSanitizedContentOrdainer.ordainAsSafe(
      EscapingConventions.FilterTelUri.INSTANCE.getInnocuousOutput(),
      SanitizedContent.ContentKind.URI);
}
 
開發者ID:google,項目名稱:closure-templates,代碼行數:12,代碼來源:Sanitizers.java


注:本文中的com.google.template.soy.data.UnsafeSanitizedContentOrdainer類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。