Module pachyderm_sdk.api.pjs

Expand source code
# Generated by the protocol buffer compiler.  DO NOT EDIT!
# sources: api/pjs/pjs.proto
# plugin: python-betterproto
# This file has been @generated
from dataclasses import dataclass
from typing import (
    TYPE_CHECKING,
    AsyncIterable,
    AsyncIterator,
    Dict,
    Iterable,
    Iterator,
    List,
    Optional,
    Union,
)

import betterproto
import betterproto.lib.google.protobuf as betterproto_lib_google_protobuf
import grpc


if TYPE_CHECKING:
    import grpc


class JobState(betterproto.Enum):
    JobState_UNSPECIFIED = 0
    """UNSPECIFIED means the job state is unspecified."""

    QUEUED = 1
    """
    QUEUED means the job is currently in a queue. A QUEUED job will not have
    any descendants.
    """

    PROCESSING = 2
    """PROCESSING means the job is currently being processed by a worker."""

    DONE = 3
    """DONE means the job, and all of its descendants, are done."""


class JobErrorCode(betterproto.Enum):
    JobErrorCode_UNSPECIFIED = 0
    """UNSPECIFIED means the job error code is unspecified."""

    FAILED = 1
    """
    FAILED means that the worker processing the job indicated that it failed.
    """

    DISCONNECTED = 2
    """DISCONNECTED means the worker processing the job disconnected."""

    CANCELED = 3
    """CANCELED means the job was canceled."""


class WalkAlgorithm(betterproto.Enum):
    """
    WalkAlgorithm is used by WalkJob to specify how it should walk through a
    tree.
    """

    UNKNOWN = 0
    LEVEL_ORDER = 1
    PRE_ORDER = 2
    MIRRORED_POST_ORDER = 3


@dataclass(eq=False, repr=False)
class Job(betterproto.Message):
    """
    Job uniquely identifies a Job Job will be nil to indicate no Job, or an
    unset Job.
    """

    id: int = betterproto.int64_field(1)


@dataclass(eq=False, repr=False)
class JobInfo(betterproto.Message):
    """JobInfo describes a Job"""

    job: "Job" = betterproto.message_field(1)
    """Job is the Job's identity"""

    parent_job: "Job" = betterproto.message_field(2)
    """parent_job is the Job's parent if it exists."""

    state: "JobState" = betterproto.enum_field(3)
    """
    state is the Job's state. See JobState for a description of the possible
    states.
    """

    program: str = betterproto.string_field(4)
    """
    program is the fileset that contains the code specification for the Job.
    """

    input: List[str] = betterproto.string_field(5)
    """input is the input fileset handles for the Job."""

    success: "JobInfoSuccess" = betterproto.message_field(6, group="result")
    error: "JobErrorCode" = betterproto.enum_field(7, group="result")
    """error is set when the Job is unable to complete successfully"""


@dataclass(eq=False, repr=False)
class JobInfoSuccess(betterproto.Message):
    """Success is produced by a successfully completing Job."""

    output: List[str] = betterproto.string_field(1)
    """output is a list of fileset handles produced by a successful Job."""


@dataclass(eq=False, repr=False)
class JobInfoDetails(betterproto.Message):
    """
    JobInfoDetails is more detailed information about a Job. It contains a
    superset of the information in JobInfo
    """

    job_info: "JobInfo" = betterproto.message_field(1)


@dataclass(eq=False, repr=False)
class Queue(betterproto.Message):
    """
    Queue uniquely identifies a Queue Queue will be nil to identify no Queue,
    or to indicate unset.
    """

    id: bytes = betterproto.bytes_field(1)


@dataclass(eq=False, repr=False)
class QueueInfo(betterproto.Message):
    """QueueInfo describes a Queue"""

    queue: "Queue" = betterproto.message_field(1)
    """queue is the Queue's identity"""

    program: List[str] = betterproto.string_field(2)
    """
    The current storage system supports cloned filesets with the same content
    hash.
    """


@dataclass(eq=False, repr=False)
class QueueInfoDetails(betterproto.Message):
    """
    QueueInfoDetails contains detailed information about a Queue, which may be
    more expensive to get. It contains a superset of the information in
    QueueInfo.
    """

    queue_info: "QueueInfo" = betterproto.message_field(1)
    size: int = betterproto.int64_field(2)
    """size is the number of elements queued."""


@dataclass(eq=False, repr=False)
class AwaitRequest(betterproto.Message):
    context: str = betterproto.string_field(1)
    job: int = betterproto.int64_field(2)
    desired_state: "JobState" = betterproto.enum_field(3)


@dataclass(eq=False, repr=False)
class AwaitResponse(betterproto.Message):
    actual_state: "JobState" = betterproto.enum_field(1)


@dataclass(eq=False, repr=False)
class CreateJobRequest(betterproto.Message):
    context: str = betterproto.string_field(1)
    """
    context is a bearer token used when calling from within a running Job.
    """

    program: str = betterproto.string_field(2)
    """program is a fileset handle."""

    input: List[str] = betterproto.string_field(3)
    """input is a list of fileset handles."""

    cache_read: bool = betterproto.bool_field(4)
    cache_write: bool = betterproto.bool_field(5)


@dataclass(eq=False, repr=False)
class CreateJobResponse(betterproto.Message):
    id: "Job" = betterproto.message_field(1)


@dataclass(eq=False, repr=False)
class CancelJobRequest(betterproto.Message):
    context: str = betterproto.string_field(1)
    """
    context is a bearer token used when calling from within a running Job.
    """

    job: "Job" = betterproto.message_field(2)


