When using Cloud Data Fusion, you use both the Google Cloud console and the Cloud Data Fusion web interface. You use the Google Cloud console to create a Cloud Data Fusion instance. You then use the Cloud Data Fusion web interface to create and manage your pipelines.
Alternatively, you can use command-line tools to create and manage your Cloud Data Fusion instances and pipelines.
- The REST reference describes the API for creating and managing your Cloud Data Fusion instances on Google Cloud.
- This page describes the REST API for creating and managing pipelines and datasets. Throughout this page, there are links to the CDAP documentation site, where you can find more detailed information.
Before you begin
Before you use the REST API, download the Google Cloud CLI and set environment variables for your Google Cloud CLI access credentials and CDAP API endpoint.
Download and log in to the Google Cloud CLI
- Log in to the Google Cloud CLI: - $ gcloud auth login 
Set environment variables
- AUTH_TOKEN
export AUTH_TOKEN=$(gcloud auth print-access-token) 
- CDAP_ENDPOINT
The CDAP_ENDPOINT can be obtained using either the Google Cloud CLI or the Cloud Data Fusion REST API. Use the value of the apiEndpoint, not theserviceEndpointfield. It has the formathostname/api(example:https://my-instance-my-project-id-dot-usc1.datafusion.googleusercontent.com/api).gcloudIn a local terminal window or in Cloud Shell, run the following gcloud CLI commands to set the CDAP_ENDPOINTenvironment variable toapiEndpointof your instance.export INSTANCE_ID=your-instance-name export CDAP_ENDPOINT=$(gcloud beta data-fusion instances describe \ --location=region-name \ --format="value(apiEndpoint)" \ ${INSTANCE_ID})APIUse the Try this API panel to submit an instances.getrequest:- Fill in the namerequest parameter. Provide your project-id, instance region, and instance-name in the following format:projects/project-id/locations/region/instances/instance-name
- Click EXECUTE to submit the request, and then
          copy the apiEndpointlisted in the HTTP response.
- Run the following command after inserting the apiEndpoint:export CDAP_ENDPOINT=apiEndpoint 
 
- Fill in the 
Deploy a pipeline
To deploy a Cloud Data Fusion pipeline, submit the following HTTP PUT
request.
PUT -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/namespaces/namespace-id/apps/pipeline-name"
| Parameter | Description | 
|---|---|
| namespace-id | The namespace ID must either be the name of the
        namespace 
        when it was created
        or default, which is the name of the default namespace. | 
| pipeline-name | Your pipeline name. | 
For more information, see CDAP's Create an Application.
The body of the HTTP PUT request is a JSON object in the following format:
{
  "name": "MyPipeline",
  "artifact": {
    "name": "cdap-data-pipeline",
    "version": "6.0.0",
    "scope": "system"
  },
  "config": {
    . . .
    "connections": [ . . . ],
    "engine": "spark",
    "postActions": [ . . . ],
    "stages": [ . . . ],
    "schedule": "0 * * * *",
  },
  "__ui__": {
    . . .
  }
}
For more information, see the CDAP Pipeline Configuration File Format and Creating a Batch Pipeline.
Retrieve pipelines
Retrieve all pipelines
To list Cloud Data Fusion pipelines in the specified
namespace, submit the following HTTP GET request.
GET -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/namespaces/namespace-id/apps"
| Parameter | Description | 
|---|---|
| namespace-id | The namespace ID must either be the name of the
        namespace 
        when it was created
        or default, which is the name of the default namespace. | 
For more information, see Deployed Applications.
Retrieve batch pipelines
To list Cloud Data Fusion batch pipelines in the specified
namespace, submit the following HTTP GET request.
GET -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/namespaces/namespace-id/apps?artifactName=cdap-data-pipeline"
| Parameter | Description | 
|---|---|
| namespace-id | The namespace ID must either be the name of the
        namespace 
        when it was created
        or default, which is the name of the default namespace. | 
For more information, see Deployed Applications.
Retrieve real-time pipelines
To list Cloud Data Fusion real-time pipelines in the specified
namespace, submit the following HTTP GET request.
GET -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/namespaces/namespace-id/apps?artifactName=cdap-data-streams"
| Parameter | Description | 
|---|---|
| namespace-id | The namespace ID must either be the name of the
        namespace 
        when it was created
        or default, which is the name of the default namespace. | 
For more information, see Deployed Applications.
Retrieve pipeline details
To list the details of a pipeline in the specified namespace, submit the
following HTTP GET request:
GET -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/namespaces/namespace-id/apps/pipeline-name"
| Parameter | Description | 
|---|---|
| namespace-id | The namespace ID must either be the name of the
        namespace 
        when it was created
        or default, which is the name of the default namespace. | 
| pipeline-name | Your pipeline name. | 
For more information, see Details of a Deployed Application.
Batch pipelines
Start a batch pipeline
To start a batch pipeline, submit the following HTTP POST request.
POST -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/namespaces/namespace-id/apps/pipeline-name/workflows/DataPipelineWorkflow/start"
| Parameter | Description / value | 
|---|---|
| namespace-id | The namespace ID must either be the name of the
        namespace 
        when it was created
        or default, which is the name of the default namespace. | 
| pipeline-name | Your pipeline name. | 
For more information, see Start a Program.
Stop a batch pipeline
To stop a batch pipeline, submit the following HTTP POST request.
POST -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/namespaces/namespace-id/apps/pipeline-name/workflows/DataPipelineWorkflow/stop"
| Parameter | Description / value | 
|---|---|
| namespace-id | The namespace ID must either be the name of the
        namespace 
        when it was created
        or default, which is the name of the default namespace. | 
| pipeline-name | Your pipeline name. | 
For more information, see Stop a program.
Schedule a batch pipeline
Note: Scheduling is available only for batch pipelines.
By default, scheduling is disabled. To enable scheduling for your pipeline,
submit the following HTTP POST request.
POST -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/namespaces/namespace-id/apps/pipeline-name/schedules/dataPipelineSchedule/enable"
| Parameter | Description / value | 
|---|---|
| namespace-id | The namespace ID must either be the name of the
        namespace 
        when it was created
        or default, which is the name of the default namespace. | 
| pipeline-name | Your pipeline name. | 
For more information, see Schedule a Program.
Batch pipeline run records
To get the run records of a Cloud Data Fusion batch pipeline, submit the
following HTTP GET requests.
Run records of a batch pipeline
The returned information includes the run ids of a batch pipeline.
GET -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/namespaces/namespace-id/apps/pipeline-name/workflows/DataPipelineWorkflow/runs
Records of a batch pipeline run
GET -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/namespaces/namespace-id/apps/pipeline-name/workflows/DataPipelineWorkflow/runs/run-id
| Parameter | Description | 
|---|---|
| namespace-id | The namespace ID must either be the name of the
        namespace 
        when it was created
        or default, which is the name of the default namespace. | 
| pipeline-name | |
| run-id | To find the run ID, see Batch pipeline run records, which returns a list of run IDs. | 
For more information, see List Schedules.
Logs for a batch pipeline
You can view the logs of a pipeline or of a specific pipeline run.
- To view the logs of a batch pipeline, submit the following HTTP - GETrequest.- GET -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/namespaces/namespace-id/apps/pipeline-name/workflows/DataPipelineWorkflow/logs?start=start-ts&stop=stop-ts
- To view logs of a specific run of a batch pipeline, submit the following HTTP - GETrequest.- GET -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/namespaces/namespace-id/apps/pipeline-name/workflows/DataPipelineWorkflow/runs/run-id/logs?start=start-ts&stop=stop-ts"
| Parameter | Description / value | 
|---|---|
| namespace-id | The namespace ID must either be the name of the
        namespace 
        when it was created
        or default, which is the name of the default namespace. | 
| pipeline-name | Your pipeline name. | 
| run-id | Relevant only if you want to view logs of a specific pipeline run. To find the run ID, see Batch pipeline run records, which returns a list of run IDs. | 
For more information, see Downloading Application Logs.
Metrics for a batch pipeline
To view specific metrics for a batch pipeline, submit the following HTTP POST
request.
POST -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/metrics/query"
The body of the HTTP POST request is a JSON object in the following format:
{
  "query": {
    "tags": {
      "namespace": "default",
      "app": "pipeline name",
      "workflow": "DataPipelineWorkflow",
      "run": "run-id"
    },
    "metrics": [
      "metric1 name",
      "metric2 name",
      ...
    ],
    "timeRange": {
      "aggregate": true
    }
  }
}
| Query parameter | Description / value | 
|---|---|
| pipeline name | Your pipeline name. | 
| run-id | To find the run ID, see Batch pipeline run records, which returns a list of run IDs. | 
| metric name | Metric names follow the format: user.pipeline-stage.metric
 | 
For example, the following query gets the records.out and process.time.avg
metrics for the BigQuery stage of the batch pipeline, batch-pipeline.
{
  "query": {
    "tags": {
      "namespace": "default",
      "app": "batch-pipeline",
      "workflow": "DataPipelineWorkflow",
      "run": "81e3d583-f68b-11e9-aba0-0242b9f29569"
    },
    "metrics": [
      "user.BigQuery.records.out",
      "user.BigQuery.process.time.avg"
    ],
    "timeRange": {
      "aggregate": true
    }
  }
}
For more information, see CDAP Metrics Microservices and Cloud Data Fusion flow control.
Real-time pipelines
Start a real-time pipeline
To start a real-time pipeline, submit the following HTTP POST request.
POST -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/namespaces/namespace-id/apps/pipeline-name/spark/DataStreamsSparkStreaming/start"
| Parameter | Description / value | 
|---|---|
| namespace-id | The namespace ID must either be the name of the
        namespace 
        when it was created
        or default, which is the name of the default namespace. | 
| pipeline-name | Your pipeline name. | 
For more information, see Starting a Program.
Stop a real-time pipeline
To stop a real-time pipeline, submit the following HTTP POST request.
POST -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/namespaces/namespace-id/apps/pipeline-name/spark/DataStreamsSparkStreaming/stop"
| Parameter | Description / value | |
|---|---|---|
| namespace-id | The namespace ID must either be the name of the
        namespace 
        when it was created
        or default, which is the name of the default namespace. | |
| pipeline-name | pipeline-name | 
For more information, see Stop a Program.
Real-time pipeline run records
To get the run records of a Cloud Data Fusion real-time pipeline, submit the
following HTTP GET requests.
Run records of a real-time pipeline
The returned information includes the run ids of a real-time pipeline.
GET -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/namespaces/namespace-id/apps/pipeline-name/spark/DataStreamsSparkStreaming
Records of a real-time pipeline run
GET -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/namespaces/namespace-id/apps/pipeline-name/spark/DataStreamsSparkStreaming/run-id
| Parameter | Description | 
|---|---|
| namespace-id | The namespace ID must either be the name of the
        namespace 
        when it was created
        or default, which is the name of the default namespace. | 
| pipeline-name | Your pipeline name. | 
| run-id | To find the run ID, see Real-time pipeline run records, which returns a list of run IDs. | 
For more information, see List Schedules.
Logs for a real-time pipeline
You can view the logs of a pipeline or of a specific pipeline run.
- To view the logs of a real-time pipeline, submit the following HTTP - GETrequest.- GET -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/namespaces/namespace-id/apps/pipeline-name/spark/DataStreamsSparkStreaming/logs?start=start-ts&stop=stop-ts"
- To view logs of a specific run of a real-time pipeline, submit the following HTTP - GETrequest.- GET -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/namespaces/namespace-id/apps/pipeline-name/spark/DataStreamsSparkStreaming/runs/run-id/logs?start=start-ts&stop=stop-ts"
| Parameter | Description / value | 
|---|---|
| namespace-id | The namespace ID must either be the name of the
        namespace 
        when it was created
        or default, which is the name of the default namespace. | 
| pipeline-name | Your pipeline name. | 
| run-id | Relevant only if you want to view logs of a specific pipeline run. To find the run ID, call Real-time pipeline run records, which returns a list of run IDs. | 
For more information, see Downloading Application Logs.
Metrics for a real-time pipeline
To view specific metrics for a real-time pipeline, submit the following HTTP
POST request.
POST -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/metrics/query"
The body of the HTTP POST request is a JSON object in the following format:
{
  "query": {
    "tags": {
      "namespace": "default",
      "app": "pipeline name",
      "spark": "DataStreamsSparkStreaming",
      "run": "run-id"
    },
    "metrics": [
      "metric1 name",
      "metric2 name",
      ...
    ],
    "timeRange": {
      "aggregate": true
    }
  }
}
| Query parameter | Description / value | 
|---|---|
| pipeline name | Your pipeline name. | 
| run-id | To find the run ID, call Real-time pipeline run records, which returns a list of run IDs. | 
| metric name | Metric names follow the format: user.pipeline-stage.metric
 | 
For example, the following query gets the records.out and process.time.avg
metrics for the BigQuery stage of the real-time pipeline, rt-pipeline.
{
  "query": {
    "tags": {
      "namespace": "default",
      "app": "rt-pipeline",
      "spark": "DataStreamsSparkStreaming",
      "run": "81e3d583-f68b-11e9-aba0-0242b9f29570"
    },
    "metrics": [
      "user.BigQuery.records.out",
      "user.BigQuery.process.time.avg"
    ],
    "timeRange": {
      "aggregate": true
    }
  }
}
For more information, see Metrics HTTP RESTful API and Cloud Data Fusion flow control.
Dataset metadata
Metadata properties
To view metadata properties for your dataset, submit the following HTTP GET
request.
GET -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/namespaces/default/datasets/dataset-id/metadata/properties"
| Parameter | Description / value | 
|---|---|
| dataset-id | To get the dataset ID, submit an HTTP GETrequest that
        lists all
        datasets:GET -H "Authorization: Bearer $(gcloud auth print-access-token) ${CDAP_ENDPOINT}/v3/namespaces/namespace-id/data/datasetsYou can create a namespace. The namespace ID must either be the name of the namespace when it was created or default, which is the name of the default 
        namespace. | 
For more information, see Retrieving Properties.
Metadata tags
To view metadata tags for your dataset, submit the following HTTP GET request.
GET -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/namespaces/default/datasets/dataset-id/metadata/tags"
| Parameter | Description / value | 
|---|---|
| dataset-id | To get the dataset ID, submit an HTTP GETrequest that
        lists all
        datasets:GET -H "Authorization: Bearer $(gcloud auth print-access-token) ${CDAP_ENDPOINT}/v3/namespaces/namespace-id/data/datasets.
        You can
        create 
        a namespace.
        The namespace ID must either be the name of the namespace when it was 
        created ordefault, which is the name of the default 
        namespace. | 
For more information, see Retrieving Tags.
Lineage
Dataset lineage
To view the lineage of your dataset, submit the following HTTP GET request.
GET -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/namespaces/namespace-id/datasets/dataset-id/lineage?start=start-ts&end=end-ts"
| Parameter | Description / value | 
|---|---|
| namespace-id | The namespace ID must either be the name of the
        namespace 
        when it was created
        or default, which is the name of the default namespace. | 
| dataset-id | To get the dataset ID, submit an HTTP GETrequest that
        lists all
        datasets:GET -H "Authorization: Bearer $(gcloud auth print-access-token) ${CDAP_ENDPOINT}/v3/namespaces/namespace-id/data/datasets.
        You can 
        create 
        a namespace.
        The namespace ID must either be the name of the namespace when it was 
        created ordefault, which is the name of the default 
        namespace. | 
| start-ts | Starting timestamp of lineage in seconds. | 
| end-ts | Ending timestamp of lineage in seconds. | 
For more information, see Viewing Lineages.
Field level lineage
To view the lineage of fields in your dataset in a specified range of time,
submit the following HTTP GET request.
GET -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/namespaces/namespace-id/datasets/dataset-id/lineage/fields?start=start-ts&end=end-ts[&prefix=prefix>]"
| Parameter | Description / value | 
|---|---|
| namespace-id | The namespace ID must either be the name of the
        namespace 
        when it was created
        or default, which is the name of the default namespace. | 
| dataset-id | To get the dataset ID, submit an HTTP GETrequest that
        lists all
        datasets:GET -H "Authorization: Bearer $(gcloud auth print-access-token) ${CDAP_ENDPOINT}/v3/namespaces/namespace-id/data/datasets. | 
| start-ts | Starting timestamp of lineage in seconds. | 
| end-ts | Ending timestamp of lineage in seconds. | 
For more information, see Field Level Lineage.
Secure storage
Use the CDAP Secure Storage HTTP RESTful API to add, retrieve, and delete secure keys.
Add a secure key
To add a secure key to secure storage, submit the following HTTP PUT request.
PUT -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/namespaces/namespace-id/securekeys/secure-key-id"
| Parameter | Description | 
|---|---|
| namespace-id | The namespace ID must either be the name of the
        namespace 
        when it was created
        or default, which is the name of the default namespace. | 
| secure-key-id | Name of the key to add to secure storage. | 
The body of the HTTP PUT request is a JSON object in the following format:
{
  "description": "Example Secure Key",
  "data": "secure-contents",
  "properties": {
    "property-key": "property-value"
  }
}
For more information, see Add a Secure Key and the Administrator Guide: Secure Storage.
Retrieve a secure key
To retrieve a secure key from secure storage, submit the following HTTP GET
request.
GET -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/namespaces/namespace-id/securekeys/secure-key-id"
| Parameter | Description | 
|---|---|
| namespace-id | The namespace ID must either be the name of the
        namespace 
        when it was created
        or default, which is the name of the default namespace. | 
| secure-key-id | Name of the key to retrieve from secure storage. | 
For more information, see Retrieve a Secure Key and the Administration Manual: Secure Storage.
Retrieve the metadata for a secure key
To retrieve the metadata for a secure key from secure storage, submit the following HTTP GET
request.
GET -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/namespaces/namespace-id/securekeys/secure-key-id/metadata"
| Parameter | Description | 
|---|---|
| namespace-id | The namespace ID must either be the name of the
        namespace 
        when it was created
        or default, which is the name of the default namespace. | 
| secure-key-id | Name of the key to retrieve from secure storage. | 
The metadata of the secure key is returned as a JSON object— the secure key name (the secure-key-id), description, created timestamp, and the map of properties—in the response body.
Example response:
{
  "name": "secure-key-id",
  "description": "Example Secure Key",
  "createdEpochMs": 1471718010326,
  "properties": {
    "property-key": "property-value"
  }
}
For more information, see Retrieve a Secure Key, Retrieve the Metadata for a Secure Key, and the Administration Manual: Secure Storage.
List all secure keys
To list all the keys in a namespace from secure storage, submit the following
HTTP GET request.
GET -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/namespaces/namespace-id/securekeys"
| Parameter | Description | 
|---|---|
| namespace-id | The namespace ID must either be the name of the
        namespace 
        when it was created
        or default, which is the name of the default namespace. | 
For more information, see List all Secure Keys and the Administration Manual: Secure Storage.
Delete a secure key
To delete a secure key from secure storage, submit the following
HTTP DELETE request.
DELETE -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/namespaces/namespace-id/securekeys/secure-key-id"
| Parameter | Description | 
|---|---|
| namespace-id | The namespace ID must either be the name of the
        namespace 
        when it was created
        or default, which is the name of the default namespace. | 
| secure-key-id | Name of the key to delete from secure storage. | 
For more information, see Remove a Secure Key and the Administration Manual: Secure Storage.
Delete a namespace
To delete a Cloud Data Fusion namespace, submit the following HTTP PATCH
request to enable enable.unrecoverable.reset.
PATCH -H 'Content-Type: application/json' -H "Authorization: Bearer ${AUTH_TOKEN}" 'https://datafusion.googleapis.com/v1beta1/projects/project-id/locations/region/instances/instance-name?updateMask=options' -d '{ "options": { "enable.unrecoverable.reset": "true" } }'
After the enable.unrecoverable.reset property is set to true, restart the instance:
gcloud beta data-fusion instances restart --project=project-id --location=region instance-name
Delete the namespace with the following DELETE request or in the web interface.
DELETE -H "Authorization: Bearer ${AUTH_TOKEN}" "${CDAP_ENDPOINT}/v3/unrecoverable/namespaces/namespace-id"
To avoid accidental deletion of the namespaces, update the
enable.unrecoverable.reset property to set to false,
and restart
the instance .
PATCH -H 'Content-Type: application/json' -H "Authorization: Bearer ${AUTH_TOKEN}" 'https://datafusion.googleapis.com/v1beta1/projects/project-id/locations/region/instances/instance-name?updateMask=options' -d '{ "options": { "enable.unrecoverable.reset": "false" } }'
| Parameter | Description | 
|---|---|
| project-id | The project ID that hosts the Cloud Data Fusion instance. | 
| region | The location of your Cloud Data Fusion instance. | 
| instance-name | The Cloud Data Fusion instance name. | 
| namespace-id | The name of the namespace to delete. |