Skip to content

Commit

Permalink
Sync docs from v3.8.10 to gh-pages
Browse files Browse the repository at this point in the history
  • Loading branch information
github-actions committed Oct 3, 2024
1 parent f713eba commit 475c972
Show file tree
Hide file tree
Showing 56 changed files with 50,177 additions and 0 deletions.
20 changes: 20 additions & 0 deletions 3.8.10/reference/html/Guardfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
require 'asciidoctor'
require 'erb'

guard 'shell' do
watch(/.*\.adoc$/) {|m|
Asciidoctor.render_file('index.adoc', \
:in_place => true, \
:safe => Asciidoctor::SafeMode::UNSAFE, \
:attributes=> { \
'source-highlighter' => 'prettify', \
'icons' => 'font', \
'linkcss'=> 'true', \
'copycss' => 'true', \
'doctype' => 'book'})
}
end

guard 'livereload' do
watch(%r{^.+\.(css|js|html)$})
end
957 changes: 957 additions & 0 deletions 3.8.10/reference/html/appendix.html

Large diffs are not rendered by default.

523 changes: 523 additions & 0 deletions 3.8.10/reference/html/bigquery.html

Large diffs are not rendered by default.

322 changes: 322 additions & 0 deletions 3.8.10/reference/html/cloudfoundry.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,322 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta name="generator" content="Asciidoctor 2.0.10">
<title>Cloud Foundry</title>
<link rel="stylesheet" href="css/site.css">
<script src="js/setup.js"></script><script defer src="js/site.js"></script>

<style>
.hidden {
display: none;
}

.switch {
border-width: 1px 1px 0 1px;
border-style: solid;
border-color: #7a2518;
display: inline-block;
}

.switch--item {
padding: 10px;
background-color: #ffffff;
color: #7a2518;
display: inline-block;
cursor: pointer;
}

.switch--item:not(:first-child) {
border-width: 0 0 0 1px;
border-style: solid;
border-color: #7a2518;
}

.switch--item.selected {
background-color: #7a2519;
color: #ffffff;
}

</style>
<script type="text/javascript">
function addBlockSwitches() {
for (var primary of document.querySelectorAll('.primary')) {
var switchItem = createSwitchItem(primary, createBlockSwitch(primary));
switchItem.item.classList.add("selected");
var title = primary.querySelector('.title')
title.remove();
}
for (var secondary of document.querySelectorAll('.secondary')) {
var primary = findPrimary(secondary);
if (primary === null) {
console.error("Found secondary block with no primary sibling");
}
else {
var switchItem = createSwitchItem(secondary, primary.querySelector('.switch'));
switchItem.content.classList.add("hidden");
primary.append(switchItem.content);
secondary.remove();
}
}
}

function createElementFromHtml(html) {
var template = document.createElement('template');
template.innerHTML = html;
return template.content.firstChild;
}

function createBlockSwitch(primary) {
var blockSwitch = createElementFromHtml('<div class="switch"></div>');
primary.prepend(blockSwitch)
return blockSwitch;
}

function findPrimary(secondary) {
var candidate = secondary.previousElementSibling;
while (candidate != null && !candidate.classList.contains('primary')) {
candidate = candidate.previousElementSibling;
}
return candidate;
}

function createSwitchItem(block, blockSwitch) {
var blockName = block.querySelector('.title').textContent;
var content = block.querySelectorAll('.content').item(0);
var colist = nextSibling(block, '.colist');
if (colist != null) {
content.append(colist);
}
var item = createElementFromHtml('<div class="switch--item">' + blockName + '</div>');
item.dataset.blockName = blockName;
content.dataset.blockName = blockName;
blockSwitch.append(item);
return {'item': item, 'content': content};
}

function nextSibling(element, selector) {
var sibling = element.nextElementSibling;
while (sibling) {
if (sibling.matches(selector)) {
return sibling;
}
sibling = sibling.nextElementSibling;
}
}

function globalSwitch() {
document.querySelectorAll(".switch--item").forEach(function(item) {
var blockId = blockIdForSwitchItem(item);
var handler = function(event) {
selectedText = event.target.textContent;
window.localStorage.setItem(blockId, selectedText);
for (var switchItem of document.querySelectorAll(".switch--item")) {
if (blockIdForSwitchItem(switchItem) === blockId && switchItem.textContent === selectedText) {
select(switchItem);
}
}
}
item.addEventListener("click", handler);
if (item.textContent === window.localStorage.getItem(blockId)) {
select(item);
}
});
}