@dataclass(eq=False, repr=False)
class CancelJobResponse(betterproto.Message):
    pass


@dataclass(eq=False, repr=False)
class DeleteJobRequest(betterproto.Message):
    context: str = betterproto.string_field(1)
    """
    context is a bearer token used when calling from within a running Job.
    """

    job: "Job" = betterproto.message_field(2)


@dataclass(eq=False, repr=False)
class DeleteJobResponse(betterproto.Message):
    pass


@dataclass(eq=False, repr=False)
class ListJobRequest(betterproto.Message):
    """TODO: - Filter - Paginate"""

    context: str = betterproto.string_field(1)
    """
    context is a bearer token used when calling from within a running Job.
    """

    job: "Job" = betterproto.message_field(2)
    """
    job is the job to start listing at. If nil, then the listing starts at the
    first job in the natural ordering.
    """


@dataclass(eq=False, repr=False)
class ListJobResponse(betterproto.Message):
    """
    ListJobResponse lists information about Jobs ID will always be set. Info
    and Details may not be set depending on how much information was requested.
    """

    id: "Job" = betterproto.message_field(1)
    info: "JobInfo" = betterproto.message_field(2)
    details: "JobInfoDetails" = betterproto.message_field(3)


@dataclass(eq=False, repr=False)
class WalkJobRequest(betterproto.Message):
    context: str = betterproto.string_field(1)
    """
    context is a bearer token used when calling from within a running Job.
    """

    job: "Job" = betterproto.message_field(2)
    """
    job is the job to start walking from.  If unset, the context Job is
    assumed.
    """

    algorithm: "WalkAlgorithm" = betterproto.enum_field(3)
    """A sane client should default to 'LEVEL_ORDER'."""

    max_depth: int = betterproto.uint64_field(4)
    """
    The depth relative from the starting point to traverse to. A depth of 0 is
    interpreted as 10,000. A depth greater than 10,000 is capped at 10,000.
    """


@dataclass(eq=False, repr=False)
class InspectJobRequest(betterproto.Message):
    context: str = betterproto.string_field(1)
    """
    context is a bearer token used when calling from within a running Job.
    """

    job: "Job" = betterproto.message_field(2)
    """
    job is the job to start walking from.  If unset the context Job is assumed.
    """


@dataclass(eq=False, repr=False)
class InspectJobResponse(betterproto.Message):
    details: "JobInfoDetails" = betterproto.message_field(1)


@dataclass(eq=False, repr=False)
class ProcessQueueRequest(betterproto.Message):
    """
    Queue Messages ProcessQueueRequest is the client -> server message for the
    bi-di ProcessQueue RPC.
    """

    queue: "Queue" = betterproto.message_field(1)
    """queue is set to start processing from a Queue."""

    success: "ProcessQueueRequestSuccess" = betterproto.message_field(2, group="result")
    failed: bool = betterproto.bool_field(3, group="result")
    """
    failed is set by the client to fail the Job. The Job will transition to
    state DONE with code FAILED.
    """


@dataclass(eq=False, repr=False)
class ProcessQueueRequestSuccess(betterproto.Message):
    """Success is set by the client to complete the Job successfully."""

    output: List[str] = betterproto.string_field(1)
    """output is a list of fileset handles produced by a successful Job."""


@dataclass(eq=False, repr=False)
class ProcessQueueResponse(betterproto.Message):
    """
    ProcessQueueResposne is the server -> client message for the bi-di
    ProcessQueue RPC.
    """

    context: str = betterproto.string_field(1)
    """
    context is a bearer token used to act on behalf of the Job in other RPCs.
    The server issues this token to the client, and the client should use it
    when performing Job RPCs.
    """

    input: List[str] = betterproto.string_field(2)
    """
    input is the input data for a Job. The server sends this to ask the client
    to compute the output.
    """


@dataclass(eq=False, repr=False)
class ListQueueRequest(betterproto.Message):
    """TODO: - Filter - Paginate"""

    pass


@dataclass(eq=False, repr=False)
class ListQueueResponse(betterproto.Message):
    id: "Queue" = betterproto.message_field(1)
    info: "QueueInfo" = betterproto.message_field(2)
    details: "QueueInfoDetails" = betterproto.message_field(3)


@dataclass(eq=False, repr=False)
class InspectQueueRequest(betterproto.Message):
    queue: "Queue" = betterproto.message_field(1)


@dataclass(eq=False, repr=False)
class InspectQueueResponse(betterproto.Message):
    details: "QueueInfoDetails" = betterproto.message_field(1)


