Interface of a session object.

A session object represents a live connection to a session kernel.

This represents a persistent kernel connection with a particular key, that persists across changing kernels and kernels getting terminated. As such, a number of signals are proxied from the current kernel for convenience.

The kernel is owned by the session, in that the session creates the kernel and manages its lifecycle.

interface ISessionConnection {
    anyMessage: ISignal<Session.ISessionConnection, IAnyMessageArgs>;
    connectionStatusChanged: ISignal<
        Session.ISessionConnection,
        Kernel.ConnectionStatus,
    >;
    disposed: ISignal<Session.ISessionConnection, void>;
    id: string;
    iopubMessage: ISignal<
        Session.ISessionConnection,
        IIOPubMessage<IOPubMessageType>,
    >;
    isDisposed: boolean;
    kernel: null | Kernel.IKernelConnection;
    kernelChanged: ISignal<
        Session.ISessionConnection,
        IChangedArgs<
            null
            | Kernel.IKernelConnection,
            null | Kernel.IKernelConnection,
            "kernel",
        >,
    >;
    model: Session.IModel;
    name: string;
    path: string;
    pendingInput: ISignal<Session.ISessionConnection, boolean>;
    propertyChanged: ISignal<
        Session.ISessionConnection,
        "name"
        | "type"
        | "path",
    >;
    serverSettings: ServerConnection.ISettings;
    statusChanged: ISignal<Session.ISessionConnection, Kernel.Status>;
    type: string;
    unhandledMessage: ISignal<
        Session.ISessionConnection,
        KernelMessage.IMessage<KernelMessage.MessageType>,
    >;
    changeKernel(
        options: Partial<Kernel.IModel>,
    ): Promise<null | Kernel.IKernelConnection>;
    dispose(): void;
    setName(name: string): Promise<void>;
    setPath(path: string): Promise<void>;
    setType(type: string): Promise<void>;
    shutdown(): Promise<void>;
}

Hierarchy

Properties

The kernel anyMessage signal, proxied from the current kernel.

connectionStatusChanged: ISignal<
    Session.ISessionConnection,
    Kernel.ConnectionStatus,
>

The kernel connectionStatusChanged signal, proxied from the current kernel.

A signal emitted when the object is disposed.

id: string

Unique id of the session.

The kernel iopubMessage signal, proxied from the current kernel.

isDisposed: boolean

Test whether the object has been disposed.

This property is always safe to access.

kernel: null | Kernel.IKernelConnection

The kernel.

This is a read-only property, and can be altered by [changeKernel].

A number of kernel signals are proxied through the session from whatever the current kernel is for convenience.

kernelChanged: ISignal<
    Session.ISessionConnection,
    IChangedArgs<
        null
        | Kernel.IKernelConnection,
        null | Kernel.IKernelConnection,
        "kernel",
    >,
>

A signal emitted when the kernel changes.

The model associated with the session.

name: string

The current name associated with the session.

path: string

The current path associated with the session.

pendingInput: ISignal<Session.ISessionConnection, boolean>

The kernel pendingInput signal, proxied from the current kernel.

propertyChanged: ISignal<Session.ISessionConnection, "name" | "type" | "path">

A signal emitted when a session property changes.

serverSettings: ServerConnection.ISettings

The server settings of the session.

The kernel statusChanged signal, proxied from the current kernel.

type: string

The type of the session.

The kernel unhandledMessage signal, proxied from the current kernel.

Methods

  • Dispose of the resources held by the object.

    If the object's dispose method is called more than once, all calls made after the first will be a no-op.

    It is undefined behavior to use any functionality of the object after it has been disposed unless otherwise explicitly noted.

    Returns void

  • Change the session name.

    Parameters

    • name: string

    Returns Promise<void>

    A promise that resolves when the session has renamed.

    This uses the Jupyter REST API, and the response is validated. The promise is fulfilled on a valid response and rejected otherwise.

  • Change the session path.

    Parameters

    • path: string

      The new session path.

    Returns Promise<void>

    A promise that resolves when the session has renamed.

    This uses the Jupyter REST API, and the response is validated. The promise is fulfilled on a valid response and rejected otherwise.

  • Change the session type.

    Parameters

    • type: string

    Returns Promise<void>

    A promise that resolves when the session has renamed.

    This uses the Jupyter REST API, and the response is validated. The promise is fulfilled on a valid response and rejected otherwise.

  • Kill the kernel and shutdown the session.

    Returns Promise<void>

    A promise that resolves when the session is shut down.

    This uses the Jupyter REST API, and the response is validated. The promise is fulfilled on a valid response and rejected otherwise.