blob: 1ce2590fc151d6b6a04bc2e876fa45d5ca5ddd99 [file] [log] [blame]
<!DOCTYPE html>
<!--[if IE 8]><html class="no-js lt-ie9" lang="en" > <![endif]-->
<!--[if gt IE 8]><!--> <html class="no-js" lang="en" > <!--<![endif]-->
<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="author" content="Apache Software Foundation">
<link rel="shortcut icon" href="../../img/favicon.ico">
<title>Rest Api - Apache Gobblin</title>
<link href='https://fonts.googleapis.com/css?family=Lato:400,700|Roboto+Slab:400,700|Inconsolata:400,700' rel='stylesheet' type='text/css'>
<link rel="stylesheet" href="../../css/theme.css" type="text/css" />
<link rel="stylesheet" href="../../css/theme_extra.css" type="text/css" />
<link rel="stylesheet" href="//cdnjs.cloudflare.com/ajax/libs/highlight.js/9.12.0/styles/github.min.css">
<link href="../../css/extra.css" rel="stylesheet">
<script>
// Current page data
var mkdocs_page_name = "Rest Api";
var mkdocs_page_input_path = "sources/RestApiSource.md";
var mkdocs_page_url = null;
</script>
<script src="../../js/jquery-2.1.1.min.js" defer></script>
<script src="../../js/modernizr-2.8.3.min.js" defer></script>
<script src="//cdnjs.cloudflare.com/ajax/libs/highlight.js/9.12.0/highlight.min.js"></script>
<script>hljs.initHighlightingOnLoad();</script>
</head>
<body class="wy-body-for-nav" role="document">
<div class="wy-grid-for-nav">
<nav data-toggle="wy-nav-shift" class="wy-nav-side stickynav">
<div class="wy-side-nav-search">
<a href="../.." class="icon icon-home"> Apache Gobblin</a>
<div role="search">
<form id ="rtd-search-form" class="wy-form" action="../../search.html" method="get">
<input type="text" name="q" placeholder="Search docs" title="Type search term here" />
</form>
</div>
</div>
<div class="wy-menu wy-menu-vertical" data-spy="affix" role="navigation" aria-label="main navigation">
<ul class="current">
<li class="toctree-l1">
<a class="" href="/">Home</a>
</li>
<li class="toctree-l1">
<a class="" href="../../Powered-By/">Companies Powered By Gobblin</a>
</li>
<li class="toctree-l1">
<a class="" href="../../Getting-Started/">Getting Started</a>
</li>
<li class="toctree-l1">
<a class="" href="../../Gobblin-Architecture/">Architecture</a>
</li>
<li class="toctree-l1">
<span class="caption-text">User Guide</span>
<ul class="subnav">
<li class="">
<a class="" href="../../user-guide/Working-with-Job-Configuration-Files/">Job Configuration Files</a>
</li>
<li class="">
<a class="" href="../../user-guide/Gobblin-Deployment/">Deployment</a>
</li>
<li class="">
<a class="" href="../../user-guide/Gobblin-as-a-Library/">Gobblin as a Library</a>
</li>
<li class="">
<a class="" href="../../user-guide/Gobblin-CLI/">Gobblin CLI</a>
</li>
<li class="">
<a class="" href="../../user-guide/Gobblin-Compliance/">Gobblin Compliance</a>
</li>
<li class="">
<a class="" href="../../user-guide/Gobblin-on-Yarn/">Gobblin on Yarn</a>
</li>
<li class="">
<a class="" href="../../user-guide/Compaction/">Compaction</a>
</li>
<li class="">
<a class="" href="../../user-guide/State-Management-and-Watermarks/">State Management and Watermarks</a>
</li>
<li class="">
<a class="" href="../../user-guide/Working-with-the-ForkOperator/">Fork Operator</a>
</li>
<li class="">
<a class="" href="../../user-guide/Configuration-Properties-Glossary/">Configuration Glossary</a>
</li>
<li class="">
<a class="" href="../../user-guide/Source-schema-and-Converters/">Source schema and Converters</a>
</li>
<li class="">
<a class="" href="../../user-guide/Partitioned-Writers/">Partitioned Writers</a>
</li>
<li class="">
<a class="" href="../../user-guide/Monitoring/">Monitoring</a>
</li>
<li class="">
<a class="" href="../../user-guide/Gobblin-template/">Template</a>
</li>
<li class="">
<a class="" href="../../user-guide/Gobblin-Schedulers/">Schedulers</a>
</li>
<li class="">
<a class="" href="../../user-guide/Job-Execution-History-Store/">Job Execution History Store</a>
</li>
<li class="">
<a class="" href="../../user-guide/Building-Gobblin/">Building Gobblin</a>
</li>
<li class="">
<a class="" href="../../user-guide/Gobblin-genericLoad/">Generic Configuration Loading</a>
</li>
<li class="">
<a class="" href="../../user-guide/Hive-Registration/">Hive Registration</a>
</li>
<li class="">
<a class="" href="../../user-guide/Config-Management/">Config Management</a>
</li>
<li class="">
<a class="" href="../../user-guide/Docker-Integration/">Docker Integration</a>
</li>
<li class="">
<a class="" href="../../user-guide/Troubleshooting/">Troubleshooting</a>
</li>
<li class="">
<a class="" href="../../user-guide/FAQs/">FAQs</a>
</li>
</ul>
</li>
<li class="toctree-l1">
<span class="caption-text">Sources</span>
<ul class="subnav">
<li class="">
<a class="" href="../AvroFileSource/">Avro files</a>
</li>
<li class="">
<a class="" href="../CopySource/">File copy</a>
</li>
<li class="">
<a class="" href="../QueryBasedSource/">Query based</a>
</li>
<li class=" current">
<a class="current" href="./">Rest Api</a>
<ul class="subnav">
<li class="toctree-l3"><a href="#introduction">Introduction</a></li>
<li class="toctree-l3"><a href="#constructs">Constructs</a></li>
<ul>
<li><a class="toctree-l4" href="#restapisource">RestApiSource</a></li>
<li><a class="toctree-l4" href="#restapiextractor">RestApiExtractor</a></li>
</ul>
<li class="toctree-l3"><a href="#configuration">Configuration</a></li>
</ul>
</li>
<li class="">
<a class="" href="../GoogleAnalyticsSource/">Google Analytics</a>
</li>
<li class="">
<a class="" href="../GoogleDriveSource/">Google Drive</a>
</li>
<li class="">
<a class="" href="../GoogleWebmaster/">Google Webmaster</a>
</li>
<li class="">
<a class="" href="../HadoopTextInputSource/">Hadoop Text Input</a>
</li>
<li class="">
<a class="" href="../HelloWorldSource/">Hello World</a>
</li>
<li class="">
<a class="" href="../HiveAvroToOrcSource/">Hive Avro-to-ORC</a>
</li>
<li class="">
<a class="" href="../HivePurgerSource/">Hive compliance purging</a>
</li>
<li class="">
<a class="" href="../SimpleJsonSource/">JSON</a>
</li>
<li class="">
<a class="" href="../KafkaSource/">Kafka</a>
</li>
<li class="">
<a class="" href="../MySQLSource/">MySQL</a>
</li>
<li class="">
<a class="" href="../OracleSource/">Oracle</a>
</li>
<li class="">
<a class="" href="../SalesforceSource/">Salesforce</a>
</li>
<li class="">
<a class="" href="../SftpSource/">SFTP</a>
</li>
<li class="">
<a class="" href="../SqlServerSource/">SQL Server</a>
</li>
<li class="">
<a class="" href="../TeradataSource/">Teradata</a>
</li>
<li class="">
<a class="" href="../WikipediaSource/">Wikipedia</a>
</li>
</ul>
</li>
<li class="toctree-l1">
<span class="caption-text">Sinks (Writers)</span>
<ul class="subnav">
<li class="">
<a class="" href="../../sinks/AvroHdfsDataWriter/">Avro HDFS</a>
</li>
<li class="">
<a class="" href="../../sinks/ParquetHdfsDataWriter/">Parquet HDFS</a>
</li>
<li class="">
<a class="" href="../../sinks/SimpleBytesWriter/">HDFS Byte array</a>
</li>
<li class="">
<a class="" href="../../sinks/ConsoleWriter/">Console</a>
</li>
<li class="">
<a class="" href="../../sinks/CouchbaseWriter/">Couchbase</a>
</li>
<li class="">
<a class="" href="../../sinks/Http/">HTTP</a>
</li>
<li class="">
<a class="" href="../../sinks/Gobblin-JDBC-Writer/">JDBC</a>
</li>
<li class="">
<a class="" href="../../sinks/Kafka/">Kafka</a>
</li>
</ul>
</li>
<li class="toctree-l1">
<span class="caption-text">Gobblin Adaptors</span>
<ul class="subnav">
<li class="">
<a class="" href="../../adaptors/Gobblin-Distcp/">Gobblin Distcp</a>
</li>
<li class="">
<a class="" href="../../adaptors/Hive-Avro-To-ORC-Converter/">Hive Avro-To-Orc Converter</a>
</li>
</ul>
</li>
<li class="toctree-l1">
<span class="caption-text">Case Studies</span>
<ul class="subnav">
<li class="">
<a class="" href="../../case-studies/Kafka-HDFS-Ingestion/">Kafka-HDFS Ingestion</a>
</li>
<li class="">
<a class="" href="../../case-studies/Publishing-Data-to-S3/">Publishing Data to S3</a>
</li>
<li class="">
<a class="" href="../../case-studies/Writing-ORC-Data/">Writing ORC Data</a>
</li>
<li class="">
<a class="" href="../../case-studies/Hive-Distcp/">Hive Distcp</a>
</li>
</ul>
</li>
<li class="toctree-l1">
<span class="caption-text">Gobblin Data Management</span>
<ul class="subnav">
<li class="">
<a class="" href="../../data-management/Gobblin-Retention/">Retention</a>
</li>
<li class="">
<a class="" href="../../data-management/DistcpNgEvents/">Distcp-NG events</a>
</li>
</ul>
</li>
<li class="toctree-l1">
<span class="caption-text">Gobblin Metrics</span>
<ul class="subnav">
<li class="">
<a class="" href="../../metrics/Gobblin-Metrics/">Quick Start</a>
</li>
<li class="">
<a class="" href="../../metrics/Existing-Reporters/">Existing Reporters</a>
</li>
<li class="">
<a class="" href="../../metrics/Metrics-for-Gobblin-ETL/">Metrics for Gobblin ETL</a>
</li>
<li class="">
<a class="" href="../../metrics/Gobblin-Metrics-Architecture/">Gobblin Metrics Architecture</a>
</li>
<li class="">
<a class="" href="../../metrics/Implementing-New-Reporters/">Implementing New Reporters</a>
</li>
<li class="">
<a class="" href="../../metrics/Gobblin-Metrics-Performance/">Gobblin Metrics Performance</a>
</li>
</ul>
</li>
<li class="toctree-l1">
<span class="caption-text">Developer Guide</span>
<ul class="subnav">
<li class="">
<a class="" href="../../developer-guide/Customization-for-New-Source/">Customization for New Source</a>
</li>
<li class="">
<a class="" href="../../developer-guide/Customization-for-Converter-and-Operator/">Customization for Converter and Operator</a>
</li>
<li class="">
<a class="" href="../../developer-guide/CodingStyle/">Code Style Guide</a>
</li>
<li class="">
<a class="" href="../../developer-guide/Gobblin-Compliance-Design/">Gobblin Compliance Design</a>
</li>
<li class="">
<a class="" href="../../developer-guide/IDE-setup/">IDE setup</a>
</li>
<li class="">
<a class="" href="../../developer-guide/Monitoring-Design/">Monitoring Design</a>
</li>
<li class="">
<a class="" href="../../developer-guide/Documentation-Architecture/">Documentation Architecture</a>
</li>
<li class="">
<a class="" href="../../developer-guide/Contributing/">Contributing</a>
</li>
<li class="">
<a class="" href="../../developer-guide/GobblinModules/">Gobblin Modules</a>
</li>
<li class="">
<a class="" href="../../developer-guide/HighLevelConsumer/">High Level Consumer</a>
</li>
</ul>
</li>
<li class="toctree-l1">
<span class="caption-text">Project</span>
<ul class="subnav">
<li class="">
<a class="" href="../../project/Feature-List/">Feature List</a>
</li>
<li class="">
<a class="" href="/people">Contributors and Team</a>
</li>
<li class="">
<a class="" href="../../project/Talks-and-Tech-Blogs/">Talks and Tech Blog Posts</a>
</li>
<li class="">
<a class="" href="../../project/Posts/">Posts</a>
</li>
</ul>
</li>
<li class="toctree-l1">
<span class="caption-text">Miscellaneous</span>
<ul class="subnav">
<li class="">
<a class="" href="../../miscellaneous/Camus-to-Gobblin-Migration/">Camus to Gobblin Migration</a>
</li>
<li class="">
<a class="" href="../../miscellaneous/Exactly-Once-Support/">Exactly Once Support</a>
</li>
</ul>
</li>
</ul>
</div>
&nbsp;
</nav>
<section data-toggle="wy-nav-shift" class="wy-nav-content-wrap">
<nav class="wy-nav-top" role="navigation" aria-label="top navigation">
<i data-toggle="wy-nav-top" class="fa fa-bars"></i>
<a href="../..">Apache Gobblin</a>
</nav>
<div class="wy-nav-content">
<div class="rst-content">
<div role="navigation" aria-label="breadcrumbs navigation">
<ul class="wy-breadcrumbs">
<li><a href="../..">Docs</a> &raquo;</li>
<li>Sources &raquo;</li>
<li>Rest Api</li>
<li class="wy-breadcrumbs-aside">
<a href="https://github.com/apache/incubator-gobblin/edit/master/docs/sources/RestApiSource.md" rel="nofollow"> Edit on Gobblin</a>
</li>
</ul>
<hr/>
</div>
<div role="main">
<div class="section">
<div class="toc">
<ul>
<li><a href="#introduction">Introduction</a></li>
<li><a href="#constructs">Constructs</a><ul>
<li><a href="#restapisource">RestApiSource</a></li>
<li><a href="#restapiextractor">RestApiExtractor</a></li>
</ul>
</li>
<li><a href="#configuration">Configuration</a></li>
</ul>
</div>
<h1 id="introduction">Introduction</h1>
<p>A RestApiSource is a <a href="../QueryBasedSource/">QueryBasedSource</a> which uses <a href="https://en.wikipedia.org/wiki/Representational_state_transfer" rel="nofollow">RESTful</a>
Api for query. <code>RestApiExtractor</code> is a <code>QueryBasedExtractor</code> that uses REST to communicate with the source. To establish the communication,
a <a href="https://github.com/apache/incubator-gobblin/blob/master/gobblin-core/src/main/java/org/apache/gobblin/source/extractor/extract/restapi/RestApiConnector.java" rel="nofollow"><code>RestApiConnector</code></a> is
required.</p>
<h1 id="constructs">Constructs</h1>
<h2 id="restapisource"><code>RestApiSource</code></h2>
<p>Coming soon...</p>
<h2 id="restapiextractor"><code>RestApiExtractor</code></h2>
<p>A <code>RestApiExtractor</code> sets up the common routines to query information from a REST source, for example, <code>extractMetadata</code>,
<code>getMaxWatermark</code>, <code>getSourceCount</code>, <code>getRecordSet</code>, which are mentioned in chapter <a href="../QueryBasedSource/">QueryBasedSource</a>.
In terms of constructing the actual query and extracting the data from the response, the source specific layer holds the truth,
for example, <code>SalesforceExtractor</code>.</p>
<p>A simplified general flow of routines is depicted in Figure 1:</p>
<p align="center">
<figure>
<img src=../../img/Rest-Api-Extractor-Flow.png alt="Rest api extractor general routine flow" width="500">
<figcaption><br>Figure 1: RestApiExtractor general routine flow <br></figcaption>
</figure>
</p>
<p>Depends on the routines, [getX], [constructGetXQuery], [extractXFromResponse] are</p>
<table>
<thead>
<tr>
<th>Description</th>
<th>[getX]</th>
<th>[constructGetXQuery]</th>
<th>[extractXFromResponse]</th>
</tr>
</thead>
<tbody>
<tr>
<td>Get data schema</td>
<td><code>extractMetadata</code></td>
<td><code>getSchemaMetadata</code></td>
<td><code>getSchema</code></td>
</tr>
<tr>
<td>Calculate latest high watermark</td>
<td><code>getMaxWatermark</code></td>
<td><code>getHighWatermarkMetadata</code></td>
<td><code>getHighWatermark</code></td>
</tr>
<tr>
<td>Get total counts of records to be pulled</td>
<td><code>getSourceCount</code></td>
<td><code>getCountMetadata</code></td>
<td><code>getCount</code></td>
</tr>
<tr>
<td>Get records</td>
<td><code>getRecordSet</code></td>
<td><code>getDataMetadata</code></td>
<td><code>getData</code></td>
</tr>
</tbody>
</table>
<p>There are other interactions between the <code>RestApiExtractor</code> layer and <code>SourceSpecificLayer</code>. The key points are:</p>
<ul>
<li>A <a href="https://github.com/apache/incubator-gobblin/blob/master/gobblin-core/src/main/java/org/apache/gobblin/source/extractor/extract/ProtocolSpecificLayer.java" rel="nofollow"><code>ProtocolSpecificLayer</code></a>, such as
<code>RestApiExtractor</code>, understands the protocol and sets up a routine to communicate with the source</li>
<li>A <code>SourceSpecificLayer</code>, such as <code>SalesforceExtractor</code>, knows the source and fits into the routine by providing and analyzing source specific information</li>
</ul>
<h1 id="configuration">Configuration</h1>
<table>
<thead>
<tr>
<th>Configuration Key</th>
<th>Default Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td><code>source.querybased.query</code></td>
<td>Optional</td>
<td>The query that the extractor should execute to pull data.</td>
</tr>
<tr>
<td><code>source.querybased.excluded.columns</code></td>
<td>Options</td>
<td>Names of columns excluded while pulling data.</td>
</tr>
<tr>
<td><code>extract.delta.fields</code></td>
<td>Optional</td>
<td>List of columns that are associated with the watermark.</td>
</tr>
<tr>
<td><code>extract.primary.key.fields</code></td>
<td>Optional</td>
<td>List of columns that will be used as the primary key for the data.</td>
</tr>
</tbody>
</table>
</div>
</div>
<footer>
<div class="rst-footer-buttons" role="navigation" aria-label="footer navigation">
<a href="../GoogleAnalyticsSource/" class="btn btn-neutral float-right" title="Google Analytics">Next <span class="icon icon-circle-arrow-right"></span></a>
<a href="../QueryBasedSource/" class="btn btn-neutral" title="Query based"><span class="icon icon-circle-arrow-left"></span> Previous</a>
</div>
<hr/>
<div role="contentinfo">
<!-- Copyright etc -->
</div>
Built with <a href="http://www.mkdocs.org" rel="nofollow">MkDocs</a> using a <a href="https://github.com/snide/sphinx_rtd_theme" rel="nofollow">theme</a> provided by <a href="https://readthedocs.org" rel="nofollow">Read the Docs</a>.
</footer>
</div>
</div>
</section>
</div>
<div class="rst-versions" role="note" style="cursor: pointer">
<span class="rst-current-version" data-toggle="rst-current-version">
<span><a href="../QueryBasedSource/" style="color: #fcfcfc;">&laquo; Previous</a></span>
<span style="margin-left: 15px"><a href="../GoogleAnalyticsSource/" style="color: #fcfcfc">Next &raquo;</a></span>
</span>
</div>
<script>var base_url = '../..';</script>
<script src="../../js/theme.js" defer></script>
<script src="../../js/extra.js" defer></script>
<script src="../../search/main.js" defer></script>
</body>
</html>