• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1<html><body>
2<style>
3
4body, h1, h2, h3, div, span, p, pre, a {
5  margin: 0;
6  padding: 0;
7  border: 0;
8  font-weight: inherit;
9  font-style: inherit;
10  font-size: 100%;
11  font-family: inherit;
12  vertical-align: baseline;
13}
14
15body {
16  font-size: 13px;
17  padding: 1em;
18}
19
20h1 {
21  font-size: 26px;
22  margin-bottom: 1em;
23}
24
25h2 {
26  font-size: 24px;
27  margin-bottom: 1em;
28}
29
30h3 {
31  font-size: 20px;
32  margin-bottom: 1em;
33  margin-top: 1em;
34}
35
36pre, code {
37  line-height: 1.5;
38  font-family: Monaco, 'DejaVu Sans Mono', 'Bitstream Vera Sans Mono', 'Lucida Console', monospace;
39}
40
41pre {
42  margin-top: 0.5em;
43}
44
45h1, h2, h3, p {
46  font-family: Arial, sans serif;
47}
48
49h1, h2, h3 {
50  border-bottom: solid #CCC 1px;
51}
52
53.toc_element {
54  margin-top: 0.5em;
55}
56
57.firstline {
58  margin-left: 2 em;
59}
60
61.method  {
62  margin-top: 1em;
63  border: solid 1px #CCC;
64  padding: 1em;
65  background: #EEE;
66}
67
68.details {
69  font-weight: bold;
70  font-size: 14px;
71}
72
73</style>
74
75<h1><a href="genomics_v1alpha2.html">Genomics API</a> . <a href="genomics_v1alpha2.pipelines.html">pipelines</a></h1>
76<h2>Instance Methods</h2>
77<p class="toc_element">
78  <code><a href="#create">create(body, x__xgafv=None)</a></code></p>
79<p class="firstline">Creates a pipeline that can be run later. Create takes a Pipeline that</p>
80<p class="toc_element">
81  <code><a href="#delete">delete(pipelineId, x__xgafv=None)</a></code></p>
82<p class="firstline">Deletes a pipeline based on ID.</p>
83<p class="toc_element">
84  <code><a href="#get">get(pipelineId, x__xgafv=None)</a></code></p>
85<p class="firstline">Retrieves a pipeline based on ID.</p>
86<p class="toc_element">
87  <code><a href="#getControllerConfig">getControllerConfig(validationToken=None, x__xgafv=None, operationId=None)</a></code></p>
88<p class="firstline">Gets controller configuration information. Should only be called</p>
89<p class="toc_element">
90  <code><a href="#list">list(pageSize=None, projectId=None, namePrefix=None, pageToken=None, x__xgafv=None)</a></code></p>
91<p class="firstline">Lists pipelines.</p>
92<p class="toc_element">
93  <code><a href="#list_next">list_next(previous_request, previous_response)</a></code></p>
94<p class="firstline">Retrieves the next page of results.</p>
95<p class="toc_element">
96  <code><a href="#run">run(body, x__xgafv=None)</a></code></p>
97<p class="firstline">Runs a pipeline. If `pipelineId` is specified in the request, then</p>
98<p class="toc_element">
99  <code><a href="#setOperationStatus">setOperationStatus(body, x__xgafv=None)</a></code></p>
100<p class="firstline">Sets status of a given operation. Any new timestamps (as determined by</p>
101<h3>Method Details</h3>
102<div class="method">
103    <code class="details" id="create">create(body, x__xgafv=None)</code>
104  <pre>Creates a pipeline that can be run later. Create takes a Pipeline that
105has all fields other than `pipelineId` populated, and then returns
106the same pipeline with `pipelineId` populated. This id can be used
107to run the pipeline.
108
109Caller must have WRITE permission to the project.
110
111Args:
112  body: object, The request body. (required)
113    The object takes the form of:
114
115{ # The pipeline object. Represents a transformation from a set of input
116    # parameters to a set of output parameters. The transformation is defined
117    # as a docker image and command to run within that image. Each pipeline
118    # is run on a Google Compute Engine VM. A pipeline can be created with the
119    # `create` method and then later run with the `run` method, or a pipeline can
120    # be defined and run all at once with the `run` method.
121  "pipelineId": "A String", # Unique pipeline id that is generated by the service when CreatePipeline
122      # is called. Cannot be specified in the Pipeline used in the
123      # CreatePipelineRequest, and will be populated in the response to
124      # CreatePipeline and all subsequent Get and List calls. Indicates that the
125      # service has registered this pipeline.
126  "name": "A String", # Required. A user specified pipeline name that does not have to be unique.
127      # This name can be used for filtering Pipelines in ListPipelines.
128  "projectId": "A String", # Required. The project in which to create the pipeline. The caller must have
129      # WRITE access.
130  "outputParameters": [ # Output parameters of the pipeline.
131    { # Parameters facilitate setting and delivering data into the
132        # pipeline's execution environment. They are defined at create time,
133        # with optional defaults, and can be overridden at run time.
134        #
135        # If `localCopy` is unset, then the parameter specifies a string that
136        # is passed as-is into the pipeline, as the value of the environment
137        # variable with the given name.  A default value can be optionally
138        # specified at create time. The default can be overridden at run time
139        # using the inputs map. If no default is given, a value must be
140        # supplied at runtime.
141        #
142        # If `localCopy` is defined, then the parameter specifies a data
143        # source or sink, both in Google Cloud Storage and on the Docker container
144        # where the pipeline computation is run. The service account associated with
145        # the Pipeline (by
146        # default the project's Compute Engine service account) must have access to the
147        # Google Cloud Storage paths.
148        #
149        # At run time, the Google Cloud Storage paths can be overridden if a default
150        # was provided at create time, or must be set otherwise. The pipeline runner
151        # should add a key/value pair to either the inputs or outputs map. The
152        # indicated data copies will be carried out before/after pipeline execution,
153        # just as if the corresponding arguments were provided to `gsutil cp`.
154        #
155        # For example: Given the following `PipelineParameter`, specified
156        # in the `inputParameters` list:
157        #
158        # ```
159        # {name: "input_file", localCopy: {path: "file.txt", disk: "pd1"}}
160        # ```
161        #
162        # where `disk` is defined in the `PipelineResources` object as:
163        #
164        # ```
165        # {name: "pd1", mountPoint: "/mnt/disk/"}
166        # ```
167        #
168        # We create a disk named `pd1`, mount it on the host VM, and map
169        # `/mnt/pd1` to `/mnt/disk` in the docker container.  At
170        # runtime, an entry for `input_file` would be required in the inputs
171        # map, such as:
172        #
173        # ```
174        #   inputs["input_file"] = "gs://my-bucket/bar.txt"
175        # ```
176        #
177        # This would generate the following gsutil call:
178        #
179        # ```
180        #   gsutil cp gs://my-bucket/bar.txt /mnt/pd1/file.txt
181        # ```
182        #
183        # The file `/mnt/pd1/file.txt` maps to `/mnt/disk/file.txt` in the
184        # Docker container. Acceptable paths are:
185        #
186        # <table>
187        #   <thead>
188        #     <tr><th>Google Cloud storage path</th><th>Local path</th></tr>
189        #   </thead>
190        #   <tbody>
191        #     <tr><td>file</td><td>file</td></tr>
192        #     <tr><td>glob</td><td>directory</td></tr>
193        #   </tbody>
194        # </table>
195        #
196        # For outputs, the direction of the copy is reversed:
197        #
198        # ```
199        #   gsutil cp /mnt/disk/file.txt gs://my-bucket/bar.txt
200        # ```
201        #
202        # Acceptable paths are:
203        #
204        # <table>
205        #   <thead>
206        #     <tr><th>Local path</th><th>Google Cloud Storage path</th></tr>
207        #   </thead>
208        #   <tbody>
209        #     <tr><td>file</td><td>file</td></tr>
210        #     <tr>
211        #       <td>file</td>
212        #       <td>directory - directory must already exist</td>
213        #     </tr>
214        #     <tr>
215        #       <td>glob</td>
216        #       <td>directory - directory will be created if it doesn't exist</td></tr>
217        #   </tbody>
218        # </table>
219        #
220        # One restriction due to docker limitations, is that for outputs that are found
221        # on the boot disk, the local path cannot be a glob and must be a file.
222      "defaultValue": "A String", # The default value for this parameter. Can be overridden at runtime.
223          # If `localCopy` is present, then this must be a Google Cloud Storage path
224          # beginning with `gs://`.
225      "description": "A String", # Human-readable description.
226      "name": "A String", # Required. Name of the parameter - the pipeline runner uses this string
227          # as the key to the input and output maps in RunPipeline.
228      "localCopy": { # LocalCopy defines how a remote file should be copied to and from the VM. # If present, this parameter is marked for copying to and from the VM.
229          # `LocalCopy` indicates where on the VM the file should be. The value
230          # given to this parameter (either at runtime or using `defaultValue`)
231          # must be the remote path where the file should be.
232        "path": "A String", # Required. The path within the user's docker container where
233            # this input should be localized to and from, relative to the specified
234            # disk's mount point. For example: file.txt,
235        "disk": "A String", # Required. The name of the disk where this parameter is
236            # located. Can be the name of one of the disks specified in the
237            # Resources field, or "boot", which represents the Docker
238            # instance's boot disk and has a mount point of `/`.
239      },
240    },
241  ],
242  "inputParameters": [ # Input parameters of the pipeline.
243    { # Parameters facilitate setting and delivering data into the
244        # pipeline's execution environment. They are defined at create time,
245        # with optional defaults, and can be overridden at run time.
246        #
247        # If `localCopy` is unset, then the parameter specifies a string that
248        # is passed as-is into the pipeline, as the value of the environment
249        # variable with the given name.  A default value can be optionally
250        # specified at create time. The default can be overridden at run time
251        # using the inputs map. If no default is given, a value must be
252        # supplied at runtime.
253        #
254        # If `localCopy` is defined, then the parameter specifies a data
255        # source or sink, both in Google Cloud Storage and on the Docker container
256        # where the pipeline computation is run. The service account associated with
257        # the Pipeline (by
258        # default the project's Compute Engine service account) must have access to the
259        # Google Cloud Storage paths.
260        #
261        # At run time, the Google Cloud Storage paths can be overridden if a default
262        # was provided at create time, or must be set otherwise. The pipeline runner
263        # should add a key/value pair to either the inputs or outputs map. The
264        # indicated data copies will be carried out before/after pipeline execution,
265        # just as if the corresponding arguments were provided to `gsutil cp`.
266        #
267        # For example: Given the following `PipelineParameter`, specified
268        # in the `inputParameters` list:
269        #
270        # ```
271        # {name: "input_file", localCopy: {path: "file.txt", disk: "pd1"}}
272        # ```
273        #
274        # where `disk` is defined in the `PipelineResources` object as:
275        #
276        # ```
277        # {name: "pd1", mountPoint: "/mnt/disk/"}
278        # ```
279        #
280        # We create a disk named `pd1`, mount it on the host VM, and map
281        # `/mnt/pd1` to `/mnt/disk` in the docker container.  At
282        # runtime, an entry for `input_file` would be required in the inputs
283        # map, such as:
284        #
285        # ```
286        #   inputs["input_file"] = "gs://my-bucket/bar.txt"
287        # ```
288        #
289        # This would generate the following gsutil call:
290        #
291        # ```
292        #   gsutil cp gs://my-bucket/bar.txt /mnt/pd1/file.txt
293        # ```
294        #
295        # The file `/mnt/pd1/file.txt` maps to `/mnt/disk/file.txt` in the
296        # Docker container. Acceptable paths are:
297        #
298        # <table>
299        #   <thead>
300        #     <tr><th>Google Cloud storage path</th><th>Local path</th></tr>
301        #   </thead>
302        #   <tbody>
303        #     <tr><td>file</td><td>file</td></tr>
304        #     <tr><td>glob</td><td>directory</td></tr>
305        #   </tbody>
306        # </table>
307        #
308        # For outputs, the direction of the copy is reversed:
309        #
310        # ```
311        #   gsutil cp /mnt/disk/file.txt gs://my-bucket/bar.txt
312        # ```
313        #
314        # Acceptable paths are:
315        #
316        # <table>
317        #   <thead>
318        #     <tr><th>Local path</th><th>Google Cloud Storage path</th></tr>
319        #   </thead>
320        #   <tbody>
321        #     <tr><td>file</td><td>file</td></tr>
322        #     <tr>
323        #       <td>file</td>
324        #       <td>directory - directory must already exist</td>
325        #     </tr>
326        #     <tr>
327        #       <td>glob</td>
328        #       <td>directory - directory will be created if it doesn't exist</td></tr>
329        #   </tbody>
330        # </table>
331        #
332        # One restriction due to docker limitations, is that for outputs that are found
333        # on the boot disk, the local path cannot be a glob and must be a file.
334      "defaultValue": "A String", # The default value for this parameter. Can be overridden at runtime.
335          # If `localCopy` is present, then this must be a Google Cloud Storage path
336          # beginning with `gs://`.
337      "description": "A String", # Human-readable description.
338      "name": "A String", # Required. Name of the parameter - the pipeline runner uses this string
339          # as the key to the input and output maps in RunPipeline.
340      "localCopy": { # LocalCopy defines how a remote file should be copied to and from the VM. # If present, this parameter is marked for copying to and from the VM.
341          # `LocalCopy` indicates where on the VM the file should be. The value
342          # given to this parameter (either at runtime or using `defaultValue`)
343          # must be the remote path where the file should be.
344        "path": "A String", # Required. The path within the user's docker container where
345            # this input should be localized to and from, relative to the specified
346            # disk's mount point. For example: file.txt,
347        "disk": "A String", # Required. The name of the disk where this parameter is
348            # located. Can be the name of one of the disks specified in the
349            # Resources field, or "boot", which represents the Docker
350            # instance's boot disk and has a mount point of `/`.
351      },
352    },
353  ],
354  "docker": { # The Docker execuctor specification. # Specifies the docker run information.
355    "cmd": "A String", # Required. The command or newline delimited script to run. The command
356        # string will be executed within a bash shell.
357        #
358        # If the command exits with a non-zero exit code, output parameter
359        # de-localization will be skipped and the pipeline operation's
360        # `error` field will be populated.
361        #
362        # Maximum command string length is 16384.
363    "imageName": "A String", # Required. Image name from either Docker Hub or Google Container Registry.
364        # Users that run pipelines must have READ access to the image.
365  },
366  "resources": { # The system resources for the pipeline run. # Required. Specifies resource requirements for the pipeline run.
367      # Required fields:
368      #
369      # *
370      # minimumCpuCores
371      #
372      # *
373      # minimumRamGb
374    "noAddress": True or False, # Whether to assign an external IP to the instance. This is an experimental
375        # feature that may go away. Defaults to false.
376        # Corresponds to `--no_address` flag for [gcloud compute instances create]
377        # (https://cloud.google.com/sdk/gcloud/reference/compute/instances/create).
378        # In order to use this, must be true for both create time and run time.
379        # Cannot be true at run time if false at create time. If you need to ssh into
380        # a private IP VM for debugging, you can ssh to a public VM and then ssh into
381        # the private VM's Internal IP.  If noAddress is set, this pipeline run may
382        # only load docker images from Google Container Registry and not Docker Hub.
383        # Before using this, you must
384        # [configure access to Google services from internal IPs](https://cloud.google.com/compute/docs/configure-private-google-access#configuring_access_to_google_services_from_internal_ips).
385    "minimumRamGb": 3.14, # The minimum amount of RAM to use. Defaults to 3.75 (GB)
386    "preemptible": True or False, # Whether to use preemptible VMs. Defaults to `false`. In order to use this,
387        # must be true for both create time and run time. Cannot be true at run time
388        # if false at create time.
389    "disks": [ # Disks to attach.
390      { # A Google Compute Engine disk resource specification.
391        "autoDelete": True or False, # Deprecated. Disks created by the Pipelines API will be deleted at the end
392            # of the pipeline run, regardless of what this field is set to.
393        "sizeGb": 42, # The size of the disk. Defaults to 500 (GB).
394            # This field is not applicable for local SSD.
395        "source": "A String", # The full or partial URL of the persistent disk to attach. See
396            # https://cloud.google.com/compute/docs/reference/latest/instances#resource
397            # and
398            # https://cloud.google.com/compute/docs/disks/persistent-disks#snapshots
399            # for more details.
400        "readOnly": True or False, # Specifies how a sourced-base persistent disk will be mounted. See
401            # https://cloud.google.com/compute/docs/disks/persistent-disks#use_multi_instances
402            # for more details.
403            # Can only be set at create time.
404        "mountPoint": "A String", # Required at create time and cannot be overridden at run time.
405            # Specifies the path in the docker container where files on
406            # this disk should be located. For example, if `mountPoint`
407            # is `/mnt/disk`, and the parameter has `localPath`
408            # `inputs/file.txt`, the docker container can access the data at
409            # `/mnt/disk/inputs/file.txt`.
410        "type": "A String", # Required. The type of the disk to create.
411        "name": "A String", # Required. The name of the disk that can be used in the pipeline
412            # parameters. Must be 1 - 63 characters.
413            # The name "boot" is reserved for system use.
414      },
415    ],
416    "bootDiskSizeGb": 42, # The size of the boot disk. Defaults to 10 (GB).
417    "zones": [ # List of Google Compute Engine availability zones to which resource
418        # creation will restricted. If empty, any zone may be chosen.
419      "A String",
420    ],
421    "minimumCpuCores": 42, # The minimum number of cores to use. Defaults to 1.
422  },
423  "description": "A String", # User-specified description.
424}
425
426  x__xgafv: string, V1 error format.
427    Allowed values
428      1 - v1 error format
429      2 - v2 error format
430
431Returns:
432  An object of the form:
433
434    { # The pipeline object. Represents a transformation from a set of input
435      # parameters to a set of output parameters. The transformation is defined
436      # as a docker image and command to run within that image. Each pipeline
437      # is run on a Google Compute Engine VM. A pipeline can be created with the
438      # `create` method and then later run with the `run` method, or a pipeline can
439      # be defined and run all at once with the `run` method.
440    "pipelineId": "A String", # Unique pipeline id that is generated by the service when CreatePipeline
441        # is called. Cannot be specified in the Pipeline used in the
442        # CreatePipelineRequest, and will be populated in the response to
443        # CreatePipeline and all subsequent Get and List calls. Indicates that the
444        # service has registered this pipeline.
445    "name": "A String", # Required. A user specified pipeline name that does not have to be unique.
446        # This name can be used for filtering Pipelines in ListPipelines.
447    "projectId": "A String", # Required. The project in which to create the pipeline. The caller must have
448        # WRITE access.
449    "outputParameters": [ # Output parameters of the pipeline.
450      { # Parameters facilitate setting and delivering data into the
451          # pipeline's execution environment. They are defined at create time,
452          # with optional defaults, and can be overridden at run time.
453          #
454          # If `localCopy` is unset, then the parameter specifies a string that
455          # is passed as-is into the pipeline, as the value of the environment
456          # variable with the given name.  A default value can be optionally
457          # specified at create time. The default can be overridden at run time
458          # using the inputs map. If no default is given, a value must be
459          # supplied at runtime.
460          #
461          # If `localCopy` is defined, then the parameter specifies a data
462          # source or sink, both in Google Cloud Storage and on the Docker container
463          # where the pipeline computation is run. The service account associated with
464          # the Pipeline (by
465          # default the project's Compute Engine service account) must have access to the
466          # Google Cloud Storage paths.
467          #
468          # At run time, the Google Cloud Storage paths can be overridden if a default
469          # was provided at create time, or must be set otherwise. The pipeline runner
470          # should add a key/value pair to either the inputs or outputs map. The
471          # indicated data copies will be carried out before/after pipeline execution,
472          # just as if the corresponding arguments were provided to `gsutil cp`.
473          #
474          # For example: Given the following `PipelineParameter`, specified
475          # in the `inputParameters` list:
476          #
477          # ```
478          # {name: "input_file", localCopy: {path: "file.txt", disk: "pd1"}}
479          # ```
480          #
481          # where `disk` is defined in the `PipelineResources` object as:
482          #
483          # ```
484          # {name: "pd1", mountPoint: "/mnt/disk/"}
485          # ```
486          #
487          # We create a disk named `pd1`, mount it on the host VM, and map
488          # `/mnt/pd1` to `/mnt/disk` in the docker container.  At
489          # runtime, an entry for `input_file` would be required in the inputs
490          # map, such as:
491          #
492          # ```
493          #   inputs["input_file"] = "gs://my-bucket/bar.txt"
494          # ```
495          #
496          # This would generate the following gsutil call:
497          #
498          # ```
499          #   gsutil cp gs://my-bucket/bar.txt /mnt/pd1/file.txt
500          # ```
501          #
502          # The file `/mnt/pd1/file.txt` maps to `/mnt/disk/file.txt` in the
503          # Docker container. Acceptable paths are:
504          #
505          # <table>
506          #   <thead>
507          #     <tr><th>Google Cloud storage path</th><th>Local path</th></tr>
508          #   </thead>
509          #   <tbody>
510          #     <tr><td>file</td><td>file</td></tr>
511          #     <tr><td>glob</td><td>directory</td></tr>
512          #   </tbody>
513          # </table>
514          #
515          # For outputs, the direction of the copy is reversed:
516          #
517          # ```
518          #   gsutil cp /mnt/disk/file.txt gs://my-bucket/bar.txt
519          # ```
520          #
521          # Acceptable paths are:
522          #
523          # <table>
524          #   <thead>
525          #     <tr><th>Local path</th><th>Google Cloud Storage path</th></tr>
526          #   </thead>
527          #   <tbody>
528          #     <tr><td>file</td><td>file</td></tr>
529          #     <tr>
530          #       <td>file</td>
531          #       <td>directory - directory must already exist</td>
532          #     </tr>
533          #     <tr>
534          #       <td>glob</td>
535          #       <td>directory - directory will be created if it doesn't exist</td></tr>
536          #   </tbody>
537          # </table>
538          #
539          # One restriction due to docker limitations, is that for outputs that are found
540          # on the boot disk, the local path cannot be a glob and must be a file.
541        "defaultValue": "A String", # The default value for this parameter. Can be overridden at runtime.
542            # If `localCopy` is present, then this must be a Google Cloud Storage path
543            # beginning with `gs://`.
544        "description": "A String", # Human-readable description.
545        "name": "A String", # Required. Name of the parameter - the pipeline runner uses this string
546            # as the key to the input and output maps in RunPipeline.
547        "localCopy": { # LocalCopy defines how a remote file should be copied to and from the VM. # If present, this parameter is marked for copying to and from the VM.
548            # `LocalCopy` indicates where on the VM the file should be. The value
549            # given to this parameter (either at runtime or using `defaultValue`)
550            # must be the remote path where the file should be.
551          "path": "A String", # Required. The path within the user's docker container where
552              # this input should be localized to and from, relative to the specified
553              # disk's mount point. For example: file.txt,
554          "disk": "A String", # Required. The name of the disk where this parameter is
555              # located. Can be the name of one of the disks specified in the
556              # Resources field, or "boot", which represents the Docker
557              # instance's boot disk and has a mount point of `/`.
558        },
559      },
560    ],
561    "inputParameters": [ # Input parameters of the pipeline.
562      { # Parameters facilitate setting and delivering data into the
563          # pipeline's execution environment. They are defined at create time,
564          # with optional defaults, and can be overridden at run time.
565          #
566          # If `localCopy` is unset, then the parameter specifies a string that
567          # is passed as-is into the pipeline, as the value of the environment
568          # variable with the given name.  A default value can be optionally
569          # specified at create time. The default can be overridden at run time
570          # using the inputs map. If no default is given, a value must be
571          # supplied at runtime.
572          #
573          # If `localCopy` is defined, then the parameter specifies a data
574          # source or sink, both in Google Cloud Storage and on the Docker container
575          # where the pipeline computation is run. The service account associated with
576          # the Pipeline (by
577          # default the project's Compute Engine service account) must have access to the
578          # Google Cloud Storage paths.
579          #
580          # At run time, the Google Cloud Storage paths can be overridden if a default
581          # was provided at create time, or must be set otherwise. The pipeline runner
582          # should add a key/value pair to either the inputs or outputs map. The
583          # indicated data copies will be carried out before/after pipeline execution,
584          # just as if the corresponding arguments were provided to `gsutil cp`.
585          #
586          # For example: Given the following `PipelineParameter`, specified
587          # in the `inputParameters` list:
588          #
589          # ```
590          # {name: "input_file", localCopy: {path: "file.txt", disk: "pd1"}}
591          # ```
592          #
593          # where `disk` is defined in the `PipelineResources` object as:
594          #
595          # ```
596          # {name: "pd1", mountPoint: "/mnt/disk/"}
597          # ```
598          #
599          # We create a disk named `pd1`, mount it on the host VM, and map
600          # `/mnt/pd1` to `/mnt/disk` in the docker container.  At
601          # runtime, an entry for `input_file` would be required in the inputs
602          # map, such as:
603          #
604          # ```
605          #   inputs["input_file"] = "gs://my-bucket/bar.txt"
606          # ```
607          #
608          # This would generate the following gsutil call:
609          #
610          # ```
611          #   gsutil cp gs://my-bucket/bar.txt /mnt/pd1/file.txt
612          # ```
613          #
614          # The file `/mnt/pd1/file.txt` maps to `/mnt/disk/file.txt` in the
615          # Docker container. Acceptable paths are:
616          #
617          # <table>
618          #   <thead>
619          #     <tr><th>Google Cloud storage path</th><th>Local path</th></tr>
620          #   </thead>
621          #   <tbody>
622          #     <tr><td>file</td><td>file</td></tr>
623          #     <tr><td>glob</td><td>directory</td></tr>
624          #   </tbody>
625          # </table>
626          #
627          # For outputs, the direction of the copy is reversed:
628          #
629          # ```
630          #   gsutil cp /mnt/disk/file.txt gs://my-bucket/bar.txt
631          # ```
632          #
633          # Acceptable paths are:
634          #
635          # <table>
636          #   <thead>
637          #     <tr><th>Local path</th><th>Google Cloud Storage path</th></tr>
638          #   </thead>
639          #   <tbody>
640          #     <tr><td>file</td><td>file</td></tr>
641          #     <tr>
642          #       <td>file</td>
643          #       <td>directory - directory must already exist</td>
644          #     </tr>
645          #     <tr>
646          #       <td>glob</td>
647          #       <td>directory - directory will be created if it doesn't exist</td></tr>
648          #   </tbody>
649          # </table>
650          #
651          # One restriction due to docker limitations, is that for outputs that are found
652          # on the boot disk, the local path cannot be a glob and must be a file.
653        "defaultValue": "A String", # The default value for this parameter. Can be overridden at runtime.
654            # If `localCopy` is present, then this must be a Google Cloud Storage path
655            # beginning with `gs://`.
656        "description": "A String", # Human-readable description.
657        "name": "A String", # Required. Name of the parameter - the pipeline runner uses this string
658            # as the key to the input and output maps in RunPipeline.
659        "localCopy": { # LocalCopy defines how a remote file should be copied to and from the VM. # If present, this parameter is marked for copying to and from the VM.
660            # `LocalCopy` indicates where on the VM the file should be. The value
661            # given to this parameter (either at runtime or using `defaultValue`)
662            # must be the remote path where the file should be.
663          "path": "A String", # Required. The path within the user's docker container where
664              # this input should be localized to and from, relative to the specified
665              # disk's mount point. For example: file.txt,
666          "disk": "A String", # Required. The name of the disk where this parameter is
667              # located. Can be the name of one of the disks specified in the
668              # Resources field, or "boot", which represents the Docker
669              # instance's boot disk and has a mount point of `/`.
670        },
671      },
672    ],
673    "docker": { # The Docker execuctor specification. # Specifies the docker run information.
674      "cmd": "A String", # Required. The command or newline delimited script to run. The command
675          # string will be executed within a bash shell.
676          #
677          # If the command exits with a non-zero exit code, output parameter
678          # de-localization will be skipped and the pipeline operation's
679          # `error` field will be populated.
680          #
681          # Maximum command string length is 16384.
682      "imageName": "A String", # Required. Image name from either Docker Hub or Google Container Registry.
683          # Users that run pipelines must have READ access to the image.
684    },
685    "resources": { # The system resources for the pipeline run. # Required. Specifies resource requirements for the pipeline run.
686        # Required fields:
687        #
688        # *
689        # minimumCpuCores
690        #
691        # *
692        # minimumRamGb
693      "noAddress": True or False, # Whether to assign an external IP to the instance. This is an experimental
694          # feature that may go away. Defaults to false.
695          # Corresponds to `--no_address` flag for [gcloud compute instances create]
696          # (https://cloud.google.com/sdk/gcloud/reference/compute/instances/create).
697          # In order to use this, must be true for both create time and run time.
698          # Cannot be true at run time if false at create time. If you need to ssh into
699          # a private IP VM for debugging, you can ssh to a public VM and then ssh into
700          # the private VM's Internal IP.  If noAddress is set, this pipeline run may
701          # only load docker images from Google Container Registry and not Docker Hub.
702          # Before using this, you must
703          # [configure access to Google services from internal IPs](https://cloud.google.com/compute/docs/configure-private-google-access#configuring_access_to_google_services_from_internal_ips).
704      "minimumRamGb": 3.14, # The minimum amount of RAM to use. Defaults to 3.75 (GB)
705      "preemptible": True or False, # Whether to use preemptible VMs. Defaults to `false`. In order to use this,
706          # must be true for both create time and run time. Cannot be true at run time
707          # if false at create time.
708      "disks": [ # Disks to attach.
709        { # A Google Compute Engine disk resource specification.
710          "autoDelete": True or False, # Deprecated. Disks created by the Pipelines API will be deleted at the end
711              # of the pipeline run, regardless of what this field is set to.
712          "sizeGb": 42, # The size of the disk. Defaults to 500 (GB).
713              # This field is not applicable for local SSD.
714          "source": "A String", # The full or partial URL of the persistent disk to attach. See
715              # https://cloud.google.com/compute/docs/reference/latest/instances#resource
716              # and
717              # https://cloud.google.com/compute/docs/disks/persistent-disks#snapshots
718              # for more details.
719          "readOnly": True or False, # Specifies how a sourced-base persistent disk will be mounted. See
720              # https://cloud.google.com/compute/docs/disks/persistent-disks#use_multi_instances
721              # for more details.
722              # Can only be set at create time.
723          "mountPoint": "A String", # Required at create time and cannot be overridden at run time.
724              # Specifies the path in the docker container where files on
725              # this disk should be located. For example, if `mountPoint`
726              # is `/mnt/disk`, and the parameter has `localPath`
727              # `inputs/file.txt`, the docker container can access the data at
728              # `/mnt/disk/inputs/file.txt`.
729          "type": "A String", # Required. The type of the disk to create.
730          "name": "A String", # Required. The name of the disk that can be used in the pipeline
731              # parameters. Must be 1 - 63 characters.
732              # The name "boot" is reserved for system use.
733        },
734      ],
735      "bootDiskSizeGb": 42, # The size of the boot disk. Defaults to 10 (GB).
736      "zones": [ # List of Google Compute Engine availability zones to which resource
737          # creation will restricted. If empty, any zone may be chosen.
738        "A String",
739      ],
740      "minimumCpuCores": 42, # The minimum number of cores to use. Defaults to 1.
741    },
742    "description": "A String", # User-specified description.
743  }</pre>
744</div>
745
746<div class="method">
747    <code class="details" id="delete">delete(pipelineId, x__xgafv=None)</code>
748  <pre>Deletes a pipeline based on ID.
749
750Caller must have WRITE permission to the project.
751
752Args:
753  pipelineId: string, Caller must have WRITE access to the project in which this pipeline
754is defined. (required)
755  x__xgafv: string, V1 error format.
756    Allowed values
757      1 - v1 error format
758      2 - v2 error format
759
760Returns:
761  An object of the form:
762
763    { # A generic empty message that you can re-use to avoid defining duplicated
764      # empty messages in your APIs. A typical example is to use it as the request
765      # or the response type of an API method. For instance:
766      #
767      #     service Foo {
768      #       rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty);
769      #     }
770      #
771      # The JSON representation for `Empty` is empty JSON object `{}`.
772  }</pre>
773</div>
774
775<div class="method">
776    <code class="details" id="get">get(pipelineId, x__xgafv=None)</code>
777  <pre>Retrieves a pipeline based on ID.
778
779Caller must have READ permission to the project.
780
781Args:
782  pipelineId: string, Caller must have READ access to the project in which this pipeline
783is defined. (required)
784  x__xgafv: string, V1 error format.
785    Allowed values
786      1 - v1 error format
787      2 - v2 error format
788
789Returns:
790  An object of the form:
791
792    { # The pipeline object. Represents a transformation from a set of input
793      # parameters to a set of output parameters. The transformation is defined
794      # as a docker image and command to run within that image. Each pipeline
795      # is run on a Google Compute Engine VM. A pipeline can be created with the
796      # `create` method and then later run with the `run` method, or a pipeline can
797      # be defined and run all at once with the `run` method.
798    "pipelineId": "A String", # Unique pipeline id that is generated by the service when CreatePipeline
799        # is called. Cannot be specified in the Pipeline used in the
800        # CreatePipelineRequest, and will be populated in the response to
801        # CreatePipeline and all subsequent Get and List calls. Indicates that the
802        # service has registered this pipeline.
803    "name": "A String", # Required. A user specified pipeline name that does not have to be unique.
804        # This name can be used for filtering Pipelines in ListPipelines.
805    "projectId": "A String", # Required. The project in which to create the pipeline. The caller must have
806        # WRITE access.
807    "outputParameters": [ # Output parameters of the pipeline.
808      { # Parameters facilitate setting and delivering data into the
809          # pipeline's execution environment. They are defined at create time,
810          # with optional defaults, and can be overridden at run time.
811          #
812          # If `localCopy` is unset, then the parameter specifies a string that
813          # is passed as-is into the pipeline, as the value of the environment
814          # variable with the given name.  A default value can be optionally
815          # specified at create time. The default can be overridden at run time
816          # using the inputs map. If no default is given, a value must be
817          # supplied at runtime.
818          #
819          # If `localCopy` is defined, then the parameter specifies a data
820          # source or sink, both in Google Cloud Storage and on the Docker container
821          # where the pipeline computation is run. The service account associated with
822          # the Pipeline (by
823          # default the project's Compute Engine service account) must have access to the
824          # Google Cloud Storage paths.
825          #
826          # At run time, the Google Cloud Storage paths can be overridden if a default
827          # was provided at create time, or must be set otherwise. The pipeline runner
828          # should add a key/value pair to either the inputs or outputs map. The
829          # indicated data copies will be carried out before/after pipeline execution,
830          # just as if the corresponding arguments were provided to `gsutil cp`.
831          #
832          # For example: Given the following `PipelineParameter`, specified
833          # in the `inputParameters` list:
834          #
835          # ```
836          # {name: "input_file", localCopy: {path: "file.txt", disk: "pd1"}}
837          # ```
838          #
839          # where `disk` is defined in the `PipelineResources` object as:
840          #
841          # ```
842          # {name: "pd1", mountPoint: "/mnt/disk/"}
843          # ```
844          #
845          # We create a disk named `pd1`, mount it on the host VM, and map
846          # `/mnt/pd1` to `/mnt/disk` in the docker container.  At
847          # runtime, an entry for `input_file` would be required in the inputs
848          # map, such as:
849          #
850          # ```
851          #   inputs["input_file"] = "gs://my-bucket/bar.txt"
852          # ```
853          #
854          # This would generate the following gsutil call:
855          #
856          # ```
857          #   gsutil cp gs://my-bucket/bar.txt /mnt/pd1/file.txt
858          # ```
859          #
860          # The file `/mnt/pd1/file.txt` maps to `/mnt/disk/file.txt` in the
861          # Docker container. Acceptable paths are:
862          #
863          # <table>
864          #   <thead>
865          #     <tr><th>Google Cloud storage path</th><th>Local path</th></tr>
866          #   </thead>
867          #   <tbody>
868          #     <tr><td>file</td><td>file</td></tr>
869          #     <tr><td>glob</td><td>directory</td></tr>
870          #   </tbody>
871          # </table>
872          #
873          # For outputs, the direction of the copy is reversed:
874          #
875          # ```
876          #   gsutil cp /mnt/disk/file.txt gs://my-bucket/bar.txt
877          # ```
878          #
879          # Acceptable paths are:
880          #
881          # <table>
882          #   <thead>
883          #     <tr><th>Local path</th><th>Google Cloud Storage path</th></tr>
884          #   </thead>
885          #   <tbody>
886          #     <tr><td>file</td><td>file</td></tr>
887          #     <tr>
888          #       <td>file</td>
889          #       <td>directory - directory must already exist</td>
890          #     </tr>
891          #     <tr>
892          #       <td>glob</td>
893          #       <td>directory - directory will be created if it doesn't exist</td></tr>
894          #   </tbody>
895          # </table>
896          #
897          # One restriction due to docker limitations, is that for outputs that are found
898          # on the boot disk, the local path cannot be a glob and must be a file.
899        "defaultValue": "A String", # The default value for this parameter. Can be overridden at runtime.
900            # If `localCopy` is present, then this must be a Google Cloud Storage path
901            # beginning with `gs://`.
902        "description": "A String", # Human-readable description.
903        "name": "A String", # Required. Name of the parameter - the pipeline runner uses this string
904            # as the key to the input and output maps in RunPipeline.
905        "localCopy": { # LocalCopy defines how a remote file should be copied to and from the VM. # If present, this parameter is marked for copying to and from the VM.
906            # `LocalCopy` indicates where on the VM the file should be. The value
907            # given to this parameter (either at runtime or using `defaultValue`)
908            # must be the remote path where the file should be.
909          "path": "A String", # Required. The path within the user's docker container where
910              # this input should be localized to and from, relative to the specified
911              # disk's mount point. For example: file.txt,
912          "disk": "A String", # Required. The name of the disk where this parameter is
913              # located. Can be the name of one of the disks specified in the
914              # Resources field, or "boot", which represents the Docker
915              # instance's boot disk and has a mount point of `/`.
916        },
917      },
918    ],
919    "inputParameters": [ # Input parameters of the pipeline.
920      { # Parameters facilitate setting and delivering data into the
921          # pipeline's execution environment. They are defined at create time,
922          # with optional defaults, and can be overridden at run time.
923          #
924          # If `localCopy` is unset, then the parameter specifies a string that
925          # is passed as-is into the pipeline, as the value of the environment
926          # variable with the given name.  A default value can be optionally
927          # specified at create time. The default can be overridden at run time
928          # using the inputs map. If no default is given, a value must be
929          # supplied at runtime.
930          #
931          # If `localCopy` is defined, then the parameter specifies a data
932          # source or sink, both in Google Cloud Storage and on the Docker container
933          # where the pipeline computation is run. The service account associated with
934          # the Pipeline (by
935          # default the project's Compute Engine service account) must have access to the
936          # Google Cloud Storage paths.
937          #
938          # At run time, the Google Cloud Storage paths can be overridden if a default
939          # was provided at create time, or must be set otherwise. The pipeline runner
940          # should add a key/value pair to either the inputs or outputs map. The
941          # indicated data copies will be carried out before/after pipeline execution,
942          # just as if the corresponding arguments were provided to `gsutil cp`.
943          #
944          # For example: Given the following `PipelineParameter`, specified
945          # in the `inputParameters` list:
946          #
947          # ```
948          # {name: "input_file", localCopy: {path: "file.txt", disk: "pd1"}}
949          # ```
950          #
951          # where `disk` is defined in the `PipelineResources` object as:
952          #
953          # ```
954          # {name: "pd1", mountPoint: "/mnt/disk/"}
955          # ```
956          #
957          # We create a disk named `pd1`, mount it on the host VM, and map
958          # `/mnt/pd1` to `/mnt/disk` in the docker container.  At
959          # runtime, an entry for `input_file` would be required in the inputs
960          # map, such as:
961          #
962          # ```
963          #   inputs["input_file"] = "gs://my-bucket/bar.txt"
964          # ```
965          #
966          # This would generate the following gsutil call:
967          #
968          # ```
969          #   gsutil cp gs://my-bucket/bar.txt /mnt/pd1/file.txt
970          # ```
971          #
972          # The file `/mnt/pd1/file.txt` maps to `/mnt/disk/file.txt` in the
973          # Docker container. Acceptable paths are:
974          #
975          # <table>
976          #   <thead>
977          #     <tr><th>Google Cloud storage path</th><th>Local path</th></tr>
978          #   </thead>
979          #   <tbody>
980          #     <tr><td>file</td><td>file</td></tr>
981          #     <tr><td>glob</td><td>directory</td></tr>
982          #   </tbody>
983          # </table>
984          #
985          # For outputs, the direction of the copy is reversed:
986          #
987          # ```
988          #   gsutil cp /mnt/disk/file.txt gs://my-bucket/bar.txt
989          # ```
990          #
991          # Acceptable paths are:
992          #
993          # <table>
994          #   <thead>
995          #     <tr><th>Local path</th><th>Google Cloud Storage path</th></tr>
996          #   </thead>
997          #   <tbody>
998          #     <tr><td>file</td><td>file</td></tr>
999          #     <tr>
1000          #       <td>file</td>
1001          #       <td>directory - directory must already exist</td>
1002          #     </tr>
1003          #     <tr>
1004          #       <td>glob</td>
1005          #       <td>directory - directory will be created if it doesn't exist</td></tr>
1006          #   </tbody>
1007          # </table>
1008          #
1009          # One restriction due to docker limitations, is that for outputs that are found
1010          # on the boot disk, the local path cannot be a glob and must be a file.
1011        "defaultValue": "A String", # The default value for this parameter. Can be overridden at runtime.
1012            # If `localCopy` is present, then this must be a Google Cloud Storage path
1013            # beginning with `gs://`.
1014        "description": "A String", # Human-readable description.
1015        "name": "A String", # Required. Name of the parameter - the pipeline runner uses this string
1016            # as the key to the input and output maps in RunPipeline.
1017        "localCopy": { # LocalCopy defines how a remote file should be copied to and from the VM. # If present, this parameter is marked for copying to and from the VM.
1018            # `LocalCopy` indicates where on the VM the file should be. The value
1019            # given to this parameter (either at runtime or using `defaultValue`)
1020            # must be the remote path where the file should be.
1021          "path": "A String", # Required. The path within the user's docker container where
1022              # this input should be localized to and from, relative to the specified
1023              # disk's mount point. For example: file.txt,
1024          "disk": "A String", # Required. The name of the disk where this parameter is
1025              # located. Can be the name of one of the disks specified in the
1026              # Resources field, or "boot", which represents the Docker
1027              # instance's boot disk and has a mount point of `/`.
1028        },
1029      },
1030    ],
1031    "docker": { # The Docker execuctor specification. # Specifies the docker run information.
1032      "cmd": "A String", # Required. The command or newline delimited script to run. The command
1033          # string will be executed within a bash shell.
1034          #
1035          # If the command exits with a non-zero exit code, output parameter
1036          # de-localization will be skipped and the pipeline operation's
1037          # `error` field will be populated.
1038          #
1039          # Maximum command string length is 16384.
1040      "imageName": "A String", # Required. Image name from either Docker Hub or Google Container Registry.
1041          # Users that run pipelines must have READ access to the image.
1042    },
1043    "resources": { # The system resources for the pipeline run. # Required. Specifies resource requirements for the pipeline run.
1044        # Required fields:
1045        #
1046        # *
1047        # minimumCpuCores
1048        #
1049        # *
1050        # minimumRamGb
1051      "noAddress": True or False, # Whether to assign an external IP to the instance. This is an experimental
1052          # feature that may go away. Defaults to false.
1053          # Corresponds to `--no_address` flag for [gcloud compute instances create]
1054          # (https://cloud.google.com/sdk/gcloud/reference/compute/instances/create).
1055          # In order to use this, must be true for both create time and run time.
1056          # Cannot be true at run time if false at create time. If you need to ssh into
1057          # a private IP VM for debugging, you can ssh to a public VM and then ssh into
1058          # the private VM's Internal IP.  If noAddress is set, this pipeline run may
1059          # only load docker images from Google Container Registry and not Docker Hub.
1060          # Before using this, you must
1061          # [configure access to Google services from internal IPs](https://cloud.google.com/compute/docs/configure-private-google-access#configuring_access_to_google_services_from_internal_ips).
1062      "minimumRamGb": 3.14, # The minimum amount of RAM to use. Defaults to 3.75 (GB)
1063      "preemptible": True or False, # Whether to use preemptible VMs. Defaults to `false`. In order to use this,
1064          # must be true for both create time and run time. Cannot be true at run time
1065          # if false at create time.
1066      "disks": [ # Disks to attach.
1067        { # A Google Compute Engine disk resource specification.
1068          "autoDelete": True or False, # Deprecated. Disks created by the Pipelines API will be deleted at the end
1069              # of the pipeline run, regardless of what this field is set to.
1070          "sizeGb": 42, # The size of the disk. Defaults to 500 (GB).
1071              # This field is not applicable for local SSD.
1072          "source": "A String", # The full or partial URL of the persistent disk to attach. See
1073              # https://cloud.google.com/compute/docs/reference/latest/instances#resource
1074              # and
1075              # https://cloud.google.com/compute/docs/disks/persistent-disks#snapshots
1076              # for more details.
1077          "readOnly": True or False, # Specifies how a sourced-base persistent disk will be mounted. See
1078              # https://cloud.google.com/compute/docs/disks/persistent-disks#use_multi_instances
1079              # for more details.
1080              # Can only be set at create time.
1081          "mountPoint": "A String", # Required at create time and cannot be overridden at run time.
1082              # Specifies the path in the docker container where files on
1083              # this disk should be located. For example, if `mountPoint`
1084              # is `/mnt/disk`, and the parameter has `localPath`
1085              # `inputs/file.txt`, the docker container can access the data at
1086              # `/mnt/disk/inputs/file.txt`.
1087          "type": "A String", # Required. The type of the disk to create.
1088          "name": "A String", # Required. The name of the disk that can be used in the pipeline
1089              # parameters. Must be 1 - 63 characters.
1090              # The name "boot" is reserved for system use.
1091        },
1092      ],
1093      "bootDiskSizeGb": 42, # The size of the boot disk. Defaults to 10 (GB).
1094      "zones": [ # List of Google Compute Engine availability zones to which resource
1095          # creation will restricted. If empty, any zone may be chosen.
1096        "A String",
1097      ],
1098      "minimumCpuCores": 42, # The minimum number of cores to use. Defaults to 1.
1099    },
1100    "description": "A String", # User-specified description.
1101  }</pre>
1102</div>
1103
1104<div class="method">
1105    <code class="details" id="getControllerConfig">getControllerConfig(validationToken=None, x__xgafv=None, operationId=None)</code>
1106  <pre>Gets controller configuration information. Should only be called
1107by VMs created by the Pipelines Service and not by end users.
1108
1109Args:
1110  validationToken: string, A parameter
1111  x__xgafv: string, V1 error format.
1112    Allowed values
1113      1 - v1 error format
1114      2 - v2 error format
1115  operationId: string, The operation to retrieve controller configuration for.
1116
1117Returns:
1118  An object of the form:
1119
1120    { # Stores the information that the controller will fetch from the
1121      # server in order to run. Should only be used by VMs created by the
1122      # Pipelines Service and not by end users.
1123    "cmd": "A String",
1124    "machineType": "A String",
1125    "vars": {
1126      "a_key": "A String",
1127    },
1128    "gcsLogPath": "A String",
1129    "gcsSinks": {
1130      "a_key": {
1131        "values": [
1132          "A String",
1133        ],
1134      },
1135    },
1136    "image": "A String",
1137    "disks": {
1138      "a_key": "A String",
1139    },
1140    "gcsSources": {
1141      "a_key": {
1142        "values": [
1143          "A String",
1144        ],
1145      },
1146    },
1147  }</pre>
1148</div>
1149
1150<div class="method">
1151    <code class="details" id="list">list(pageSize=None, projectId=None, namePrefix=None, pageToken=None, x__xgafv=None)</code>
1152  <pre>Lists pipelines.
1153
1154Caller must have READ permission to the project.
1155
1156Args:
1157  pageSize: integer, Number of pipelines to return at once. Defaults to 256, and max
1158is 2048.
1159  projectId: string, Required. The name of the project to search for pipelines. Caller
1160must have READ access to this project.
1161  namePrefix: string, Pipelines with names that match this prefix should be
1162returned.  If unspecified, all pipelines in the project, up to
1163`pageSize`, will be returned.
1164  pageToken: string, Token to use to indicate where to start getting results.
1165If unspecified, returns the first page of results.
1166  x__xgafv: string, V1 error format.
1167    Allowed values
1168      1 - v1 error format
1169      2 - v2 error format
1170
1171Returns:
1172  An object of the form:
1173
1174    { # The response of ListPipelines. Contains at most `pageSize`
1175      # pipelines. If it contains `pageSize` pipelines, and more pipelines
1176      # exist, then `nextPageToken` will be populated and should be
1177      # used as the `pageToken` argument to a subsequent ListPipelines
1178      # request.
1179    "nextPageToken": "A String", # The token to use to get the next page of results.
1180    "pipelines": [ # The matched pipelines.
1181      { # The pipeline object. Represents a transformation from a set of input
1182          # parameters to a set of output parameters. The transformation is defined
1183          # as a docker image and command to run within that image. Each pipeline
1184          # is run on a Google Compute Engine VM. A pipeline can be created with the
1185          # `create` method and then later run with the `run` method, or a pipeline can
1186          # be defined and run all at once with the `run` method.
1187        "pipelineId": "A String", # Unique pipeline id that is generated by the service when CreatePipeline
1188            # is called. Cannot be specified in the Pipeline used in the
1189            # CreatePipelineRequest, and will be populated in the response to
1190            # CreatePipeline and all subsequent Get and List calls. Indicates that the
1191            # service has registered this pipeline.
1192        "name": "A String", # Required. A user specified pipeline name that does not have to be unique.
1193            # This name can be used for filtering Pipelines in ListPipelines.
1194        "projectId": "A String", # Required. The project in which to create the pipeline. The caller must have
1195            # WRITE access.
1196        "outputParameters": [ # Output parameters of the pipeline.
1197          { # Parameters facilitate setting and delivering data into the
1198              # pipeline's execution environment. They are defined at create time,
1199              # with optional defaults, and can be overridden at run time.
1200              #
1201              # If `localCopy` is unset, then the parameter specifies a string that
1202              # is passed as-is into the pipeline, as the value of the environment
1203              # variable with the given name.  A default value can be optionally
1204              # specified at create time. The default can be overridden at run time
1205              # using the inputs map. If no default is given, a value must be
1206              # supplied at runtime.
1207              #
1208              # If `localCopy` is defined, then the parameter specifies a data
1209              # source or sink, both in Google Cloud Storage and on the Docker container
1210              # where the pipeline computation is run. The service account associated with
1211              # the Pipeline (by
1212              # default the project's Compute Engine service account) must have access to the
1213              # Google Cloud Storage paths.
1214              #
1215              # At run time, the Google Cloud Storage paths can be overridden if a default
1216              # was provided at create time, or must be set otherwise. The pipeline runner
1217              # should add a key/value pair to either the inputs or outputs map. The
1218              # indicated data copies will be carried out before/after pipeline execution,
1219              # just as if the corresponding arguments were provided to `gsutil cp`.
1220              #
1221              # For example: Given the following `PipelineParameter`, specified
1222              # in the `inputParameters` list:
1223              #
1224              # ```
1225              # {name: "input_file", localCopy: {path: "file.txt", disk: "pd1"}}
1226              # ```
1227              #
1228              # where `disk` is defined in the `PipelineResources` object as:
1229              #
1230              # ```
1231              # {name: "pd1", mountPoint: "/mnt/disk/"}
1232              # ```
1233              #
1234              # We create a disk named `pd1`, mount it on the host VM, and map
1235              # `/mnt/pd1` to `/mnt/disk` in the docker container.  At
1236              # runtime, an entry for `input_file` would be required in the inputs
1237              # map, such as:
1238              #
1239              # ```
1240              #   inputs["input_file"] = "gs://my-bucket/bar.txt"
1241              # ```
1242              #
1243              # This would generate the following gsutil call:
1244              #
1245              # ```
1246              #   gsutil cp gs://my-bucket/bar.txt /mnt/pd1/file.txt
1247              # ```
1248              #
1249              # The file `/mnt/pd1/file.txt` maps to `/mnt/disk/file.txt` in the
1250              # Docker container. Acceptable paths are:
1251              #
1252              # <table>
1253              #   <thead>
1254              #     <tr><th>Google Cloud storage path</th><th>Local path</th></tr>
1255              #   </thead>
1256              #   <tbody>
1257              #     <tr><td>file</td><td>file</td></tr>
1258              #     <tr><td>glob</td><td>directory</td></tr>
1259              #   </tbody>
1260              # </table>
1261              #
1262              # For outputs, the direction of the copy is reversed:
1263              #
1264              # ```
1265              #   gsutil cp /mnt/disk/file.txt gs://my-bucket/bar.txt
1266              # ```
1267              #
1268              # Acceptable paths are:
1269              #
1270              # <table>
1271              #   <thead>
1272              #     <tr><th>Local path</th><th>Google Cloud Storage path</th></tr>
1273              #   </thead>
1274              #   <tbody>
1275              #     <tr><td>file</td><td>file</td></tr>
1276              #     <tr>
1277              #       <td>file</td>
1278              #       <td>directory - directory must already exist</td>
1279              #     </tr>
1280              #     <tr>
1281              #       <td>glob</td>
1282              #       <td>directory - directory will be created if it doesn't exist</td></tr>
1283              #   </tbody>
1284              # </table>
1285              #
1286              # One restriction due to docker limitations, is that for outputs that are found
1287              # on the boot disk, the local path cannot be a glob and must be a file.
1288            "defaultValue": "A String", # The default value for this parameter. Can be overridden at runtime.
1289                # If `localCopy` is present, then this must be a Google Cloud Storage path
1290                # beginning with `gs://`.
1291            "description": "A String", # Human-readable description.
1292            "name": "A String", # Required. Name of the parameter - the pipeline runner uses this string
1293                # as the key to the input and output maps in RunPipeline.
1294            "localCopy": { # LocalCopy defines how a remote file should be copied to and from the VM. # If present, this parameter is marked for copying to and from the VM.
1295                # `LocalCopy` indicates where on the VM the file should be. The value
1296                # given to this parameter (either at runtime or using `defaultValue`)
1297                # must be the remote path where the file should be.
1298              "path": "A String", # Required. The path within the user's docker container where
1299                  # this input should be localized to and from, relative to the specified
1300                  # disk's mount point. For example: file.txt,
1301              "disk": "A String", # Required. The name of the disk where this parameter is
1302                  # located. Can be the name of one of the disks specified in the
1303                  # Resources field, or "boot", which represents the Docker
1304                  # instance's boot disk and has a mount point of `/`.
1305            },
1306          },
1307        ],
1308        "inputParameters": [ # Input parameters of the pipeline.
1309          { # Parameters facilitate setting and delivering data into the
1310              # pipeline's execution environment. They are defined at create time,
1311              # with optional defaults, and can be overridden at run time.
1312              #
1313              # If `localCopy` is unset, then the parameter specifies a string that
1314              # is passed as-is into the pipeline, as the value of the environment
1315              # variable with the given name.  A default value can be optionally
1316              # specified at create time. The default can be overridden at run time
1317              # using the inputs map. If no default is given, a value must be
1318              # supplied at runtime.
1319              #
1320              # If `localCopy` is defined, then the parameter specifies a data
1321              # source or sink, both in Google Cloud Storage and on the Docker container
1322              # where the pipeline computation is run. The service account associated with
1323              # the Pipeline (by
1324              # default the project's Compute Engine service account) must have access to the
1325              # Google Cloud Storage paths.
1326              #
1327              # At run time, the Google Cloud Storage paths can be overridden if a default
1328              # was provided at create time, or must be set otherwise. The pipeline runner
1329              # should add a key/value pair to either the inputs or outputs map. The
1330              # indicated data copies will be carried out before/after pipeline execution,
1331              # just as if the corresponding arguments were provided to `gsutil cp`.
1332              #
1333              # For example: Given the following `PipelineParameter`, specified
1334              # in the `inputParameters` list:
1335              #
1336              # ```
1337              # {name: "input_file", localCopy: {path: "file.txt", disk: "pd1"}}
1338              # ```
1339              #
1340              # where `disk` is defined in the `PipelineResources` object as:
1341              #
1342              # ```
1343              # {name: "pd1", mountPoint: "/mnt/disk/"}
1344              # ```
1345              #
1346              # We create a disk named `pd1`, mount it on the host VM, and map
1347              # `/mnt/pd1` to `/mnt/disk` in the docker container.  At
1348              # runtime, an entry for `input_file` would be required in the inputs
1349              # map, such as:
1350              #
1351              # ```
1352              #   inputs["input_file"] = "gs://my-bucket/bar.txt"
1353              # ```
1354              #
1355              # This would generate the following gsutil call:
1356              #
1357              # ```
1358              #   gsutil cp gs://my-bucket/bar.txt /mnt/pd1/file.txt
1359              # ```
1360              #
1361              # The file `/mnt/pd1/file.txt` maps to `/mnt/disk/file.txt` in the
1362              # Docker container. Acceptable paths are:
1363              #
1364              # <table>
1365              #   <thead>
1366              #     <tr><th>Google Cloud storage path</th><th>Local path</th></tr>
1367              #   </thead>
1368              #   <tbody>
1369              #     <tr><td>file</td><td>file</td></tr>
1370              #     <tr><td>glob</td><td>directory</td></tr>
1371              #   </tbody>
1372              # </table>
1373              #
1374              # For outputs, the direction of the copy is reversed:
1375              #
1376              # ```
1377              #   gsutil cp /mnt/disk/file.txt gs://my-bucket/bar.txt
1378              # ```
1379              #
1380              # Acceptable paths are:
1381              #
1382              # <table>
1383              #   <thead>
1384              #     <tr><th>Local path</th><th>Google Cloud Storage path</th></tr>
1385              #   </thead>
1386              #   <tbody>
1387              #     <tr><td>file</td><td>file</td></tr>
1388              #     <tr>
1389              #       <td>file</td>
1390              #       <td>directory - directory must already exist</td>
1391              #     </tr>
1392              #     <tr>
1393              #       <td>glob</td>
1394              #       <td>directory - directory will be created if it doesn't exist</td></tr>
1395              #   </tbody>
1396              # </table>
1397              #
1398              # One restriction due to docker limitations, is that for outputs that are found
1399              # on the boot disk, the local path cannot be a glob and must be a file.
1400            "defaultValue": "A String", # The default value for this parameter. Can be overridden at runtime.
1401                # If `localCopy` is present, then this must be a Google Cloud Storage path
1402                # beginning with `gs://`.
1403            "description": "A String", # Human-readable description.
1404            "name": "A String", # Required. Name of the parameter - the pipeline runner uses this string
1405                # as the key to the input and output maps in RunPipeline.
1406            "localCopy": { # LocalCopy defines how a remote file should be copied to and from the VM. # If present, this parameter is marked for copying to and from the VM.
1407                # `LocalCopy` indicates where on the VM the file should be. The value
1408                # given to this parameter (either at runtime or using `defaultValue`)
1409                # must be the remote path where the file should be.
1410              "path": "A String", # Required. The path within the user's docker container where
1411                  # this input should be localized to and from, relative to the specified
1412                  # disk's mount point. For example: file.txt,
1413              "disk": "A String", # Required. The name of the disk where this parameter is
1414                  # located. Can be the name of one of the disks specified in the
1415                  # Resources field, or "boot", which represents the Docker
1416                  # instance's boot disk and has a mount point of `/`.
1417            },
1418          },
1419        ],
1420        "docker": { # The Docker execuctor specification. # Specifies the docker run information.
1421          "cmd": "A String", # Required. The command or newline delimited script to run. The command
1422              # string will be executed within a bash shell.
1423              #
1424              # If the command exits with a non-zero exit code, output parameter
1425              # de-localization will be skipped and the pipeline operation's
1426              # `error` field will be populated.
1427              #
1428              # Maximum command string length is 16384.
1429          "imageName": "A String", # Required. Image name from either Docker Hub or Google Container Registry.
1430              # Users that run pipelines must have READ access to the image.
1431        },
1432        "resources": { # The system resources for the pipeline run. # Required. Specifies resource requirements for the pipeline run.
1433            # Required fields:
1434            #
1435            # *
1436            # minimumCpuCores
1437            #
1438            # *
1439            # minimumRamGb
1440          "noAddress": True or False, # Whether to assign an external IP to the instance. This is an experimental
1441              # feature that may go away. Defaults to false.
1442              # Corresponds to `--no_address` flag for [gcloud compute instances create]
1443              # (https://cloud.google.com/sdk/gcloud/reference/compute/instances/create).
1444              # In order to use this, must be true for both create time and run time.
1445              # Cannot be true at run time if false at create time. If you need to ssh into
1446              # a private IP VM for debugging, you can ssh to a public VM and then ssh into
1447              # the private VM's Internal IP.  If noAddress is set, this pipeline run may
1448              # only load docker images from Google Container Registry and not Docker Hub.
1449              # Before using this, you must
1450              # [configure access to Google services from internal IPs](https://cloud.google.com/compute/docs/configure-private-google-access#configuring_access_to_google_services_from_internal_ips).
1451          "minimumRamGb": 3.14, # The minimum amount of RAM to use. Defaults to 3.75 (GB)
1452          "preemptible": True or False, # Whether to use preemptible VMs. Defaults to `false`. In order to use this,
1453              # must be true for both create time and run time. Cannot be true at run time
1454              # if false at create time.
1455          "disks": [ # Disks to attach.
1456            { # A Google Compute Engine disk resource specification.
1457              "autoDelete": True or False, # Deprecated. Disks created by the Pipelines API will be deleted at the end
1458                  # of the pipeline run, regardless of what this field is set to.
1459              "sizeGb": 42, # The size of the disk. Defaults to 500 (GB).
1460                  # This field is not applicable for local SSD.
1461              "source": "A String", # The full or partial URL of the persistent disk to attach. See
1462                  # https://cloud.google.com/compute/docs/reference/latest/instances#resource
1463                  # and
1464                  # https://cloud.google.com/compute/docs/disks/persistent-disks#snapshots
1465                  # for more details.
1466              "readOnly": True or False, # Specifies how a sourced-base persistent disk will be mounted. See
1467                  # https://cloud.google.com/compute/docs/disks/persistent-disks#use_multi_instances
1468                  # for more details.
1469                  # Can only be set at create time.
1470              "mountPoint": "A String", # Required at create time and cannot be overridden at run time.
1471                  # Specifies the path in the docker container where files on
1472                  # this disk should be located. For example, if `mountPoint`
1473                  # is `/mnt/disk`, and the parameter has `localPath`
1474                  # `inputs/file.txt`, the docker container can access the data at
1475                  # `/mnt/disk/inputs/file.txt`.
1476              "type": "A String", # Required. The type of the disk to create.
1477              "name": "A String", # Required. The name of the disk that can be used in the pipeline
1478                  # parameters. Must be 1 - 63 characters.
1479                  # The name "boot" is reserved for system use.
1480            },
1481          ],
1482          "bootDiskSizeGb": 42, # The size of the boot disk. Defaults to 10 (GB).
1483          "zones": [ # List of Google Compute Engine availability zones to which resource
1484              # creation will restricted. If empty, any zone may be chosen.
1485            "A String",
1486          ],
1487          "minimumCpuCores": 42, # The minimum number of cores to use. Defaults to 1.
1488        },
1489        "description": "A String", # User-specified description.
1490      },
1491    ],
1492  }</pre>
1493</div>
1494
1495<div class="method">
1496    <code class="details" id="list_next">list_next(previous_request, previous_response)</code>
1497  <pre>Retrieves the next page of results.
1498
1499Args:
1500  previous_request: The request for the previous page. (required)
1501  previous_response: The response from the request for the previous page. (required)
1502
1503Returns:
1504  A request object that you can call 'execute()' on to request the next
1505  page. Returns None if there are no more items in the collection.
1506    </pre>
1507</div>
1508
1509<div class="method">
1510    <code class="details" id="run">run(body, x__xgafv=None)</code>
1511  <pre>Runs a pipeline. If `pipelineId` is specified in the request, then
1512run a saved pipeline. If `ephemeralPipeline` is specified, then run
1513that pipeline once without saving a copy.
1514
1515The caller must have READ permission to the project where the pipeline
1516is stored and WRITE permission to the project where the pipeline will be
1517run, as VMs will be created and storage will be used.
1518
1519If a pipeline operation is still running after 6 days, it will be canceled.
1520
1521Args:
1522  body: object, The request body. (required)
1523    The object takes the form of:
1524
1525{ # The request to run a pipeline. If `pipelineId` is specified, it
1526      # refers to a saved pipeline created with CreatePipeline and set as
1527      # the `pipelineId` of the returned Pipeline object. If
1528      # `ephemeralPipeline` is specified, that pipeline is run once
1529      # with the given args and not saved. It is an error to specify both
1530      # `pipelineId` and `ephemeralPipeline`. `pipelineArgs`
1531      # must be specified.
1532    "pipelineArgs": { # The pipeline run arguments. # The arguments to use when running this pipeline.
1533      "inputs": { # Pipeline input arguments; keys are defined in the pipeline documentation.
1534          # All input parameters that do not have default values  must be specified.
1535          # If parameters with defaults are specified here, the defaults will be
1536          # overridden.
1537        "a_key": "A String",
1538      },
1539      "logging": { # The logging options for the pipeline run. # Required. Logging options. Used by the service to communicate results
1540          # to the user.
1541        "gcsPath": "A String", # The location in Google Cloud Storage to which the pipeline logs
1542            # will be copied. Can be specified as a fully qualified directory
1543            # path, in which case logs will be output with a unique identifier
1544            # as the filename in that directory, or as a fully specified path,
1545            # which must end in `.log`, in which case that path will be
1546            # used, and the user must ensure that logs are not
1547            # overwritten. Stdout and stderr logs from the run are also
1548            # generated and output as `-stdout.log` and `-stderr.log`.
1549      },
1550      "outputs": { # Pipeline output arguments; keys are defined in the pipeline
1551          # documentation.  All output parameters of without default values
1552          # must be specified.  If parameters with defaults are specified
1553          # here, the defaults will be overridden.
1554        "a_key": "A String",
1555      },
1556      "labels": { # Labels to apply to this pipeline run. Labels will also be applied to
1557          # compute resources (VM, disks) created by this pipeline run. When listing
1558          # operations, operations can filtered by labels.
1559          # Label keys may not be empty; label values may be empty. Non-empty labels
1560          # must be 1-63 characters long, and comply with [RFC1035]
1561          # (https://www.ietf.org/rfc/rfc1035.txt).
1562          # Specifically, the name must be 1-63 characters long and match the regular
1563          # expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first
1564          # character must be a lowercase letter, and all following characters must be
1565          # a dash, lowercase letter, or digit, except the last character, which cannot
1566          # be a dash.
1567        "a_key": "A String",
1568      },
1569      "serviceAccount": { # A Google Cloud Service Account. # The Google Cloud Service Account that will be used to access data and
1570          # services. By default, the compute service account associated with
1571          # `projectId` is used.
1572        "scopes": [ # List of scopes to be enabled for this service account on the VM.
1573            # The following scopes are automatically included:
1574            #
1575            # * https://www.googleapis.com/auth/compute
1576            # * https://www.googleapis.com/auth/devstorage.full_control
1577            # * https://www.googleapis.com/auth/genomics
1578            # * https://www.googleapis.com/auth/logging.write
1579            # * https://www.googleapis.com/auth/monitoring.write
1580          "A String",
1581        ],
1582        "email": "A String", # Email address of the service account. Defaults to `default`,
1583            # which uses the compute service account associated with the project.
1584      },
1585      "clientId": "A String", # This field is deprecated. Use `labels` instead. Client-specified pipeline
1586          # operation identifier.
1587      "projectId": "A String", # Required. The project in which to run the pipeline. The caller must have
1588          # WRITER access to all Google Cloud services and resources (e.g. Google
1589          # Compute Engine) will be used.
1590      "keepVmAliveOnFailureDuration": "A String", # How long to keep the VM up after a failure (for example docker command
1591          # failed, copying input or output files failed, etc). While the VM is up, one
1592          # can ssh into the VM to debug. Default is 0; maximum allowed value is 1 day.
1593      "resources": { # The system resources for the pipeline run. # Specifies resource requirements/overrides for the pipeline run.
1594        "noAddress": True or False, # Whether to assign an external IP to the instance. This is an experimental
1595            # feature that may go away. Defaults to false.
1596            # Corresponds to `--no_address` flag for [gcloud compute instances create]
1597            # (https://cloud.google.com/sdk/gcloud/reference/compute/instances/create).
1598            # In order to use this, must be true for both create time and run time.
1599            # Cannot be true at run time if false at create time. If you need to ssh into
1600            # a private IP VM for debugging, you can ssh to a public VM and then ssh into
1601            # the private VM's Internal IP.  If noAddress is set, this pipeline run may
1602            # only load docker images from Google Container Registry and not Docker Hub.
1603            # Before using this, you must
1604            # [configure access to Google services from internal IPs](https://cloud.google.com/compute/docs/configure-private-google-access#configuring_access_to_google_services_from_internal_ips).
1605        "minimumRamGb": 3.14, # The minimum amount of RAM to use. Defaults to 3.75 (GB)
1606        "preemptible": True or False, # Whether to use preemptible VMs. Defaults to `false`. In order to use this,
1607            # must be true for both create time and run time. Cannot be true at run time
1608            # if false at create time.
1609        "disks": [ # Disks to attach.
1610          { # A Google Compute Engine disk resource specification.
1611            "autoDelete": True or False, # Deprecated. Disks created by the Pipelines API will be deleted at the end
1612                # of the pipeline run, regardless of what this field is set to.
1613            "sizeGb": 42, # The size of the disk. Defaults to 500 (GB).
1614                # This field is not applicable for local SSD.
1615            "source": "A String", # The full or partial URL of the persistent disk to attach. See
1616                # https://cloud.google.com/compute/docs/reference/latest/instances#resource
1617                # and
1618                # https://cloud.google.com/compute/docs/disks/persistent-disks#snapshots
1619                # for more details.
1620            "readOnly": True or False, # Specifies how a sourced-base persistent disk will be mounted. See
1621                # https://cloud.google.com/compute/docs/disks/persistent-disks#use_multi_instances
1622                # for more details.
1623                # Can only be set at create time.
1624            "mountPoint": "A String", # Required at create time and cannot be overridden at run time.
1625                # Specifies the path in the docker container where files on
1626                # this disk should be located. For example, if `mountPoint`
1627                # is `/mnt/disk`, and the parameter has `localPath`
1628                # `inputs/file.txt`, the docker container can access the data at
1629                # `/mnt/disk/inputs/file.txt`.
1630            "type": "A String", # Required. The type of the disk to create.
1631            "name": "A String", # Required. The name of the disk that can be used in the pipeline
1632                # parameters. Must be 1 - 63 characters.
1633                # The name "boot" is reserved for system use.
1634          },
1635        ],
1636        "bootDiskSizeGb": 42, # The size of the boot disk. Defaults to 10 (GB).
1637        "zones": [ # List of Google Compute Engine availability zones to which resource
1638            # creation will restricted. If empty, any zone may be chosen.
1639          "A String",
1640        ],
1641        "minimumCpuCores": 42, # The minimum number of cores to use. Defaults to 1.
1642      },
1643    },
1644    "ephemeralPipeline": { # The pipeline object. Represents a transformation from a set of input # A new pipeline object to run once and then delete.
1645        # parameters to a set of output parameters. The transformation is defined
1646        # as a docker image and command to run within that image. Each pipeline
1647        # is run on a Google Compute Engine VM. A pipeline can be created with the
1648        # `create` method and then later run with the `run` method, or a pipeline can
1649        # be defined and run all at once with the `run` method.
1650      "pipelineId": "A String", # Unique pipeline id that is generated by the service when CreatePipeline
1651          # is called. Cannot be specified in the Pipeline used in the
1652          # CreatePipelineRequest, and will be populated in the response to
1653          # CreatePipeline and all subsequent Get and List calls. Indicates that the
1654          # service has registered this pipeline.
1655      "name": "A String", # Required. A user specified pipeline name that does not have to be unique.
1656          # This name can be used for filtering Pipelines in ListPipelines.
1657      "projectId": "A String", # Required. The project in which to create the pipeline. The caller must have
1658          # WRITE access.
1659      "outputParameters": [ # Output parameters of the pipeline.
1660        { # Parameters facilitate setting and delivering data into the
1661            # pipeline's execution environment. They are defined at create time,
1662            # with optional defaults, and can be overridden at run time.
1663            #
1664            # If `localCopy` is unset, then the parameter specifies a string that
1665            # is passed as-is into the pipeline, as the value of the environment
1666            # variable with the given name.  A default value can be optionally
1667            # specified at create time. The default can be overridden at run time
1668            # using the inputs map. If no default is given, a value must be
1669            # supplied at runtime.
1670            #
1671            # If `localCopy` is defined, then the parameter specifies a data
1672            # source or sink, both in Google Cloud Storage and on the Docker container
1673            # where the pipeline computation is run. The service account associated with
1674            # the Pipeline (by
1675            # default the project's Compute Engine service account) must have access to the
1676            # Google Cloud Storage paths.
1677            #
1678            # At run time, the Google Cloud Storage paths can be overridden if a default
1679            # was provided at create time, or must be set otherwise. The pipeline runner
1680            # should add a key/value pair to either the inputs or outputs map. The
1681            # indicated data copies will be carried out before/after pipeline execution,
1682            # just as if the corresponding arguments were provided to `gsutil cp`.
1683            #
1684            # For example: Given the following `PipelineParameter`, specified
1685            # in the `inputParameters` list:
1686            #
1687            # ```
1688            # {name: "input_file", localCopy: {path: "file.txt", disk: "pd1"}}
1689            # ```
1690            #
1691            # where `disk` is defined in the `PipelineResources` object as:
1692            #
1693            # ```
1694            # {name: "pd1", mountPoint: "/mnt/disk/"}
1695            # ```
1696            #
1697            # We create a disk named `pd1`, mount it on the host VM, and map
1698            # `/mnt/pd1` to `/mnt/disk` in the docker container.  At
1699            # runtime, an entry for `input_file` would be required in the inputs
1700            # map, such as:
1701            #
1702            # ```
1703            #   inputs["input_file"] = "gs://my-bucket/bar.txt"
1704            # ```
1705            #
1706            # This would generate the following gsutil call:
1707            #
1708            # ```
1709            #   gsutil cp gs://my-bucket/bar.txt /mnt/pd1/file.txt
1710            # ```
1711            #
1712            # The file `/mnt/pd1/file.txt` maps to `/mnt/disk/file.txt` in the
1713            # Docker container. Acceptable paths are:
1714            #
1715            # <table>
1716            #   <thead>
1717            #     <tr><th>Google Cloud storage path</th><th>Local path</th></tr>
1718            #   </thead>
1719            #   <tbody>
1720            #     <tr><td>file</td><td>file</td></tr>
1721            #     <tr><td>glob</td><td>directory</td></tr>
1722            #   </tbody>
1723            # </table>
1724            #
1725            # For outputs, the direction of the copy is reversed:
1726            #
1727            # ```
1728            #   gsutil cp /mnt/disk/file.txt gs://my-bucket/bar.txt
1729            # ```
1730            #
1731            # Acceptable paths are:
1732            #
1733            # <table>
1734            #   <thead>
1735            #     <tr><th>Local path</th><th>Google Cloud Storage path</th></tr>
1736            #   </thead>
1737            #   <tbody>
1738            #     <tr><td>file</td><td>file</td></tr>
1739            #     <tr>
1740            #       <td>file</td>
1741            #       <td>directory - directory must already exist</td>
1742            #     </tr>
1743            #     <tr>
1744            #       <td>glob</td>
1745            #       <td>directory - directory will be created if it doesn't exist</td></tr>
1746            #   </tbody>
1747            # </table>
1748            #
1749            # One restriction due to docker limitations, is that for outputs that are found
1750            # on the boot disk, the local path cannot be a glob and must be a file.
1751          "defaultValue": "A String", # The default value for this parameter. Can be overridden at runtime.
1752              # If `localCopy` is present, then this must be a Google Cloud Storage path
1753              # beginning with `gs://`.
1754          "description": "A String", # Human-readable description.
1755          "name": "A String", # Required. Name of the parameter - the pipeline runner uses this string
1756              # as the key to the input and output maps in RunPipeline.
1757          "localCopy": { # LocalCopy defines how a remote file should be copied to and from the VM. # If present, this parameter is marked for copying to and from the VM.
1758              # `LocalCopy` indicates where on the VM the file should be. The value
1759              # given to this parameter (either at runtime or using `defaultValue`)
1760              # must be the remote path where the file should be.
1761            "path": "A String", # Required. The path within the user's docker container where
1762                # this input should be localized to and from, relative to the specified
1763                # disk's mount point. For example: file.txt,
1764            "disk": "A String", # Required. The name of the disk where this parameter is
1765                # located. Can be the name of one of the disks specified in the
1766                # Resources field, or "boot", which represents the Docker
1767                # instance's boot disk and has a mount point of `/`.
1768          },
1769        },
1770      ],
1771      "inputParameters": [ # Input parameters of the pipeline.
1772        { # Parameters facilitate setting and delivering data into the
1773            # pipeline's execution environment. They are defined at create time,
1774            # with optional defaults, and can be overridden at run time.
1775            #
1776            # If `localCopy` is unset, then the parameter specifies a string that
1777            # is passed as-is into the pipeline, as the value of the environment
1778            # variable with the given name.  A default value can be optionally
1779            # specified at create time. The default can be overridden at run time
1780            # using the inputs map. If no default is given, a value must be
1781            # supplied at runtime.
1782            #
1783            # If `localCopy` is defined, then the parameter specifies a data
1784            # source or sink, both in Google Cloud Storage and on the Docker container
1785            # where the pipeline computation is run. The service account associated with
1786            # the Pipeline (by
1787            # default the project's Compute Engine service account) must have access to the
1788            # Google Cloud Storage paths.
1789            #
1790            # At run time, the Google Cloud Storage paths can be overridden if a default
1791            # was provided at create time, or must be set otherwise. The pipeline runner
1792            # should add a key/value pair to either the inputs or outputs map. The
1793            # indicated data copies will be carried out before/after pipeline execution,
1794            # just as if the corresponding arguments were provided to `gsutil cp`.
1795            #
1796            # For example: Given the following `PipelineParameter`, specified
1797            # in the `inputParameters` list:
1798            #
1799            # ```
1800            # {name: "input_file", localCopy: {path: "file.txt", disk: "pd1"}}
1801            # ```
1802            #
1803            # where `disk` is defined in the `PipelineResources` object as:
1804            #
1805            # ```
1806            # {name: "pd1", mountPoint: "/mnt/disk/"}
1807            # ```
1808            #
1809            # We create a disk named `pd1`, mount it on the host VM, and map
1810            # `/mnt/pd1` to `/mnt/disk` in the docker container.  At
1811            # runtime, an entry for `input_file` would be required in the inputs
1812            # map, such as:
1813            #
1814            # ```
1815            #   inputs["input_file"] = "gs://my-bucket/bar.txt"
1816            # ```
1817            #
1818            # This would generate the following gsutil call:
1819            #
1820            # ```
1821            #   gsutil cp gs://my-bucket/bar.txt /mnt/pd1/file.txt
1822            # ```
1823            #
1824            # The file `/mnt/pd1/file.txt` maps to `/mnt/disk/file.txt` in the
1825            # Docker container. Acceptable paths are:
1826            #
1827            # <table>
1828            #   <thead>
1829            #     <tr><th>Google Cloud storage path</th><th>Local path</th></tr>
1830            #   </thead>
1831            #   <tbody>
1832            #     <tr><td>file</td><td>file</td></tr>
1833            #     <tr><td>glob</td><td>directory</td></tr>
1834            #   </tbody>
1835            # </table>
1836            #
1837            # For outputs, the direction of the copy is reversed:
1838            #
1839            # ```
1840            #   gsutil cp /mnt/disk/file.txt gs://my-bucket/bar.txt
1841            # ```
1842            #
1843            # Acceptable paths are:
1844            #
1845            # <table>
1846            #   <thead>
1847            #     <tr><th>Local path</th><th>Google Cloud Storage path</th></tr>
1848            #   </thead>
1849            #   <tbody>
1850            #     <tr><td>file</td><td>file</td></tr>
1851            #     <tr>
1852            #       <td>file</td>
1853            #       <td>directory - directory must already exist</td>
1854            #     </tr>
1855            #     <tr>
1856            #       <td>glob</td>
1857            #       <td>directory - directory will be created if it doesn't exist</td></tr>
1858            #   </tbody>
1859            # </table>
1860            #
1861            # One restriction due to docker limitations, is that for outputs that are found
1862            # on the boot disk, the local path cannot be a glob and must be a file.
1863          "defaultValue": "A String", # The default value for this parameter. Can be overridden at runtime.
1864              # If `localCopy` is present, then this must be a Google Cloud Storage path
1865              # beginning with `gs://`.
1866          "description": "A String", # Human-readable description.
1867          "name": "A String", # Required. Name of the parameter - the pipeline runner uses this string
1868              # as the key to the input and output maps in RunPipeline.
1869          "localCopy": { # LocalCopy defines how a remote file should be copied to and from the VM. # If present, this parameter is marked for copying to and from the VM.
1870              # `LocalCopy` indicates where on the VM the file should be. The value
1871              # given to this parameter (either at runtime or using `defaultValue`)
1872              # must be the remote path where the file should be.
1873            "path": "A String", # Required. The path within the user's docker container where
1874                # this input should be localized to and from, relative to the specified
1875                # disk's mount point. For example: file.txt,
1876            "disk": "A String", # Required. The name of the disk where this parameter is
1877                # located. Can be the name of one of the disks specified in the
1878                # Resources field, or "boot", which represents the Docker
1879                # instance's boot disk and has a mount point of `/`.
1880          },
1881        },
1882      ],
1883      "docker": { # The Docker execuctor specification. # Specifies the docker run information.
1884        "cmd": "A String", # Required. The command or newline delimited script to run. The command
1885            # string will be executed within a bash shell.
1886            #
1887            # If the command exits with a non-zero exit code, output parameter
1888            # de-localization will be skipped and the pipeline operation's
1889            # `error` field will be populated.
1890            #
1891            # Maximum command string length is 16384.
1892        "imageName": "A String", # Required. Image name from either Docker Hub or Google Container Registry.
1893            # Users that run pipelines must have READ access to the image.
1894      },
1895      "resources": { # The system resources for the pipeline run. # Required. Specifies resource requirements for the pipeline run.
1896          # Required fields:
1897          #
1898          # *
1899          # minimumCpuCores
1900          #
1901          # *
1902          # minimumRamGb
1903        "noAddress": True or False, # Whether to assign an external IP to the instance. This is an experimental
1904            # feature that may go away. Defaults to false.
1905            # Corresponds to `--no_address` flag for [gcloud compute instances create]
1906            # (https://cloud.google.com/sdk/gcloud/reference/compute/instances/create).
1907            # In order to use this, must be true for both create time and run time.
1908            # Cannot be true at run time if false at create time. If you need to ssh into
1909            # a private IP VM for debugging, you can ssh to a public VM and then ssh into
1910            # the private VM's Internal IP.  If noAddress is set, this pipeline run may
1911            # only load docker images from Google Container Registry and not Docker Hub.
1912            # Before using this, you must
1913            # [configure access to Google services from internal IPs](https://cloud.google.com/compute/docs/configure-private-google-access#configuring_access_to_google_services_from_internal_ips).
1914        "minimumRamGb": 3.14, # The minimum amount of RAM to use. Defaults to 3.75 (GB)
1915        "preemptible": True or False, # Whether to use preemptible VMs. Defaults to `false`. In order to use this,
1916            # must be true for both create time and run time. Cannot be true at run time
1917            # if false at create time.
1918        "disks": [ # Disks to attach.
1919          { # A Google Compute Engine disk resource specification.
1920            "autoDelete": True or False, # Deprecated. Disks created by the Pipelines API will be deleted at the end
1921                # of the pipeline run, regardless of what this field is set to.
1922            "sizeGb": 42, # The size of the disk. Defaults to 500 (GB).
1923                # This field is not applicable for local SSD.
1924            "source": "A String", # The full or partial URL of the persistent disk to attach. See
1925                # https://cloud.google.com/compute/docs/reference/latest/instances#resource
1926                # and
1927                # https://cloud.google.com/compute/docs/disks/persistent-disks#snapshots
1928                # for more details.
1929            "readOnly": True or False, # Specifies how a sourced-base persistent disk will be mounted. See
1930                # https://cloud.google.com/compute/docs/disks/persistent-disks#use_multi_instances
1931                # for more details.
1932                # Can only be set at create time.
1933            "mountPoint": "A String", # Required at create time and cannot be overridden at run time.
1934                # Specifies the path in the docker container where files on
1935                # this disk should be located. For example, if `mountPoint`
1936                # is `/mnt/disk`, and the parameter has `localPath`
1937                # `inputs/file.txt`, the docker container can access the data at
1938                # `/mnt/disk/inputs/file.txt`.
1939            "type": "A String", # Required. The type of the disk to create.
1940            "name": "A String", # Required. The name of the disk that can be used in the pipeline
1941                # parameters. Must be 1 - 63 characters.
1942                # The name "boot" is reserved for system use.
1943          },
1944        ],
1945        "bootDiskSizeGb": 42, # The size of the boot disk. Defaults to 10 (GB).
1946        "zones": [ # List of Google Compute Engine availability zones to which resource
1947            # creation will restricted. If empty, any zone may be chosen.
1948          "A String",
1949        ],
1950        "minimumCpuCores": 42, # The minimum number of cores to use. Defaults to 1.
1951      },
1952      "description": "A String", # User-specified description.
1953    },
1954    "pipelineId": "A String", # The already created pipeline to run.
1955  }
1956
1957  x__xgafv: string, V1 error format.
1958    Allowed values
1959      1 - v1 error format
1960      2 - v2 error format
1961
1962Returns:
1963  An object of the form:
1964
1965    { # This resource represents a long-running operation that is the result of a
1966      # network API call.
1967    "metadata": { # An OperationMetadata object. This will always be returned with the Operation.
1968      "a_key": "", # Properties of the object. Contains field @type with type URL.
1969    },
1970    "error": { # The `Status` type defines a logical error model that is suitable for different # The error result of the operation in case of failure or cancellation.
1971        # programming environments, including REST APIs and RPC APIs. It is used by
1972        # [gRPC](https://github.com/grpc). The error model is designed to be:
1973        #
1974        # - Simple to use and understand for most users
1975        # - Flexible enough to meet unexpected needs
1976        #
1977        # # Overview
1978        #
1979        # The `Status` message contains three pieces of data: error code, error message,
1980        # and error details. The error code should be an enum value of
1981        # google.rpc.Code, but it may accept additional error codes if needed.  The
1982        # error message should be a developer-facing English message that helps
1983        # developers *understand* and *resolve* the error. If a localized user-facing
1984        # error message is needed, put the localized message in the error details or
1985        # localize it in the client. The optional error details may contain arbitrary
1986        # information about the error. There is a predefined set of error detail types
1987        # in the package `google.rpc` that can be used for common error conditions.
1988        #
1989        # # Language mapping
1990        #
1991        # The `Status` message is the logical representation of the error model, but it
1992        # is not necessarily the actual wire format. When the `Status` message is
1993        # exposed in different client libraries and different wire protocols, it can be
1994        # mapped differently. For example, it will likely be mapped to some exceptions
1995        # in Java, but more likely mapped to some error codes in C.
1996        #
1997        # # Other uses
1998        #
1999        # The error model and the `Status` message can be used in a variety of
2000        # environments, either with or without APIs, to provide a
2001        # consistent developer experience across different environments.
2002        #
2003        # Example uses of this error model include:
2004        #
2005        # - Partial errors. If a service needs to return partial errors to the client,
2006        #     it may embed the `Status` in the normal response to indicate the partial
2007        #     errors.
2008        #
2009        # - Workflow errors. A typical workflow has multiple steps. Each step may
2010        #     have a `Status` message for error reporting.
2011        #
2012        # - Batch operations. If a client uses batch request and batch response, the
2013        #     `Status` message should be used directly inside batch response, one for
2014        #     each error sub-response.
2015        #
2016        # - Asynchronous operations. If an API call embeds asynchronous operation
2017        #     results in its response, the status of those operations should be
2018        #     represented directly using the `Status` message.
2019        #
2020        # - Logging. If some API errors are stored in logs, the message `Status` could
2021        #     be used directly after any stripping needed for security/privacy reasons.
2022      "message": "A String", # A developer-facing error message, which should be in English. Any
2023          # user-facing error message should be localized and sent in the
2024          # google.rpc.Status.details field, or localized by the client.
2025      "code": 42, # The status code, which should be an enum value of google.rpc.Code.
2026      "details": [ # A list of messages that carry the error details.  There will be a
2027          # common set of message types for APIs to use.
2028        {
2029          "a_key": "", # Properties of the object. Contains field @type with type URL.
2030        },
2031      ],
2032    },
2033    "done": True or False, # If the value is `false`, it means the operation is still in progress.
2034        # If true, the operation is completed, and either `error` or `response` is
2035        # available.
2036    "response": { # If importing ReadGroupSets, an ImportReadGroupSetsResponse is returned. If importing Variants, an ImportVariantsResponse is returned. For pipelines and exports, an empty response is returned.
2037      "a_key": "", # Properties of the object. Contains field @type with type URL.
2038    },
2039    "name": "A String", # The server-assigned name, which is only unique within the same service that originally returns it. For example&#58; `operations/CJHU7Oi_ChDrveSpBRjfuL-qzoWAgEw`
2040  }</pre>
2041</div>
2042
2043<div class="method">
2044    <code class="details" id="setOperationStatus">setOperationStatus(body, x__xgafv=None)</code>
2045  <pre>Sets status of a given operation. Any new timestamps (as determined by
2046description) are appended to TimestampEvents. Should only be called by VMs
2047created by the Pipelines Service and not by end users.
2048
2049Args:
2050  body: object, The request body. (required)
2051    The object takes the form of:
2052
2053{ # Request to set operation status. Should only be used by VMs
2054      # created by the Pipelines Service and not by end users.
2055    "errorCode": "A String",
2056    "errorMessage": "A String",
2057    "timestampEvents": [
2058      { # Stores the list of events and times they occured for major events in job
2059          # execution.
2060        "timestamp": "A String", # The time this event occured.
2061        "description": "A String", # String indicating the type of event
2062      },
2063    ],
2064    "operationId": "A String",
2065    "validationToken": "A String",
2066  }
2067
2068  x__xgafv: string, V1 error format.
2069    Allowed values
2070      1 - v1 error format
2071      2 - v2 error format
2072
2073Returns:
2074  An object of the form:
2075
2076    { # A generic empty message that you can re-use to avoid defining duplicated
2077      # empty messages in your APIs. A typical example is to use it as the request
2078      # or the response type of an API method. For instance:
2079      #
2080      #     service Foo {
2081      #       rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty);
2082      #     }
2083      #
2084      # The JSON representation for `Empty` is empty JSON object `{}`.
2085  }</pre>
2086</div>
2087
2088</body></html>