Author: gaul
Date: Fri Aug 14 20:25:18 2015
New Revision: 1695982
URL: http://svn.apache.org/r1695982
Log:
deploy jclouds site content
Added:
jclouds/site-content/blog/2014/08/04/
jclouds/site-content/blog/2014/08/04/1-release-2-committers/
jclouds/site-content/blog/2014/08/04/1-release-2-committers/index.html
jclouds/site-content/blog/2014/09/03/
jclouds/site-content/blog/2014/09/03/better-builders/
jclouds/site-content/blog/2014/09/03/better-builders/index.html
Removed:
jclouds/site-content/blog/2014/08/05/
jclouds/site-content/blog/2014/09/04/
Modified:
jclouds/site-content/blog/atom.xml
jclouds/site-content/blog/index.html
jclouds/site-content/guides/hpcloud/index.html
jclouds/site-content/guides/profitbricks/index.html
jclouds/site-content/releasenotes/atom.xml
Added: jclouds/site-content/blog/2014/08/04/1-release-2-committers/index.html
URL:
http://svn.apache.org/viewvc/jclouds/site-content/blog/2014/08/04/1-release-2-committers/index.html?rev=1695982&view=auto
==============================================================================
--- jclouds/site-content/blog/2014/08/04/1-release-2-committers/index.html
(added)
+++ jclouds/site-content/blog/2014/08/04/1-release-2-committers/index.html Fri
Aug 14 20:25:18 2015
@@ -0,0 +1,239 @@
+<!DOCTYPE html>
+<html lang="en">
+ <head>
+ <meta charset="utf-8">
+<title>Apache jclouds® :: 1 release, 2 committers...a busy week for
jclouds!</title>
+<meta name="viewport" content="width=device-width, initial-scale=1.0">
+<meta name="description" content="">
+<meta name="author" content="">
+
+<!--link rel="stylesheet/less" href="less/bootstrap.less" type="text/css" /-->
+<!--link rel="stylesheet/less" href="less/responsive.less" type="text/css" /-->
+<!--script src="js/less-1.3.3.min.js"></script-->
+<!--append â#!watchâ to the browser URL, then refresh the page. -->
+
+<link href="/css/bootstrap.min.css" rel="stylesheet">
+<link href="/css/style.css" rel="stylesheet">
+<link href="/css/syntax.css" rel="stylesheet">
+
+<!-- HTML5 shim, for IE6-8 support of HTML5 elements -->
+<!--[if lt IE 9]>
+<script src="js/html5shiv.js"></script>
+<![endif]-->
+
+<!-- Fav and touch icons -->
+<!--
+<link rel="apple-touch-icon-precomposed" sizes="144x144"
href="/img/apple-touch-icon-144-precomposed.png">
+<link rel="apple-touch-icon-precomposed" sizes="114x114"
href="/img/apple-touch-icon-114-precomposed.png">
+<link rel="apple-touch-icon-precomposed" sizes="72x72"
href="/img/apple-touch-icon-72-precomposed.png">
+<link rel="apple-touch-icon-precomposed"
href="/img/apple-touch-icon-57-precomposed.png">
+-->
+<link rel="shortcut icon" href="/favicon.ico">
+
+<link rel="alternate" type="application/atom+xml" href="/blog/atom.xml"
title="Blog Posts Feed">
+<link rel="alternate" type="application/atom+xml"
href="/releasenotes/atom.xml" title="Release Notes Feed">
+
+<script type="text/javascript" src="/js/jquery.min.js"></script>
+<script type="text/javascript" src="/js/bootstrap.min.js"></script>
+<script type="text/javascript" src="/js/toc.js"></script>
+
+<script type="text/javascript">
+ var _gaq = _gaq || [];
+ _gaq.push(['_setAccount', 'UA-8638379-1']);
+ _gaq.push(['_trackPageview']);
+
+ (function() {
+ var ga = document.createElement('script'); ga.type = 'text/javascript';
ga.async = true;
+ ga.src = ('https:' == document.location.protocol ? 'https://ssl' :
'http://www') + '.google-analytics.com/ga.js';
+ var s = document.getElementsByTagName('script')[0];
s.parentNode.insertBefore(ga, s);
+ })();
+</script>
+<script type="text/javascript">
+
(function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
+ (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new
Date();a=s.createElement(o),
+
m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
+
})(window,document,'script','//www.google-analytics.com/analytics.js','ga');
+
+ ga('create', 'UA-47106724-1', 'jclouds.apache.org');
+ ga('send', 'pageview');
+</script>
+
+ </head>
+ <body>
+ <nav class="navbar navbar-default navbar-fixed-top" role="navigation">
+ <div class="container">
+ <div class="navbar-header">
+ <button type="button" class="navbar-toggle" data-toggle="collapse"
data-target="#bs-example-navbar-collapse-1">
+ <span class="sr-only">Toggle navigation</span>
+ <span class="icon-bar"></span>
+ <span class="icon-bar"></span>
+ <span class="icon-bar"></span>
+ </button>
+ <a class="navbar-brand" href="/">Apache jclouds ®</a>
+ </div>
+
+ <div class="collapse navbar-collapse"
id="bs-example-navbar-collapse-1">
+ <ul class="nav navbar-nav">
+ <li class="dropdown">
+ <a href="#" class="dropdown-toggle"
data-toggle="dropdown">Getting Started<strong class="caret"></strong></a>
+ <ul class="dropdown-menu">
+ <li><a href="/start/what-is-jclouds/">What Is Apache
jclouds?</a></li>
+ <li><a href="/start/install/">Installation
Guide</a></li>
+ <li class="divider"></li>
+ <li><a href="/start/concepts/">Core Concepts</a></li>
+ <li><a href="/start/compute/">ComputeService</a></li>
+ <li><a href="/start/blobstore/">BlobStore</a></li>
+ <li><a
href="http://github.com/jclouds/jclouds-examples">Examples</a></li>
+ </ul>
+ </li>
+ <li class="dropdown">
+ <a href="#" class="dropdown-toggle"
data-toggle="dropdown">Documentation<strong class="caret"></strong></a>
+ <ul class="dropdown-menu">
+ <li><a href="/reference/providers/">Cloud
Providers</a></li>
+ <li><a href="/guides">User Guides</a></li>
+ <li><a
href="/reference/troubleshooting/">Troubleshooting</a></li>
+ <li><a
href="/reference/configuration/">Configuration</a></li>
+ <li><a href="/reference/logging/">Logging</a></li>
+ <li><a href="/reference/javadoc/">Javadoc</a></li>
+ <li class="divider"></li>
+ <li class="dropdown-header">Developer Guides</li>
+ <li><a
href="https://cwiki.apache.org/confluence/display/JCLOUDS/">Wiki</a></li>
+ </ul>
+ </li>
+ <li class="dropdown">
+ <a href="#" class="dropdown-toggle"
data-toggle="dropdown">Community<strong class="caret"></strong></a>
+ <ul class="dropdown-menu">
+ <li><a href="/community/">Get In Touch!</a></li>
+ <li><a href="http://www.meetup.com/jclouds/">Attend An
Event</a></li>
+ <li><a href="/community/users/">Who Is Using
jclouds?</a></li>
+ <li class="divider"></li>
+ <li class="dropdown-header">Contribute</li>
+ <li><a href="/reference/report-a-bug/">Report a
Bug</a></li>
+ <li><a
href="http://jclouds.ci.cloudbees.com">Continuous Integration</a></li>
+ <li><a
href="https://cwiki.apache.org/confluence/display/JCLOUDS/How+to+Contribute">How
To Contribute Code</a></li>
+ <li><a
href="https://cwiki.apache.org/confluence/display/JCLOUDS/How+to+Contribute+Documentation">How
To Contribute Documentation</a></li>
+ </ul>
+ </li>
+ <li><a href="/blog">Blog</a></li>
+ </ul>
+ <ul class="nav navbar-nav navbar-right">
+ <li class="dropdown">
+ <a href="#" class="dropdown-toggle"
data-toggle="dropdown">Release Notes<strong class="caret"></strong></a>
+ <ul class="dropdown-menu">
+ <!-- only keep the release notes for supported
versions in this list -->
+ <li><a href="/releasenotes/1.9.1">1.9.1</a></li>
+ <li><a href="/releasenotes/1.9.0">1.9.0</a></li>
+ <li><a href="/releasenotes/1.8.1">1.8.1</a></li>
+ <li><a href="/releasenotes/1.8.0">1.8.0</a></li>
+ <li class="divider"></li>
+ <li class="dropdown-header">Previous releases</li>
+ <li><a href="/releasenotes">Release archive</a></li>
+ </ul>
+ </li>
+ <li>
+ <div>
+ <a class="btn btn-success navbar-btn"
href="/start/install/">
+ <span class="glyphicon glyphicon-download"></span>
+ Install
+ </a>
+ </div>
+ </li>
+ </ul>
+ </div>
+ </div>
+</nav>
+
+ <div class="container">
+ <div class="page-header">
+ <h1>1 release, 2 committers...a busy week for jclouds!</h1>
+ <span class="text-muted">04 August 2014, by <a
href="http://blog.xebialabs.com/author/aphillips/">Andrew Phillips</a></span>
+ </div>
+ <p><img class="img-right"
src="/img/posts/chris-and-andrea.png"/>There's a lot going on this week for the
jclouds community. Most importantly, we're really pleased to introduce two new
committers: Andrea Turli and Chris Custine.</p>
+
+<!--more-->
+
+
+<p><a href="https://twitter.com/turlinux">Andrea</a> has been involved with
jclouds for quite a while, working previously on the libvirt and vSphere <a
href="/start/compute/">compute</a> providers. He's recently brought SoftLayer
support up to speed and contributed the new <a href="/guides/docker/">Docker
provider</a>, which is a really exciting addition.</p>
+
+<p><a href="https://twitter.com/ccustine">Chris</a> also has a lot of prior
experience with many areas of jclouds, including <a
href="/guides/chef/">Chef</a> and <a href="/guides/karaf/">Karaf</a>, as well
as contributing to a number of projects in the surrounding ecosystem. He's
recently worked on <a href="/guides/openstack">OpenStack</a>, especially on
getting <a href="/guides/hpcloud/">HP Cloud</a>'s compute and blobstore
providers back in shape.</p>
+
+<p>Both Andrea and Chris have been active in the jclouds community too,
regularly contributing to discussions and helping to answer questions on the
mailing lists and IRC. We're very glad to have both on board!</p>
+
+<p>In other news: we've been busy <a
href="http://markmail.org/thread/7ixght2jgfbu73ok">getting the 1.8.0 release
ready</a>, which (advance warning here!) will be the last jclouds release to
support Java 6. More details to come once the release has been
finalized...watch this space!</p>
+
+
+ <div id="comments">
+ <hr/>
+ <div id="disqus_thread"></div>
+<script type="text/javascript">
+var disqus_shortname = 'jclouds';
+/* * * DON'T EDIT BELOW THIS LINE * * */
+(function() {
+ var dsq = document.createElement('script'); dsq.type = 'text/javascript';
dsq.async = true;
+ dsq.src = '//' + disqus_shortname + '.disqus.com/embed.js';
+ (document.getElementsByTagName('head')[0] ||
document.getElementsByTagName('body')[0]).appendChild(dsq);
+})();
+</script>
+<noscript>Please enable JavaScript to view the <a
href="http://disqus.com/?ref_noscript">Comments powered by
Disqus.</a></noscript>
+<a href="http://disqus.com" class="dsq-brlink">Comments powered by <span
class="logo-disqus">Disqus</span></a>
+
+ </div>
+
+ <div class="row clearfix">
+ <div id="footer" class="col-md-12 column">
+ <div id="footer">
+ <hr/>
+ <div class="row clearfix">
+ <div class="col-md-2 column">
+ <p class="text-center">
+ <a class="text-primary" href="/start/">Getting Started</a>
+ </p>
+ </div>
+ <div class="col-md-2 column">
+ <p class="text-center">
+ <a class="text-primary" href="/reference/report-a-bug/">Report
a Bug</a>
+ </p>
+ </div>
+ <div class="col-md-2 column">
+ <p class="text-center">
+ <a
href="https://github.com/jclouds/jclouds-site/edit/master/_posts/2014-08-04-1-release-2-committers.md">Fix
This Page</a><a class="text-primary"
href="https://cwiki.apache.org/confluence/display/JCLOUDS/How+to+Contribute+Documentation"><sup>*</sup></a>
+ </p>
+ </div>
+ <div class="col-md-2 column">
+ <p class="text-center">
+ <a class="text-primary"
href="https://cwiki.apache.org/confluence/display/JCLOUDS/How+to+Contribute">Contribute
Code</a>
+ </p>
+ </div>
+ <div class="col-md-2 column">
+ <p class="text-center">
+ <a class="text-primary" href="/community/">Contact Us</a>
+ </p>
+ </div>
+ <div class="col-md-2 column">
+ <p class="text-center">
+ <a class="text-primary"
href="https://twitter.com/jclouds">Follow Us</a>
+ </p>
+ </div>
+ </div>
+ <hr style="margin-top: 10px"/>
+ <div class="row clearfix">
+ <div class="col-md-12 column">
+ <p class="text-center">
+ Copyright © 2011-2014 <a href="http://www.apache.org">The
Apache Software Foundation</a>. All Rights Reserved.
+ </p>
+ <p class="text-center">
+ Apache, jclouds, Apache jclouds, the jclouds logo, and the
Apache feather logos are registered trademarks or trademarks of the Apache
Software Foundation.
+ </p>
+ <p class="text-center">
+ <img src="/img/feather-small.gif" width="80", height="24"/>
+ </p>
+ <br/>
+ </div>
+ </div>
+</div>
+
+ </div>
+ </div>
+ </div>
+ </body>
+</html>
Added: jclouds/site-content/blog/2014/09/03/better-builders/index.html
URL:
http://svn.apache.org/viewvc/jclouds/site-content/blog/2014/09/03/better-builders/index.html?rev=1695982&view=auto
==============================================================================
--- jclouds/site-content/blog/2014/09/03/better-builders/index.html (added)
+++ jclouds/site-content/blog/2014/09/03/better-builders/index.html Fri Aug 14
20:25:18 2015
@@ -0,0 +1,347 @@
+<!DOCTYPE html>
+<html lang="en">
+ <head>
+ <meta charset="utf-8">
+<title>Apache jclouds® :: Better Builders with jclouds!</title>
+<meta name="viewport" content="width=device-width, initial-scale=1.0">
+<meta name="description" content="">
+<meta name="author" content="">
+
+<!--link rel="stylesheet/less" href="less/bootstrap.less" type="text/css" /-->
+<!--link rel="stylesheet/less" href="less/responsive.less" type="text/css" /-->
+<!--script src="js/less-1.3.3.min.js"></script-->
+<!--append â#!watchâ to the browser URL, then refresh the page. -->
+
+<link href="/css/bootstrap.min.css" rel="stylesheet">
+<link href="/css/style.css" rel="stylesheet">
+<link href="/css/syntax.css" rel="stylesheet">
+
+<!-- HTML5 shim, for IE6-8 support of HTML5 elements -->
+<!--[if lt IE 9]>
+<script src="js/html5shiv.js"></script>
+<![endif]-->
+
+<!-- Fav and touch icons -->
+<!--
+<link rel="apple-touch-icon-precomposed" sizes="144x144"
href="/img/apple-touch-icon-144-precomposed.png">
+<link rel="apple-touch-icon-precomposed" sizes="114x114"
href="/img/apple-touch-icon-114-precomposed.png">
+<link rel="apple-touch-icon-precomposed" sizes="72x72"
href="/img/apple-touch-icon-72-precomposed.png">
+<link rel="apple-touch-icon-precomposed"
href="/img/apple-touch-icon-57-precomposed.png">
+-->
+<link rel="shortcut icon" href="/favicon.ico">
+
+<link rel="alternate" type="application/atom+xml" href="/blog/atom.xml"
title="Blog Posts Feed">
+<link rel="alternate" type="application/atom+xml"
href="/releasenotes/atom.xml" title="Release Notes Feed">
+
+<script type="text/javascript" src="/js/jquery.min.js"></script>
+<script type="text/javascript" src="/js/bootstrap.min.js"></script>
+<script type="text/javascript" src="/js/toc.js"></script>
+
+<script type="text/javascript">
+ var _gaq = _gaq || [];
+ _gaq.push(['_setAccount', 'UA-8638379-1']);
+ _gaq.push(['_trackPageview']);
+
+ (function() {
+ var ga = document.createElement('script'); ga.type = 'text/javascript';
ga.async = true;
+ ga.src = ('https:' == document.location.protocol ? 'https://ssl' :
'http://www') + '.google-analytics.com/ga.js';
+ var s = document.getElementsByTagName('script')[0];
s.parentNode.insertBefore(ga, s);
+ })();
+</script>
+<script type="text/javascript">
+
(function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
+ (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new
Date();a=s.createElement(o),
+
m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
+
})(window,document,'script','//www.google-analytics.com/analytics.js','ga');
+
+ ga('create', 'UA-47106724-1', 'jclouds.apache.org');
+ ga('send', 'pageview');
+</script>
+
+ </head>
+ <body>
+ <nav class="navbar navbar-default navbar-fixed-top" role="navigation">
+ <div class="container">
+ <div class="navbar-header">
+ <button type="button" class="navbar-toggle" data-toggle="collapse"
data-target="#bs-example-navbar-collapse-1">
+ <span class="sr-only">Toggle navigation</span>
+ <span class="icon-bar"></span>
+ <span class="icon-bar"></span>
+ <span class="icon-bar"></span>
+ </button>
+ <a class="navbar-brand" href="/">Apache jclouds ®</a>
+ </div>
+
+ <div class="collapse navbar-collapse"
id="bs-example-navbar-collapse-1">
+ <ul class="nav navbar-nav">
+ <li class="dropdown">
+ <a href="#" class="dropdown-toggle"
data-toggle="dropdown">Getting Started<strong class="caret"></strong></a>
+ <ul class="dropdown-menu">
+ <li><a href="/start/what-is-jclouds/">What Is Apache
jclouds?</a></li>
+ <li><a href="/start/install/">Installation
Guide</a></li>
+ <li class="divider"></li>
+ <li><a href="/start/concepts/">Core Concepts</a></li>
+ <li><a href="/start/compute/">ComputeService</a></li>
+ <li><a href="/start/blobstore/">BlobStore</a></li>
+ <li><a
href="http://github.com/jclouds/jclouds-examples">Examples</a></li>
+ </ul>
+ </li>
+ <li class="dropdown">
+ <a href="#" class="dropdown-toggle"
data-toggle="dropdown">Documentation<strong class="caret"></strong></a>
+ <ul class="dropdown-menu">
+ <li><a href="/reference/providers/">Cloud
Providers</a></li>
+ <li><a href="/guides">User Guides</a></li>
+ <li><a
href="/reference/troubleshooting/">Troubleshooting</a></li>
+ <li><a
href="/reference/configuration/">Configuration</a></li>
+ <li><a href="/reference/logging/">Logging</a></li>
+ <li><a href="/reference/javadoc/">Javadoc</a></li>
+ <li class="divider"></li>
+ <li class="dropdown-header">Developer Guides</li>
+ <li><a
href="https://cwiki.apache.org/confluence/display/JCLOUDS/">Wiki</a></li>
+ </ul>
+ </li>
+ <li class="dropdown">
+ <a href="#" class="dropdown-toggle"
data-toggle="dropdown">Community<strong class="caret"></strong></a>
+ <ul class="dropdown-menu">
+ <li><a href="/community/">Get In Touch!</a></li>
+ <li><a href="http://www.meetup.com/jclouds/">Attend An
Event</a></li>
+ <li><a href="/community/users/">Who Is Using
jclouds?</a></li>
+ <li class="divider"></li>
+ <li class="dropdown-header">Contribute</li>
+ <li><a href="/reference/report-a-bug/">Report a
Bug</a></li>
+ <li><a
href="http://jclouds.ci.cloudbees.com">Continuous Integration</a></li>
+ <li><a
href="https://cwiki.apache.org/confluence/display/JCLOUDS/How+to+Contribute">How
To Contribute Code</a></li>
+ <li><a
href="https://cwiki.apache.org/confluence/display/JCLOUDS/How+to+Contribute+Documentation">How
To Contribute Documentation</a></li>
+ </ul>
+ </li>
+ <li><a href="/blog">Blog</a></li>
+ </ul>
+ <ul class="nav navbar-nav navbar-right">
+ <li class="dropdown">
+ <a href="#" class="dropdown-toggle"
data-toggle="dropdown">Release Notes<strong class="caret"></strong></a>
+ <ul class="dropdown-menu">
+ <!-- only keep the release notes for supported
versions in this list -->
+ <li><a href="/releasenotes/1.9.1">1.9.1</a></li>
+ <li><a href="/releasenotes/1.9.0">1.9.0</a></li>
+ <li><a href="/releasenotes/1.8.1">1.8.1</a></li>
+ <li><a href="/releasenotes/1.8.0">1.8.0</a></li>
+ <li class="divider"></li>
+ <li class="dropdown-header">Previous releases</li>
+ <li><a href="/releasenotes">Release archive</a></li>
+ </ul>
+ </li>
+ <li>
+ <div>
+ <a class="btn btn-success navbar-btn"
href="/start/install/">
+ <span class="glyphicon glyphicon-download"></span>
+ Install
+ </a>
+ </div>
+ </li>
+ </ul>
+ </div>
+ </div>
+</nav>
+
+ <div class="container">
+ <div class="page-header">
+ <h1>Better Builders with jclouds!</h1>
+ <span class="text-muted">03 September 2014, by Zack
Shoylev</span>
+ </div>
+ <p>If you are a new <a href="jclouds.apache.org">jclouds</a>
developer, or even if you are already developing jclouds support for any of the
OpenStack or Rackspace APIs, you have likely seen the domain classes that are
used throughout the the jclouds codebase.
+These classes are used to represent OpenStack resources, particularly the JSON
structures supported by OpenStack APIs.</p>
+
+<!--more-->
+
+
+<p>For example, when listing database users in openstack-trove (the OpenStack
database API), the service returns a JSON response body describing the existing
users. This JSON might look something like this:</p>
+
+<div class="highlight"><pre><code class="json"><span class="p">{</span>
+ <span class="nt">"users"</span><span class="p">:</span> <span
class="p">[</span>
+ <span class="p">{</span>
+ <span class="nt">"databases"</span><span
class="p">:</span> <span class="p">[],</span>
+ <span class="nt">"host"</span><span class="p">:</span>
<span class="s2">"%"</span><span class="p">,</span>
+ <span class="nt">"name"</span><span class="p">:</span>
<span class="s2">"dbuser1"</span>
+ <span class="p">},</span>
+ <span class="p">{</span>
+ <span class="nt">"databases"</span><span
class="p">:</span> <span class="p">[</span>
+ <span class="p">{</span>
+ <span class="nt">"name"</span><span
class="p">:</span> <span class="s2">"databaseB"</span>
+ <span class="p">},</span>
+ <span class="p">{</span>
+ <span class="nt">"name"</span><span
class="p">:</span> <span class="s2">"databaseC"</span>
+ <span class="p">}</span>
+ <span class="p">],</span>
+ <span class="nt">"host"</span><span class="p">:</span>
<span class="s2">"%"</span><span class="p">,</span>
+ <span class="nt">"name"</span><span class="p">:</span>
<span class="s2">"dbuser2"</span>
+ <span class="p">},</span>
+ <span class="p">{</span>
+ <span class="nt">"databases"</span><span
class="p">:</span> <span class="p">[],</span>
+ <span class="nt">"name"</span><span class="p">:</span>
<span class="s2">"dbuser3"</span><span class="p">,</span>
+ <span class="nt">"host"</span><span class="p">:</span>
<span class="s2">"%"</span>
+ <span class="p">},</span>
+ <span class="p">{</span>
+ <span class="nt">"databases"</span><span
class="p">:</span> <span class="p">[</span>
+ <span class="p">{</span>
+ <span class="nt">"name"</span><span
class="p">:</span> <span class="s2">"sampledb"</span>
+ <span class="p">}</span>
+ <span class="p">],</span>
+ <span class="nt">"host"</span><span class="p">:</span>
<span class="s2">"%"</span><span class="p">,</span>
+ <span class="nt">"name"</span><span class="p">:</span>
<span class="s2">"demouser"</span>
+ <span class="p">}</span>
+ <span class="p">]</span>
+<span class="p">}</span>
+</code></pre></div>
+
+
+<p>To parse the response, jclouds uses <a
href="https://github.com/jclouds/jclouds/blob/master/apis/openstack-trove/src/main/java/org/jclouds/openstack/trove/v1/domain/User.java">domain
classes</a> to represent the JSON data returned by the service. The array of
"users" is unwrapped into individual User domain objects. Conversely, when
creating users, domain objects are transformed into a JSON request body.</p>
+
+<p>Because of the relative simplicity of user creation in trove, jclouds
developers can use a create method in the features package without having to
build an instance of the User class. For example, the developer might use a
method such as</p>
+
+<div class="highlight"><pre><code class="java"><span class="kt">boolean</span>
<span class="nf">create</span><span class="o">(</span><span
class="n">String</span> <span class="n">userName</span><span class="o">,</span>
<span class="n">String</span> <span class="n">password</span><span
class="o">,</span> <span class="n">String</span> <span
class="n">databaseName</span><span class="o">);</span>
+</code></pre></div>
+
+
+<p>In this case, it was easy to add support for this call by using a <a
href="https://github.com/jclouds/jclouds/blob/master/apis/openstack-trove/src/main/java/org/jclouds/openstack/trove/v1/binders/BindCreateUserToJson.java">map
binder</a>.</p>
+
+<p>However, some APIs send or receive significantly more complex JSON
structures. Recent work on Neutron has shown that there are benefits to
increased consistency among the domain classes and the OpenStack API calls that
use them.</p>
+
+<p>Current implementations have the following two issues :</p>
+
+<ol>
+<li>Heavy use of map-binders and parsers to transform JSON. Map-binders use
annotation-selected classes to map method data (such as the data in the
create-user call above) to the JSON required by the service. The <a
href="https://github.com/jclouds/jclouds-labs-openstack/blob/master/openstack-neutron/src/main/java/org/jclouds/openstack/neutron/v2_0/functions/ParseNetworkDetails.java">parsers</a>
apply the reverse transformation: from JSON to domain objects.</li>
+<li>Lack of consistent, concise, and user-friendly way to use domain objects
in create/update/list methods.</li>
+</ol>
+
+
+<p>In addition to fixing these issues, jclouds wants to provide developers
with some compiler checks and other syntactic sugar (fluent builders), while
also supporting different updating, creating, or listing validation
strategies.</p>
+
+<p>We want to</p>
+
+<ol>
+<li>Ensure object immutability.</li>
+<li>Utilize the fluent builder pattern.</li>
+<li>Ensure that "create" objects can only be used for create; update for
update; and listed resources cannot be directly sent back to the service.</li>
+<li>Reuse code and keep domain classes <a
href="http://en.wikipedia.org/wiki/Don't_repeat_yourself">DRY</a>.</li>
+<li>Allow using different validation strategies (for example, create vs
update).</li>
+</ol>
+
+
+<p>We have been able to identify a pattern that addresses these issues. Here
is some <a
href="https://github.com/jclouds/jclouds-labs-openstack/blob/master/openstack-neutron/src/main/java/org/jclouds/openstack/neutron/v2/domain/Router.java">sample
code</a>.</p>
+
+<p>This approach reuses code by having <a
href="https://code.google.com/p/google-gson/">GSON</a> handle the domain
objects directly, as much as possible, both for serialization and
deserialization, thus eliminating map-binders and parsers in most cases. The
domain classes annotate their member variables using the @Named (for
serialization) and @ConstructorProperties (for deserialization) annotations.</p>
+
+<p>Many of the JSON attributes in Neutron are optional. GSON's jclouds
configuration supports such optional values by using @Nullable and boxed types.
An alternate supported method, more convoluted, implements Optional<T> private
member variables and getter return types.</p>
+
+<p>To ensure immutability, users have no access to a constructor or setters,
and instead they must instantiate domain objects by using a slightly modified
Builder pattern. The builder pattern also provides proper validation and
user-friendliness.</p>
+
+<p>Some <a
href="https://github.com/jclouds/jclouds-labs-openstack/blob/master/openstack-neutron/src/main/java/org/jclouds/openstack/neutron/v2/domain/AddressPair.java">simpler
classes</a> implement the regular fluent builder pattern.</p>
+
+<p>In <a
href="https://github.com/jclouds/jclouds-labs-openstack/blob/master/openstack-neutron/src/main/java/org/jclouds/openstack/neutron/v2/features/NetworkApi.java">other
cases</a>, the same domain class has several different purposes, such as
making sure users have different Network-subtype object instances for updating,
creating, and listing networks:</p>
+
+<ol>
+<li>Listing networks returns a Network or a list of Networks.</li>
+<li>Updating a network requires Network.UpdateOptions.</li>
+<li>Creating a network requires Network.CreateOptions.</li>
+</ol>
+
+
+<p>CreateOptions and UpdateOptions extend Network and implement their own copy
constructors, with custom validation, if needed.</p>
+
+<p>To instantiate these create or update-specific objects, developers have
access to CreateBuilder and UpdateBuilder, which both extend the regular
Network builder abstract class. The only code these special builders implement:
the constructor (taking as parameters any required properties), a build()
method returning the create or update object, and also self(). The self method
is needed to make sure we can reuse most of the Builder code, but still be able
to chain the fluent builder methods.</p>
+
+<p>This is how it all works out from the developer's perspective:</p>
+
+<div class="highlight"><pre><code class="java"><span
class="n">Network</span><span class="o">.</span><span
class="na">CreateOptions</span> <span class="n">createNetwork</span> <span
class="o">=</span> <span class="n">Network</span><span class="o">.</span><span
class="na">createOptions</span><span class="o">(</span><span
class="s">"jclouds-wibble"</span><span class="o">)</span>
+ <span class="o">.</span><span class="na">networkType</span><span
class="o">(</span><span class="n">NetworkType</span><span
class="o">.</span><span class="na">LOCAL</span><span class="o">)</span>
+ <span class="o">.</span><span class="na">build</span><span
class="o">();</span>
+
+<span class="n">Network</span> <span class="n">network</span> <span
class="o">=</span> <span class="n">networkApi</span><span
class="o">.</span><span class="na">create</span><span class="o">(</span><span
class="n">createNetwork</span><span class="o">);</span>
+
+<span class="n">Network</span><span class="o">.</span><span
class="na">UpdateOptions</span> <span class="n">updateNetwork</span> <span
class="o">=</span> <span class="n">Network</span><span class="o">.</span><span
class="na">updateOptions</span><span class="o">()</span>
+ <span class="o">.</span><span class="na">name</span><span
class="o">(</span><span
class="s">"jclouds-wibble-updated"</span><span class="o">)</span>
+ <span class="o">.</span><span class="na">networkType</span><span
class="o">(</span><span class="n">NetworkType</span><span
class="o">.</span><span class="na">LOCAL</span><span class="o">)</span>
+ <span class="o">.</span><span class="na">build</span><span
class="o">();</span>
+
+<span class="n">networkApi</span><span class="o">.</span><span
class="na">update</span><span class="o">(</span><span class="s">"some
id"</span><span class="o">,</span> <span
class="n">updateNetwork</span><span class="o">);</span>
+</code></pre></div>
+
+
+<p>This ensures developers get an easy to understand interface, with
validation and compiler checks. It also allows jclouds developers to use
significantly less code when developing complex domain classes that need to be
reused in list/create/update API calls.</p>
+
+
+ <div id="comments">
+ <hr/>
+ <div id="disqus_thread"></div>
+<script type="text/javascript">
+var disqus_shortname = 'jclouds';
+/* * * DON'T EDIT BELOW THIS LINE * * */
+(function() {
+ var dsq = document.createElement('script'); dsq.type = 'text/javascript';
dsq.async = true;
+ dsq.src = '//' + disqus_shortname + '.disqus.com/embed.js';
+ (document.getElementsByTagName('head')[0] ||
document.getElementsByTagName('body')[0]).appendChild(dsq);
+})();
+</script>
+<noscript>Please enable JavaScript to view the <a
href="http://disqus.com/?ref_noscript">Comments powered by
Disqus.</a></noscript>
+<a href="http://disqus.com" class="dsq-brlink">Comments powered by <span
class="logo-disqus">Disqus</span></a>
+
+ </div>
+
+ <div class="row clearfix">
+ <div id="footer" class="col-md-12 column">
+ <div id="footer">
+ <hr/>
+ <div class="row clearfix">
+ <div class="col-md-2 column">
+ <p class="text-center">
+ <a class="text-primary" href="/start/">Getting Started</a>
+ </p>
+ </div>
+ <div class="col-md-2 column">
+ <p class="text-center">
+ <a class="text-primary" href="/reference/report-a-bug/">Report
a Bug</a>
+ </p>
+ </div>
+ <div class="col-md-2 column">
+ <p class="text-center">
+ <a
href="https://github.com/jclouds/jclouds-site/edit/master/_posts/2014-09-03-better-builders.md">Fix
This Page</a><a class="text-primary"
href="https://cwiki.apache.org/confluence/display/JCLOUDS/How+to+Contribute+Documentation"><sup>*</sup></a>
+ </p>
+ </div>
+ <div class="col-md-2 column">
+ <p class="text-center">
+ <a class="text-primary"
href="https://cwiki.apache.org/confluence/display/JCLOUDS/How+to+Contribute">Contribute
Code</a>
+ </p>
+ </div>
+ <div class="col-md-2 column">
+ <p class="text-center">
+ <a class="text-primary" href="/community/">Contact Us</a>
+ </p>
+ </div>
+ <div class="col-md-2 column">
+ <p class="text-center">
+ <a class="text-primary"
href="https://twitter.com/jclouds">Follow Us</a>
+ </p>
+ </div>
+ </div>
+ <hr style="margin-top: 10px"/>
+ <div class="row clearfix">
+ <div class="col-md-12 column">
+ <p class="text-center">
+ Copyright © 2011-2014 <a href="http://www.apache.org">The
Apache Software Foundation</a>. All Rights Reserved.
+ </p>
+ <p class="text-center">
+ Apache, jclouds, Apache jclouds, the jclouds logo, and the
Apache feather logos are registered trademarks or trademarks of the Apache
Software Foundation.
+ </p>
+ <p class="text-center">
+ <img src="/img/feather-small.gif" width="80", height="24"/>
+ </p>
+ <br/>
+ </div>
+ </div>
+</div>
+
+ </div>
+ </div>
+ </div>
+ </body>
+</html>
Modified: jclouds/site-content/blog/atom.xml
URL:
http://svn.apache.org/viewvc/jclouds/site-content/blog/atom.xml?rev=1695982&r1=1695981&r2=1695982&view=diff
==============================================================================
--- jclouds/site-content/blog/atom.xml (original)
+++ jclouds/site-content/blog/atom.xml Fri Aug 14 20:25:18 2015
@@ -114,10 +114,10 @@
</entry>
<entry>
- <id>http://jclouds.apache.org/blog/2014/09/04/better-builders</id>
+ <id>http://jclouds.apache.org/blog/2014/09/03/better-builders</id>
<title type="html"><![CDATA[Better Builders with jclouds!]]></title>
- <link href="http://jclouds.apache.org/blog/2014/09/04/better-builders"/>
- <updated>2014-09-04T00:00:00Z</updated>
+ <link href="http://jclouds.apache.org/blog/2014/09/03/better-builders"/>
+ <updated>2014-09-03T00:00:00Z</updated>
<content type="html"><![CDATA[<p>If you are a new <a
href="jclouds.apache.org">jclouds</a> developer, or even if you are already
developing jclouds support for any of the OpenStack or Rackspace APIs, you have
likely seen the domain classes that are used throughout the the jclouds
codebase.
These classes are used to represent OpenStack resources, particularly the JSON
structures supported by OpenStack APIs.</p>
@@ -242,10 +242,10 @@ These classes are used to represent Open
</entry>
<entry>
- <id>http://jclouds.apache.org/blog/2014/08/05/1-release-2-committers</id>
+ <id>http://jclouds.apache.org/blog/2014/08/04/1-release-2-committers</id>
<title type="html"><![CDATA[1 release, 2 committers...a busy week for
jclouds!]]></title>
- <link
href="http://jclouds.apache.org/blog/2014/08/05/1-release-2-committers"/>
- <updated>2014-08-05T00:00:00Z</updated>
+ <link
href="http://jclouds.apache.org/blog/2014/08/04/1-release-2-committers"/>
+ <updated>2014-08-04T00:00:00Z</updated>
<content type="html"><![CDATA[<p><img class="img-right"
src="/img/posts/chris-and-andrea.png"/>There's a lot going on this week for the
jclouds community. Most importantly, we're really pleased to introduce two new
committers: Andrea Turli and Chris Custine.</p>
<!--more-->
Modified: jclouds/site-content/blog/index.html
URL:
http://svn.apache.org/viewvc/jclouds/site-content/blog/index.html?rev=1695982&r1=1695981&r2=1695982&view=diff
==============================================================================
--- jclouds/site-content/blog/index.html (original)
+++ jclouds/site-content/blog/index.html Fri Aug 14 20:25:18 2015
@@ -165,14 +165,14 @@
<p>Google Summer of Code 2014 has concluded and both Apache jclouds students
have successfully completed their projects, Amazon Glacier and Google Cloud
Storage support.
</p>
-<h3><a class="text-primary" href="/blog/2014/09/04/better-builders">Better
Builders with jclouds!</a></h3>
-<span class="text-muted">04 September 2014, by Zack Shoylev</span>
+<h3><a class="text-primary" href="/blog/2014/09/03/better-builders">Better
Builders with jclouds!</a></h3>
+<span class="text-muted">03 September 2014, by Zack Shoylev</span>
<p>If you are a new jclouds developer, or even if you are already developing
jclouds support for any of the OpenStack or Rackspace APIs, you have likely
seen the domain classes that are used throughout the the jclouds codebase.
These classes are used to represent OpenStack resources, particularly the JSON
structures supported by OpenStack APIs.
</p>
-<h3><a class="text-primary" href="/blog/2014/08/05/1-release-2-committers">1
release, 2 committers...a busy week for jclouds!</a></h3>
-<span class="text-muted">05 August 2014, by <a
href="http://blog.xebialabs.com/author/aphillips/">Andrew Phillips</a></span>
+<h3><a class="text-primary" href="/blog/2014/08/04/1-release-2-committers">1
release, 2 committers...a busy week for jclouds!</a></h3>
+<span class="text-muted">04 August 2014, by <a
href="http://blog.xebialabs.com/author/aphillips/">Andrew Phillips</a></span>
<p>There's a lot going on this week for the jclouds community. Most
importantly, we're really pleased to introduce two new committers: Andrea Turli
and Chris Custine.
</p>
Modified: jclouds/site-content/guides/hpcloud/index.html
URL:
http://svn.apache.org/viewvc/jclouds/site-content/guides/hpcloud/index.html?rev=1695982&r1=1695981&r2=1695982&view=diff
==============================================================================
--- jclouds/site-content/guides/hpcloud/index.html (original)
+++ jclouds/site-content/guides/hpcloud/index.html Fri Aug 14 20:25:18 2015
@@ -187,12 +187,14 @@ versions of the HP Cloud provider (prior
<span class="n">BlobStoreContext</span> <span class="n">context</span> <span
class="o">=</span> <span class="n">ContextBuilder</span><span
class="o">.</span><span class="na">newBuilder</span><span
class="o">(</span><span class="s">"hpcloud-objectstorage"</span><span
class="o">)</span>
<span class="o">.</span><span
class="na">credentials</span><span class="o">(</span><span
class="s">"tenantName:accessKey"</span><span class="o">,</span> <span
class="s">"secretKey"</span><span class="o">)</span>
<span class="o">.</span><span
class="na">buildView</span><span class="o">(</span><span
class="n">BlobStoreContext</span><span class="o">.</span><span
class="na">class</span><span class="o">);</span>
+<span class="n">BlobStore</span> <span class="n">blobStore</span> <span
class="o">=</span> <span class="n">context</span><span class="o">.</span><span
class="na">getBlobStore</span><span class="o">();</span>
<span class="c1">// Create a container in the default location</span>
-<span class="n">context</span><span class="o">.</span><span
class="na">getBlobStore</span><span class="o">().</span><span
class="na">createContainerInLocation</span><span class="o">(</span><span
class="kc">null</span><span class="o">,</span> <span
class="n">container</span><span class="o">);</span>
+<span class="n">blobStore</span><span class="o">.</span><span
class="na">createContainerInLocation</span><span class="o">(</span><span
class="kc">null</span><span class="o">,</span> <span
class="n">container</span><span class="o">);</span>
-<span class="c1">// Use the map interface for easy access to put/get things,
keySet, etc.</span>
-<span class="n">context</span><span class="o">.</span><span
class="na">createInputStreamMap</span><span class="o">(</span><span
class="n">container</span><span class="o">).</span><span
class="na">put</span><span class="o">(</span><span
class="s">"blob.txt"</span><span class="o">,</span> <span
class="n">inputStream</span><span class="o">);</span>
+<span class="c1">// Upload an empty blob</span>
+<span class="n">Blob</span> <span class="n">blob</span> <span
class="o">=</span> <span class="n">blobStore</span><span
class="o">.</span><span class="na">blobBuilder</span><span
class="o">(</span><span class="s">"blob-name"</span><span
class="o">).</span><span class="na">payload</span><span class="o">(</span><span
class="k">new</span> <span class="kt">byte</span><span class="o">[</span><span
class="mi">0</span><span class="o">]).</span><span class="na">build</span><span
class="o">();</span>
+<span class="n">blobStore</span><span class="o">.</span><span
class="na">putBlob</span><span class="o">(</span><span
class="n">container</span><span class="o">,</span> <span
class="n">blob</span><span class="o">);</span>
<span class="c1">// When you need access to hpcloud specific features, use the
provider-specific context</span>
<span class="n">HPCloudObjectStorageClient</span> <span
class="n">hpcloudClient</span> <span class="o">=</span>
Modified: jclouds/site-content/guides/profitbricks/index.html
URL:
http://svn.apache.org/viewvc/jclouds/site-content/guides/profitbricks/index.html?rev=1695982&r1=1695981&r2=1695982&view=diff
==============================================================================
--- jclouds/site-content/guides/profitbricks/index.html (original)
+++ jclouds/site-content/guides/profitbricks/index.html Fri Aug 14 20:25:18 2015
@@ -189,18 +189,16 @@
</ul>
-<p><code>java
- javac -version
-</code></p>
+<pre><code class="java"> javac -version
+</code></pre>
<ul>
<li>Ensure you are using <a
href="http://maven.apache.org/guides/getting-started/maven-in-five-minutes.html">Maven
version 3</a> or later. You can check this by running:</li>
</ul>
-<p><code>java
- mvn -version
-</code></p>
+<pre><code class="java"> mvn -version
+</code></pre>
<p>Now that you have validated the pre-requisities, you will want to do the
following:</p>