Cloning¶
The clone
module¶
BookstoreCloneHandler
¶
-
class
bookstore.clone.
BookstoreCloneHandler
(application: tornado.web.Application, request: tornado.httputil.HTTPServerRequest, **kwargs)¶ Prepares and provides clone options page, populating UI with clone option parameters.
Provides handling for
GET
requests when cloning a notebook from storage (S3). Launches a user interface with cloning options.-
initialize
(self)¶ Helper to access bookstore settings.
-
get
(self)¶ Checks for valid storage settings and render a UI for clone options.
-
construct_template_params
(self, s3_bucket, s3_object_key)¶ Helper to populate Jinja template for cloning option page.
-
get_template
(self, name)¶ Loads a Jinja template and its related settings.
-
Methods¶
-
BookstoreCloneHandler.
initialize
() Helper to retrieve bookstore setting for the session.
-
BookstoreCloneHandler.
get
() GET /bookstore/clone?s3_bucket=<your_s3_bucket>&s3_key=<your_s3_key>
Renders an options page that will allow you to clone a notebook from a specific bucket via the Bookstore cloning API.
s3_bucket is the bucket you wish to clone from. s3_key is the object key that you wish to clone.
-
BookstoreCloneHandler.
construct_template_params
(s3_bucket, s3_object_key) Helper that takes valid S3 parameters and populates UI template
Returns: Template parameters in a dictionary Return type: dict
-
BookstoreCloneHandler.
get_template
(name) Loads a Jinja template by name.
BookstoreCloneAPIHandler
¶
-
class
bookstore.clone.
BookstoreCloneAPIHandler
(application: tornado.web.Application, request: tornado.httputil.HTTPServerRequest, **kwargs)¶ Handle notebook clone from storage.
Provides API handling for
POST
and clones a notebook from storage (S3).-
initialize
(self)¶ Helper to access bookstore settings.
-
post
(self)¶ Clone a notebook from the location specified by the payload.
-
Methods¶
-
BookstoreCloneAPIHandler.
initialize
() Helper to retrieve bookstore setting for the session.
-
BookstoreCloneAPIHandler.
post
() POST /api/bookstore/clone
Clone a notebook to the path specified in the payload.
The payload type for the request should be:
{ "s3_bucket": string, "s3_key": string, "target_path"?: string }
The response payload should match the standard Jupyter contents API POST response.
-
BookstoreCloneAPIHandler.
build_post_model_response
(model, target_path)¶ Helper that takes constructs a Jupyter Contents API compliant model.
If the file at target_path already exists, this increments the file name.