function select(selected) {
for (var child of selected.parentNode.children) {
child.classList.remove("selected");
}
selected.classList.add("selected");
for (var child of selected.parentNode.parentNode.children) {
if (child.classList.contains("content")) {
if (selected.dataset.blockName === child.dataset.blockName) {
child.classList.remove("hidden");
}
else {
child.classList.add("hidden");
}
}
}
}

function blockIdForSwitchItem(item) {
idComponents = []
for (var switchItem of item.parentNode.querySelectorAll(".switch--item")) {
idComponents.push(switchItem.textContent.toLowerCase());
}
return idComponents.sort().join("-")
}

window.onload = function() {
addBlockSwitches();
globalSwitch();
};

</script>

</head>
<body class="book toc2 toc-left"><div id="banner-container" class="container" role="banner">
<div id="banner" class="contained" role="banner">
<div id="switch-theme">
<input type="checkbox" id="switch-theme-checkbox" />
<label for="switch-theme-checkbox">Dark Theme</label>
</div>
</div>
</div>
<div id="tocbar-container" class="container" role="navigation">
<div id="tocbar" class="contained" role="navigation">
<button id="toggle-toc"></button>
</div>
</div>
<div id="main-container" class="container">
<div id="main" class="contained">
<div id="doc" class="doc">
<div id="header">
<div id="toc" class="toc2">
<div id="toctitle">Table of Contents</div>
<span id="back-to-index"><a href="${index-link}">Back to index</a></span><ul class="sectlevel1">
<li><a href="#_cloud_foundry">Cloud Foundry</a>
<ul class="sectlevel2">
<li><a href="#_user_provided_services">User-Provided Services</a></li>
</ul>
</li>
</ul>
</div>
</div>
<div id="content">
<div class="sect1">
<h2 id="_cloud_foundry"><a class="anchor" href="#_cloud_foundry"></a><a class="link" href="#_cloud_foundry">Cloud Foundry</a></h2>
<div class="sectionbody">
<div class="paragraph">
<p>Spring Framework on Google Cloud provides support for Cloud Foundry&#8217;s <a href="https://docs.pivotal.io/partners/gcp-sb/index.html">GCP Service Broker</a>.
Our Pub/Sub, Cloud Spanner, Storage, Cloud Trace and Cloud SQL MySQL and PostgreSQL starters are Cloud Foundry aware and retrieve properties like project ID, credentials, etc., that are used in auto configuration from the Cloud Foundry environment.</p>
</div>
<div class="paragraph">
<p>In order to take advantage of the Cloud Foundry support make sure the following dependency is added:</p>
</div>
<div class="listingblock">
<div class="content">
<pre class="highlight"><code class="language-xml" data-lang="xml">&lt;dependency&gt;
&lt;groupId&gt;com.google.cloud&lt;/groupId&gt;
&lt;artifactId&gt;spring-cloud-gcp-starter-cloudfoundry&lt;/artifactId&gt;
&lt;/dependency&gt;</code></pre>
</div>
</div>
<div class="paragraph">
<p>In cases like Pub/Sub&#8217;s topic and subscription, or Storage&#8217;s bucket name, where those parameters are not used in auto configuration, you can fetch them using the VCAP mapping provided by Spring Boot.
For example, to retrieve the provisioned Pub/Sub topic, you can use the <code>vcap.services.mypubsub.credentials.topic_name</code> property from the application environment.</p>
</div>
<div class="admonitionblock note">
<table>
<tr>
<td class="icon">
<i class="fa icon-note" title="Note"></i>
</td>
<td class="content">
If the same service is bound to the same application more than once, the auto configuration will not be able to choose among bindings and will not be activated for that service.
This includes both MySQL and PostgreSQL bindings to the same app.
</td>
</tr>
</table>
</div>
<div class="admonitionblock warning">
<table>
<tr>
<td class="icon">
<i class="fa icon-warning" title="Warning"></i>
</td>
<td class="content">
In order for the Cloud SQL integration to work in Cloud Foundry, auto-reconfiguration must be disabled.
You can do so using the <code>cf set-env &lt;APP&gt; JBP_CONFIG_SPRING_AUTO_RECONFIGURATION '{enabled: false}'</code> command.
Otherwise, Cloud Foundry will produce a <code>DataSource</code> with an invalid JDBC URL (i.e., <code>jdbc:mysql://null/null</code>).
</td>
</tr>
</table>
</div>
<div class="sect2">
<h3 id="_user_provided_services"><a class="anchor" href="#_user_provided_services"></a><a class="link" href="#_user_provided_services">User-Provided Services</a></h3>
<div class="paragraph">
<p><a href="https://docs.cloudfoundry.org/devguide/services/user-provided.html">User-provided services</a> enable developers to use services that are not available in the marketplace with their apps running on Cloud Foundry.
For example, you may want to use a user-provided service that points to a shared Google Service (like Cloud Spanner) used across your organization.</p>
</div>
<div class="paragraph">
<p>In order for Spring Framework on Google Cloud to detect your user-provided service as a Google Cloud Service, you must add an <a href="https://docs.cloudfoundry.org/devguide/services/managing-services.html#instance-tags-create">instance tag</a> indicating the Google Cloud Service it uses.
The tag should simply be the Cloud Foundry name for the Google Service.</p>
</div>
<div class="paragraph">
<p>For example, if you create a user-provided service using Cloud Spanner, you might run:</p>
</div>
<div class="listingblock">
<div class="content">
<pre class="highlight"><code class="language-shell" data-lang="shell">$ cf create-user-provided-service user-spanner-service -t "google-spanner" ...</code></pre>
</div>
</div>
<div class="paragraph">
<p>This allows Spring Framework on Google Cloud to retrieve the correct service properties from Cloud Foundry and use them in the auto configuration for your application.</p>
</div>
<div class="paragraph">
<p>A mapping of Google service names to Cloud Foundry names are provided below:</p>
</div>
<table class="tableblock frame-all grid-all stretch">
<colgroup>
<col style="width: 50%;">
<col style="width: 50%;">
</colgroup>
<tbody>
<tr>
<td class="tableblock halign-left valign-top"><p class="tableblock">Google Cloud Service</p></td>
<td class="tableblock halign-left valign-top"><p class="tableblock">Cloud Foundry Name (add this as a tag)</p></td>
</tr>
<tr>
<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="https://cloud.google.com/pubsub">Google Cloud Pub/Sub</a></p></td>
<td class="tableblock halign-left valign-top"><p class="tableblock"><code>google-pubsub</code></p></td>
</tr>
<tr>
<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="https://cloud.google.com/storage">Google Cloud Storage</a></p></td>
<td class="tableblock halign-left valign-top"><p class="tableblock"><code>google-storage</code></p></td>
</tr>
<tr>
<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="https://cloud.google.com/spanner">Google Cloud Spanner</a></p></td>
<td class="tableblock halign-left valign-top"><p class="tableblock"><code>google-spanner</code></p></td>
</tr>
<tr>
<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="https://cloud.google.com/datastore">Datastore</a></p></td>
<td class="tableblock halign-left valign-top"><p class="tableblock"><code>google-datastore</code></p></td>
</tr>
<tr>
<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="https://cloud.google.com/firestore">Firestore</a></p></td>
<td class="tableblock halign-left valign-top"><p class="tableblock"><code>google-firestore</code></p></td>
</tr>
<tr>
<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="https://cloud.google.com/bigquery">BigQuery</a></p></td>
<td class="tableblock halign-left valign-top"><p class="tableblock"><code>google-bigquery</code></p></td>
</tr>
<tr>
<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="https://cloud.google.com/products/operations">Cloud Trace</a></p></td>
<td class="tableblock halign-left valign-top"><p class="tableblock"><code>google-stackdriver-trace</code></p></td>
</tr>
<tr>
<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="https://cloud.google.com/sql">Cloud Sql (MySQL)</a></p></td>
<td class="tableblock halign-left valign-top"><p class="tableblock"><code>google-cloudsql-mysql</code></p></td>
</tr>
<tr>
<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="https://cloud.google.com/sql">Cloud Sql (PostgreSQL)</a></p></td>
<td class="tableblock halign-left valign-top"><p class="tableblock"><code>google-cloudsql-postgres</code></p></td>
</tr>
</tbody>
</table>
</div>
</div>
</div>
</div>
<script src="js/highlight/highlight.min.js"></script>
<script>hljs.initHighlighting()</script>
</div>
</div>
</div>
</body>
</html>
Loading

0 comments on commit 475c972

Please sign in to comment.