class ApiStub:

    def __init__(self, channel: "grpc.Channel"):
        self.__rpc_create_job = channel.unary_unary(
            "/pjs.API/CreateJob",
            request_serializer=CreateJobRequest.SerializeToString,
            response_deserializer=CreateJobResponse.FromString,
        )
        self.__rpc_cancel_job = channel.unary_unary(
            "/pjs.API/CancelJob",
            request_serializer=CancelJobRequest.SerializeToString,
            response_deserializer=CancelJobResponse.FromString,
        )
        self.__rpc_delete_job = channel.unary_unary(
            "/pjs.API/DeleteJob",
            request_serializer=DeleteJobRequest.SerializeToString,
            response_deserializer=DeleteJobResponse.FromString,
        )
        self.__rpc_list_job = channel.unary_stream(
            "/pjs.API/ListJob",
            request_serializer=ListJobRequest.SerializeToString,
            response_deserializer=ListJobResponse.FromString,
        )
        self.__rpc_walk_job = channel.unary_stream(
            "/pjs.API/WalkJob",
            request_serializer=WalkJobRequest.SerializeToString,
            response_deserializer=ListJobResponse.FromString,
        )
        self.__rpc_inspect_job = channel.unary_unary(
            "/pjs.API/InspectJob",
            request_serializer=InspectJobRequest.SerializeToString,
            response_deserializer=InspectJobResponse.FromString,
        )
        self.__rpc_process_queue = channel.stream_stream(
            "/pjs.API/ProcessQueue",
            request_serializer=ProcessQueueRequest.SerializeToString,
            response_deserializer=ProcessQueueResponse.FromString,
        )
        self.__rpc_list_queue = channel.unary_stream(
            "/pjs.API/ListQueue",
            request_serializer=ListQueueRequest.SerializeToString,
            response_deserializer=ListQueueResponse.FromString,
        )
        self.__rpc_inspect_queue = channel.unary_unary(
            "/pjs.API/InspectQueue",
            request_serializer=InspectQueueRequest.SerializeToString,
            response_deserializer=InspectQueueResponse.FromString,
        )
        self.__rpc_await_ = channel.unary_unary(
            "/pjs.API/Await",
            request_serializer=AwaitRequest.SerializeToString,
            response_deserializer=AwaitResponse.FromString,
        )

    def create_job(
        self,
        *,
        context: str = "",
        program: str = "",
        input: Optional[List[str]] = None,
        cache_read: bool = False,
        cache_write: bool = False
    ) -> "CreateJobResponse":
        input = input or []

        request = CreateJobRequest()
        request.context = context
        request.program = program
        request.input = input
        request.cache_read = cache_read
        request.cache_write = cache_write

        return self.__rpc_create_job(request)

    def cancel_job(
        self, *, context: str = "", job: "Job" = None
    ) -> "CancelJobResponse":

        request = CancelJobRequest()
        request.context = context
        if job is not None:
            request.job = job

        return self.__rpc_cancel_job(request)

    def delete_job(
        self, *, context: str = "", job: "Job" = None
    ) -> "DeleteJobResponse":

        request = DeleteJobRequest()
        request.context = context
        if job is not None:
            request.job = job

        return self.__rpc_delete_job(request)

    def list_job(
        self, *, context: str = "", job: "Job" = None
    ) -> Iterator["ListJobResponse"]:

        request = ListJobRequest()
        request.context = context
        if job is not None:
            request.job = job

        for response in self.__rpc_list_job(request):
            yield response

    def walk_job(
        self,
        *,
        context: str = "",
        job: "Job" = None,
        algorithm: "WalkAlgorithm" = None,
        max_depth: int = 0
    ) -> Iterator["ListJobResponse"]:

        request = WalkJobRequest()
        request.context = context
        if job is not None:
            request.job = job
        request.algorithm = algorithm
        request.max_depth = max_depth

        for response in self.__rpc_walk_job(request):
            yield response

    def inspect_job(
        self, *, context: str = "", job: "Job" = None
    ) -> "InspectJobResponse":

        request = InspectJobRequest()
        request.context = context
        if job is not None:
            request.job = job

        return self.__rpc_inspect_job(request)

    def process_queue(
        self,
        request_iterator: Union[
            AsyncIterable["ProcessQueueRequest"], Iterable["ProcessQueueRequest"]
        ],
    ) -> Iterator["ProcessQueueResponse"]:

        for response in self.__rpc_process_queue(request_iterator):
            yield response

    def list_queue(self) -> Iterator["ListQueueResponse"]:

        request = ListQueueRequest()

        for response in self.__rpc_list_queue(request):
            yield response

    def inspect_queue(self, *, queue: "Queue" = None) -> "InspectQueueResponse":

        request = InspectQueueRequest()
        if queue is not None:
            request.queue = queue

        return self.__rpc_inspect_queue(request)

    def await_(
        self, *, context: str = "", job: int = 0, desired_state: "JobState" = None
    ) -> "AwaitResponse":

        request = AwaitRequest()
        request.context = context
        request.job = job
        request.desired_state = desired_state

        return self.__rpc_await_(request)

Classes

class JobState (*args, **kwds)

The base class for protobuf enumerations, all generated enumerations will inherit from this. Bases :class:enum.IntEnum.

Expand source code
class JobState(betterproto.Enum):
    JobState_UNSPECIFIED = 0
    """UNSPECIFIED means the job state is unspecified."""

    QUEUED = 1
    """
    QUEUED means the job is currently in a queue. A QUEUED job will not have
    any descendants.
    """

    PROCESSING = 2
    """PROCESSING means the job is currently being processed by a worker."""

    DONE = 3
    """DONE means the job, and all of its descendants, are done."""

Ancestors

  • betterproto.Enum
  • enum.IntEnum
  • builtins.int
  • enum.ReprEnum
  • enum.Enum

Class variables

var JobState_UNSPECIFIED

UNSPECIFIED means the job state is unspecified.

var QUEUED

QUEUED means the job is currently in a queue. A QUEUED job will not have any descendants.

var PROCESSING

PROCESSING means the job is currently being processed by a worker.

var DONE

DONE means the job, and all of its descendants, are done.

class JobErrorCode (*args, **kwds)

The base class for protobuf enumerations, all generated enumerations will inherit from this. Bases :class:enum.IntEnum.

Expand source code
class JobErrorCode(betterproto.Enum):
    JobErrorCode_UNSPECIFIED = 0
    """UNSPECIFIED means the job error code is unspecified."""

    FAILED = 1
    """
    FAILED means that the worker processing the job indicated that it failed.
    """

    DISCONNECTED = 2
    """DISCONNECTED means the worker processing the job disconnected."""

    CANCELED = 3
    """CANCELED means the job was canceled."""

Ancestors

  • betterproto.Enum
  • enum.IntEnum
  • builtins.int
  • enum.ReprEnum
  • enum.Enum

Class variables

var JobErrorCode_UNSPECIFIED

UNSPECIFIED means the job error code is unspecified.

var FAILED

FAILED means that the worker processing the job indicated that it failed.

var DISCONNECTED

DISCONNECTED means the worker processing the job disconnected.

var CANCELED

CANCELED means the job was canceled.

class WalkAlgorithm (*args, **kwds)

WalkAlgorithm is used by WalkJob to specify how it should walk through a tree.

Expand source code
class WalkAlgorithm(betterproto.Enum):
    """
    WalkAlgorithm is used by WalkJob to specify how it should walk through a
    tree.
    """

    UNKNOWN = 0
    LEVEL_ORDER = 1
    PRE_ORDER = 2
    MIRRORED_POST_ORDER = 3

Ancestors

  • betterproto.Enum
  • enum.IntEnum
  • builtins.int
  • enum.ReprEnum
  • enum.Enum

Class variables

var UNKNOWN
var LEVEL_ORDER
var PRE_ORDER
var MIRRORED_POST_ORDER
class Job (id: int = None)

Job uniquely identifies a Job Job will be nil to indicate no Job, or an unset Job.

Expand source code
@dataclass(eq=False, repr=False)
class Job(betterproto.Message):
    """
    Job uniquely identifies a Job Job will be nil to indicate no Job, or an
    unset Job.
    """

    id: int = betterproto.int64_field(1)

Ancestors

  • betterproto.Message
  • abc.ABC

Class variables

var id : int
class JobInfo (job: Job = None, parent_job: Job = None, state: JobState = None, program: str = None, input: List[str] = None, success: JobInfoSuccess = None, error: JobErrorCode = None)

JobInfo describes a Job

Expand source code
@dataclass(eq=False, repr=False)
class JobInfo(betterproto.Message):
    """JobInfo describes a Job"""

    job: "Job" = betterproto.message_field(1)
    """Job is the Job's identity"""

    parent_job: "Job" = betterproto.message_field(2)
    """parent_job is the Job's parent if it exists."""

    state: "JobState" = betterproto.enum_field(3)
    """
    state is the Job's state. See JobState for a description of the possible
    states.
    """

    program: str = betterproto.string_field(4)
    """
    program is the fileset that contains the code specification for the Job.
    """

    input: List[str] = betterproto.string_field(5)
    """input is the input fileset handles for the Job."""

    success: "JobInfoSuccess" = betterproto.message_field(6, group="result")
    error: "JobErrorCode" = betterproto.enum_field(7, group="result")
    """error is set when the Job is unable to complete successfully"""

Ancestors

  • betterproto.Message
  • abc.ABC

Class variables

var jobJob

Job is the Job's identity

var parent_jobJob

parent_job is the Job's parent if it exists.

var stateJobState

state is the Job's state. See JobState for a description of the possible states.

var program : str

program is the fileset that contains the code specification for the Job.

var input : List[str]

input is the input fileset handles for the Job.

var successJobInfoSuccess
var errorJobErrorCode

error is set when the Job is unable to complete successfully

class JobInfoSuccess (output: List[str] = None)

Success is produced by a successfully completing Job.

Expand source code
@dataclass(eq=False, repr=False)
class JobInfoSuccess(betterproto.Message):
    """Success is produced by a successfully completing Job."""

    output: List[str] = betterproto.string_field(1)
    """output is a list of fileset handles produced by a successful Job."""

Ancestors

  • betterproto.Message
  • abc.ABC

Class variables

var output : List[str]

output is a list of fileset handles produced by a successful Job.

class JobInfoDetails (job_info: JobInfo = None)

JobInfoDetails is more detailed information about a Job. It contains a superset of the information in JobInfo

Expand source code
@dataclass(eq=False, repr=False)
class JobInfoDetails(betterproto.Message):
    """
    JobInfoDetails is more detailed information about a Job. It contains a
    superset of the information in JobInfo
    """

    job_info: "JobInfo" = betterproto.message_field(1)

Ancestors

  • betterproto.Message
  • abc.ABC

Class variables

var job_infoJobInfo
class Queue (id: bytes = None)

Queue uniquely identifies a Queue Queue will be nil to identify no Queue, or to indicate unset.

Expand source code
@dataclass(eq=False, repr=False)
class Queue(betterproto.Message):
    """
    Queue uniquely identifies a Queue Queue will be nil to identify no Queue,
    or to indicate unset.
    """

    id: bytes = betterproto.bytes_field(1)

Ancestors

  • betterproto.Message
  • abc.ABC

Class variables

var id : bytes
class QueueInfo (queue: Queue = None, program: List[str] = None)

QueueInfo describes a Queue

Expand source code
@dataclass(eq=False, repr=False)
class QueueInfo(betterproto.Message):
    """QueueInfo describes a Queue"""

    queue: "Queue" = betterproto.message_field(1)
    """queue is the Queue's identity"""

    program: List[str] = betterproto.string_field(2)
    """
    The current storage system supports cloned filesets with the same content
    hash.
    """

Ancestors

  • betterproto.Message
  • abc.ABC

Class variables

var queueQueue

queue is the Queue's identity

var program : List[str]

The current storage system supports cloned filesets with the same content hash.

class QueueInfoDetails (queue_info: QueueInfo = None, size: int = None)

QueueInfoDetails contains detailed information about a Queue, which may be more expensive to get. It contains a superset of the information in QueueInfo.

Expand source code
@dataclass(eq=False, repr=False)
class QueueInfoDetails(betterproto.Message):
    """
    QueueInfoDetails contains detailed information about a Queue, which may be
    more expensive to get. It contains a superset of the information in
    QueueInfo.
    """

    queue_info: "QueueInfo" = betterproto.message_field(1)
    size: int = betterproto.int64_field(2)
    """size is the number of elements queued."""

Ancestors

  • betterproto.Message
  • abc.ABC

Class variables

var queue_infoQueueInfo
var size : int

size is the number of elements queued.

class AwaitRequest (context: str = None, job: int = None, desired_state: JobState = None)

AwaitRequest(context: str = None, job: int = None, desired_state: 'JobState' = None)

Expand source code
@dataclass(eq=False, repr=False)
class AwaitRequest(betterproto.Message):
    context: str = betterproto.string_field(1)
    job: int = betterproto.int64_field(2)
    desired_state: "JobState" = betterproto.enum_field(3)

Ancestors

  • betterproto.Message
  • abc.ABC

Class variables

var context : str
var job : int
var desired_stateJobState
class AwaitResponse (actual_state: JobState = None)

AwaitResponse(actual_state: 'JobState' = None)

Expand source code
@dataclass(eq=False, repr=False)
class AwaitResponse(betterproto.Message):
    actual_state: "JobState" = betterproto.enum_field(1)

Ancestors

  • betterproto.Message
  • abc.ABC

Class variables

var actual_stateJobState
class CreateJobRequest (context: str = None, program: str = None, input: List[str] = None, cache_read: bool = None, cache_write: bool = None)

CreateJobRequest(context: str = None, program: str = None, input: List[str] = None, cache_read: bool = None, cache_write: bool = None)

Expand source code
@dataclass(eq=False, repr=False)
class CreateJobRequest(betterproto.Message):
    context: str = betterproto.string_field(1)
    """
    context is a bearer token used when calling from within a running Job.
    """

    program: str = betterproto.string_field(2)
    """program is a fileset handle."""

    input: List[str] = betterproto.string_field(3)
    """input is a list of fileset handles."""

    cache_read: bool = betterproto.bool_field(4)
    cache_write: bool = betterproto.bool_field(5)

Ancestors

  • betterproto.Message
  • abc.ABC

Class variables

var context : str

context is a bearer token used when calling from within a running Job.

var program : str

program is a fileset handle.

var input : List[str]

input is a list of fileset handles.

var cache_read : bool
var cache_write : bool
class CreateJobResponse (id: Job = None)

CreateJobResponse(id: 'Job' = None)

Expand source code
@dataclass(eq=False, repr=False)
class CreateJobResponse(betterproto.Message):
    id: "Job" = betterproto.message_field(1)

Ancestors

  • betterproto.Message
  • abc.ABC

Class variables

var idJob
class CancelJobRequest (context: str = None, job: Job = None)

CancelJobRequest(context: str = None, job: 'Job' = None)

Expand source code
@dataclass(eq=False, repr=False)
class CancelJobRequest(betterproto.Message):
    context: str = betterproto.string_field(1)
    """
    context is a bearer token used when calling from within a running Job.
    """

    job: "Job" = betterproto.message_field(2)

Ancestors

  • betterproto.Message
  • abc.ABC

Class variables

var context : str

context is a bearer token used when calling from within a running Job.

var jobJob
class CancelJobResponse

CancelJobResponse()

Expand source code
@dataclass(eq=False, repr=False)
class CancelJobResponse(betterproto.Message):
    pass

Ancestors

  • betterproto.Message
  • abc.ABC
class DeleteJobRequest (context: str = None, job: Job = None)

DeleteJobRequest(context: str = None, job: 'Job' = None)

Expand source code
@dataclass(eq=False, repr=False)
class DeleteJobRequest(betterproto.Message):
    context: str = betterproto.string_field(1)
    """
    context is a bearer token used when calling from within a running Job.
    """

    job: "Job" = betterproto.message_field(2)

Ancestors

  • betterproto.Message
  • abc.ABC

Class variables

var context : str

context is a bearer token used when calling from within a running Job.

var jobJob
class DeleteJobResponse

DeleteJobResponse()

Expand source code
@dataclass(eq=False, repr=False)
class DeleteJobResponse(betterproto.Message):
    pass

Ancestors

  • betterproto.Message
  • abc.ABC
class ListJobRequest (context: str = None, job: Job = None)

TODO: - Filter - Paginate

Expand source code
@dataclass(eq=False, repr=False)
class ListJobRequest(betterproto.Message):
    """TODO: - Filter - Paginate"""

    context: str = betterproto.string_field(1)
    """
    context is a bearer token used when calling from within a running Job.
    """

    job: "Job" = betterproto.message_field(2)
    """
    job is the job to start listing at. If nil, then the listing starts at the
    first job in the natural ordering.
    """

Ancestors

  • betterproto.Message
  • abc.ABC

Class variables

var context : str

context is a bearer token used when calling from within a running Job.

var jobJob

job is the job to start listing at. If nil, then the listing starts at the first job in the natural ordering.

class ListJobResponse (id: Job = None, info: JobInfo = None, details: JobInfoDetails = None)

ListJobResponse lists information about Jobs ID will always be set. Info and Details may not be set depending on how much information was requested.

Expand source code
@dataclass(eq=False, repr=False)
class ListJobResponse(betterproto.Message):
    """
    ListJobResponse lists information about Jobs ID will always be set. Info
    and Details may not be set depending on how much information was requested.
    """

    id: "Job" = betterproto.message_field(1)
    info: "JobInfo" = betterproto.message_field(2)
    details: "JobInfoDetails" = betterproto.message_field(3)

Ancestors

  • betterproto.Message
  • abc.ABC

Class variables

var idJob
var infoJobInfo
var detailsJobInfoDetails
class WalkJobRequest (context: str = None, job: Job = None, algorithm: WalkAlgorithm = None, max_depth: int = None)

WalkJobRequest(context: str = None, job: 'Job' = None, algorithm: 'WalkAlgorithm' = None, max_depth: int = None)

Expand source code
@dataclass(eq=False, repr=False)
class WalkJobRequest(betterproto.Message):
    context: str = betterproto.string_field(1)
    """
    context is a bearer token used when calling from within a running Job.
    """

    job: "Job" = betterproto.message_field(2)
    """
    job is the job to start walking from.  If unset, the context Job is
    assumed.
    """

    algorithm: "WalkAlgorithm" = betterproto.enum_field(3)
    """A sane client should default to 'LEVEL_ORDER'."""

    max_depth: int = betterproto.uint64_field(4)
    """
    The depth relative from the starting point to traverse to. A depth of 0 is
    interpreted as 10,000. A depth greater than 10,000 is capped at 10,000.
    """

Ancestors

  • betterproto.Message
  • abc.ABC

Class variables

var context : str

context is a bearer token used when calling from within a running Job.

var jobJob

job is the job to start walking from. If unset, the context Job is assumed.

var algorithmWalkAlgorithm

A sane client should default to 'LEVEL_ORDER'.

var max_depth : int

The depth relative from the starting point to traverse to. A depth of 0 is interpreted as 10,000. A depth greater than 10,000 is capped at 10,000.

class InspectJobRequest (context: str = None, job: Job = None)

InspectJobRequest(context: str = None, job: 'Job' = None)

Expand source code
@dataclass(eq=False, repr=False)
class InspectJobRequest(betterproto.Message):
    context: str = betterproto.string_field(1)
    """
    context is a bearer token used when calling from within a running Job.
    """

    job: "Job" = betterproto.message_field(2)
    """
    job is the job to start walking from.  If unset the context Job is assumed.
    """

Ancestors

  • betterproto.Message
  • abc.ABC

Class variables

var context : str

context is a bearer token used when calling from within a running Job.

var jobJob

job is the job to start walking from. If unset the context Job is assumed.

class InspectJobResponse (details: JobInfoDetails = None)

InspectJobResponse(details: 'JobInfoDetails' = None)

Expand source code
@dataclass(eq=False, repr=False)
class InspectJobResponse(betterproto.Message):
    details: "JobInfoDetails" = betterproto.message_field(1)

Ancestors

  • betterproto.Message
  • abc.ABC

Class variables

var detailsJobInfoDetails
class ProcessQueueRequest (queue: Queue = None, success: ProcessQueueRequestSuccess = None, failed: bool = None)

Queue Messages ProcessQueueRequest is the client -> server message for the bi-di ProcessQueue RPC.

Expand source code
@dataclass(eq=False, repr=False)
class ProcessQueueRequest(betterproto.Message):
    """
    Queue Messages ProcessQueueRequest is the client -> server message for the
    bi-di ProcessQueue RPC.
    """

    queue: "Queue" = betterproto.message_field(1)
    """queue is set to start processing from a Queue."""

    success: "ProcessQueueRequestSuccess" = betterproto.message_field(2, group="result")
    failed: bool = betterproto.bool_field(3, group="result")
    """
    failed is set by the client to fail the Job. The Job will transition to
    state DONE with code FAILED.
    """

Ancestors

  • betterproto.Message
  • abc.ABC

Class variables

var queueQueue

queue is set to start processing from a Queue.

var successProcessQueueRequestSuccess
var failed : bool

failed is set by the client to fail the Job. The Job will transition to state DONE with code FAILED.

class ProcessQueueRequestSuccess (output: List[str] = None)

Success is set by the client to complete the Job successfully.

Expand source code
@dataclass(eq=False, repr=False)
class ProcessQueueRequestSuccess(betterproto.Message):
    """Success is set by the client to complete the Job successfully."""

    output: List[str] = betterproto.string_field(1)
    """output is a list of fileset handles produced by a successful Job."""

Ancestors

  • betterproto.Message
  • abc.ABC

Class variables

var output : List[str]

output is a list of fileset handles produced by a successful Job.

class ProcessQueueResponse (context: str = None, input: List[str] = None)

ProcessQueueResposne is the server -> client message for the bi-di ProcessQueue RPC.

Expand source code
@dataclass(eq=False, repr=False)
class ProcessQueueResponse(betterproto.Message):
    """
    ProcessQueueResposne is the server -> client message for the bi-di
    ProcessQueue RPC.
    """

    context: str = betterproto.string_field(1)
    """
    context is a bearer token used to act on behalf of the Job in other RPCs.
    The server issues this token to the client, and the client should use it
    when performing Job RPCs.
    """

    input: List[str] = betterproto.string_field(2)
    """
    input is the input data for a Job. The server sends this to ask the client
    to compute the output.
    """

Ancestors

  • betterproto.Message
  • abc.ABC

Class variables

var context : str

context is a bearer token used to act on behalf of the Job in other RPCs. The server issues this token to the client, and the client should use it when performing Job RPCs.

var input : List[str]

input is the input data for a Job. The server sends this to ask the client to compute the output.

class ListQueueRequest

TODO: - Filter - Paginate

Expand source code
@dataclass(eq=False, repr=False)
class ListQueueRequest(betterproto.Message):
    """TODO: - Filter - Paginate"""

    pass

Ancestors

  • betterproto.Message
  • abc.ABC
class ListQueueResponse (id: Queue = None, info: QueueInfo = None, details: QueueInfoDetails = None)

ListQueueResponse(id: 'Queue' = None, info: 'QueueInfo' = None, details: 'QueueInfoDetails' = None)

Expand source code
@dataclass(eq=False, repr=False)
class ListQueueResponse(betterproto.Message):
    id: "Queue" = betterproto.message_field(1)
    info: "QueueInfo" = betterproto.message_field(2)
    details: "QueueInfoDetails" = betterproto.message_field(3)

Ancestors

  • betterproto.Message
  • abc.ABC

Class variables

var idQueue
var infoQueueInfo
var detailsQueueInfoDetails
class InspectQueueRequest (queue: Queue = None)

InspectQueueRequest(queue: 'Queue' = None)

Expand source code
@dataclass(eq=False, repr=False)
class InspectQueueRequest(betterproto.Message):
    queue: "Queue" = betterproto.message_field(1)

Ancestors

  • betterproto.Message
  • abc.ABC

Class variables

var queueQueue
class InspectQueueResponse (details: QueueInfoDetails = None)

InspectQueueResponse(details: 'QueueInfoDetails' = None)

Expand source code
@dataclass(eq=False, repr=False)
class InspectQueueResponse(betterproto.Message):
    details: "QueueInfoDetails" = betterproto.message_field(1)

Ancestors

  • betterproto.Message
  • abc.ABC

Class variables

var detailsQueueInfoDetails
class ApiStub (channel: grpc.Channel)
Expand source code
class ApiStub:

    def __init__(self, channel: "grpc.Channel"):
        self.__rpc_create_job = channel.unary_unary(
            "/pjs.API/CreateJob",
            request_serializer=CreateJobRequest.SerializeToString,
            response_deserializer=CreateJobResponse.FromString,
        )
        self.__rpc_cancel_job = channel.unary_unary(
            "/pjs.API/CancelJob",
            request_serializer=CancelJobRequest.SerializeToString,
            response_deserializer=CancelJobResponse.FromString,
        )
        self.__rpc_delete_job = channel.unary_unary(
            "/pjs.API/DeleteJob",
            request_serializer=DeleteJobRequest.SerializeToString,
            response_deserializer=DeleteJobResponse.FromString,
        )
        self.__rpc_list_job = channel.unary_stream(
            "/pjs.API/ListJob",
            request_serializer=ListJobRequest.SerializeToString,
            response_deserializer=ListJobResponse.FromString,
        )
        self.__rpc_walk_job = channel.unary_stream(
            "/pjs.API/WalkJob",
            request_serializer=WalkJobRequest.SerializeToString,
            response_deserializer=ListJobResponse.FromString,
        )
        self.__rpc_inspect_job = channel.unary_unary(
            "/pjs.API/InspectJob",
            request_serializer=InspectJobRequest.SerializeToString,
            response_deserializer=InspectJobResponse.FromString,
        )
        self.__rpc_process_queue = channel.stream_stream(
            "/pjs.API/ProcessQueue",
            request_serializer=ProcessQueueRequest.SerializeToString,
            response_deserializer=ProcessQueueResponse.FromString,
        )
        self.__rpc_list_queue = channel.unary_stream(
            "/pjs.API/ListQueue",
            request_serializer=ListQueueRequest.SerializeToString,
            response_deserializer=ListQueueResponse.FromString,
        )
        self.__rpc_inspect_queue = channel.unary_unary(
            "/pjs.API/InspectQueue",
            request_serializer=InspectQueueRequest.SerializeToString,
            response_deserializer=InspectQueueResponse.FromString,
        )
        self.__rpc_await_ = channel.unary_unary(
            "/pjs.API/Await",
            request_serializer=AwaitRequest.SerializeToString,
            response_deserializer=AwaitResponse.FromString,
        )

    def create_job(
        self,
        *,
        context: str = "",
        program: str = "",
        input: Optional[List[str]] = None,
        cache_read: bool = False,
        cache_write: bool = False
    ) -> "CreateJobResponse":
        input = input or []

        request = CreateJobRequest()
        request.context = context
        request.program = program
        request.input = input
        request.cache_read = cache_read
        request.cache_write = cache_write

        return self.__rpc_create_job(request)

    def cancel_job(
        self, *, context: str = "", job: "Job" = None
    ) -> "CancelJobResponse":

        request = CancelJobRequest()
        request.context = context
        if job is not None:
            request.job = job

        return self.__rpc_cancel_job(request)

    def delete_job(
        self, *, context: str = "", job: "Job" = None
    ) -> "DeleteJobResponse":

        request = DeleteJobRequest()
        request.context = context
        if job is not None:
            request.job = job

        return self.__rpc_delete_job(request)

    def list_job(
        self, *, context: str = "", job: "Job" = None
    ) -> Iterator["ListJobResponse"]:

        request = ListJobRequest()
        request.context = context
        if job is not None:
            request.job = job

        for response in self.__rpc_list_job(request):
            yield response

    def walk_job(
        self,
        *,
        context: str = "",
        job: "Job" = None,
        algorithm: "WalkAlgorithm" = None,
        max_depth: int = 0
    ) -> Iterator["ListJobResponse"]:

        request = WalkJobRequest()
        request.context = context
        if job is not None:
            request.job = job
        request.algorithm = algorithm
        request.max_depth = max_depth

        for response in self.__rpc_walk_job(request):
            yield response

    def inspect_job(
        self, *, context: str = "", job: "Job" = None
    ) -> "InspectJobResponse":

        request = InspectJobRequest()
        request.context = context
        if job is not None:
            request.job = job

        return self.__rpc_inspect_job(request)

    def process_queue(
        self,
        request_iterator: Union[
            AsyncIterable["ProcessQueueRequest"], Iterable["ProcessQueueRequest"]
        ],
    ) -> Iterator["ProcessQueueResponse"]:

        for response in self.__rpc_process_queue(request_iterator):
            yield response

    def list_queue(self) -> Iterator["ListQueueResponse"]:

        request = ListQueueRequest()

        for response in self.__rpc_list_queue(request):
            yield response

    def inspect_queue(self, *, queue: "Queue" = None) -> "InspectQueueResponse":

        request = InspectQueueRequest()
        if queue is not None:
            request.queue = queue

        return self.__rpc_inspect_queue(request)

    def await_(
        self, *, context: str = "", job: int = 0, desired_state: "JobState" = None
    ) -> "AwaitResponse":

        request = AwaitRequest()
        request.context = context
        request.job = job
        request.desired_state = desired_state

        return self.__rpc_await_(request)

Methods

def create_job(self, *, context: str = '', program: str = '', input: Optional[List[str]] = None, cache_read: bool = False, cache_write: bool = False) ‑> CreateJobResponse
Expand source code
def create_job(
    self,
    *,
    context: str = "",
    program: str = "",
    input: Optional[List[str]] = None,
    cache_read: bool = False,
    cache_write: bool = False
) -> "CreateJobResponse":
    input = input or []

    request = CreateJobRequest()
    request.context = context
    request.program = program
    request.input = input
    request.cache_read = cache_read
    request.cache_write = cache_write

    return self.__rpc_create_job(request)
def cancel_job(self, *, context: str = '', job: Job = None) ‑> CancelJobResponse
Expand source code
def cancel_job(
    self, *, context: str = "", job: "Job" = None
) -> "CancelJobResponse":

    request = CancelJobRequest()
    request.context = context
    if job is not None:
        request.job = job

    return self.__rpc_cancel_job(request)
def delete_job(self, *, context: str = '', job: Job = None) ‑> DeleteJobResponse
Expand source code
def delete_job(
    self, *, context: str = "", job: "Job" = None
) -> "DeleteJobResponse":

    request = DeleteJobRequest()
    request.context = context
    if job is not None:
        request.job = job

    return self.__rpc_delete_job(request)
def list_job(self, *, context: str = '', job: Job = None) ‑> Iterator[ListJobResponse]
Expand source code
def list_job(
    self, *, context: str = "", job: "Job" = None
) -> Iterator["ListJobResponse"]:

    request = ListJobRequest()
    request.context = context
    if job is not None:
        request.job = job

    for response in self.__rpc_list_job(request):
        yield response
def walk_job(self, *, context: str = '', job: Job = None, algorithm: WalkAlgorithm = None, max_depth: int = 0) ‑> Iterator[ListJobResponse]
Expand source code
def walk_job(
    self,
    *,
    context: str = "",
    job: "Job" = None,
    algorithm: "WalkAlgorithm" = None,
    max_depth: int = 0
) -> Iterator["ListJobResponse"]:

    request = WalkJobRequest()
    request.context = context
    if job is not None:
        request.job = job
    request.algorithm = algorithm
    request.max_depth = max_depth

    for response in self.__rpc_walk_job(request):
        yield response
def inspect_job(self, *, context: str = '', job: Job = None) ‑> InspectJobResponse
Expand source code
def inspect_job(
    self, *, context: str = "", job: "Job" = None
) -> "InspectJobResponse":

    request = InspectJobRequest()
    request.context = context
    if job is not None:
        request.job = job

    return self.__rpc_inspect_job(request)
def process_queue(self, request_iterator: Union[AsyncIterable[ForwardRef('ProcessQueueRequest')], Iterable[ForwardRef('ProcessQueueRequest')]]) ‑> Iterator[ProcessQueueResponse]
Expand source code
def process_queue(
    self,
    request_iterator: Union[
        AsyncIterable["ProcessQueueRequest"], Iterable["ProcessQueueRequest"]
    ],
) -> Iterator["ProcessQueueResponse"]:

    for response in self.__rpc_process_queue(request_iterator):
        yield response
def list_queue(self) ‑> Iterator[ListQueueResponse]
Expand source code
def list_queue(self) -> Iterator["ListQueueResponse"]:

    request = ListQueueRequest()

    for response in self.__rpc_list_queue(request):
        yield response
def inspect_queue(self, *, queue: Queue = None) ‑> InspectQueueResponse
Expand source code
def inspect_queue(self, *, queue: "Queue" = None) -> "InspectQueueResponse":

    request = InspectQueueRequest()
    if queue is not None:
        request.queue = queue

    return self.__rpc_inspect_queue(request)
def await_(self, *, context: str = '', job: int = 0, desired_state: JobState = None) ‑> AwaitResponse
Expand source code
def await_(
    self, *, context: str = "", job: int = 0, desired_state: "JobState" = None
) -> "AwaitResponse":

    request = AwaitRequest()
    request.context = context
    request.job = job
    request.desired_state = desired_state

    return self.__rpc_await_(request)