alibabacloud-emr-serverless-spark20230808 1.0.1__tar.gz → 1.2.0__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of alibabacloud-emr-serverless-spark20230808 might be problematic. Click here for more details.

Files changed (18) hide show
  1. alibabacloud_emr-serverless-spark20230808-1.2.0/ChangeLog.md +18 -0
  2. {alibabacloud_emr-serverless-spark20230808-1.0.1 → alibabacloud_emr-serverless-spark20230808-1.2.0}/PKG-INFO +1 -1
  3. alibabacloud_emr-serverless-spark20230808-1.2.0/alibabacloud_emr_serverless_spark20230808/__init__.py +1 -0
  4. {alibabacloud_emr-serverless-spark20230808-1.0.1 → alibabacloud_emr-serverless-spark20230808-1.2.0}/alibabacloud_emr_serverless_spark20230808/client.py +472 -0
  5. {alibabacloud_emr-serverless-spark20230808-1.0.1 → alibabacloud_emr-serverless-spark20230808-1.2.0}/alibabacloud_emr_serverless_spark20230808/models.py +1268 -0
  6. {alibabacloud_emr-serverless-spark20230808-1.0.1 → alibabacloud_emr-serverless-spark20230808-1.2.0}/alibabacloud_emr_serverless_spark20230808.egg-info/PKG-INFO +1 -1
  7. {alibabacloud_emr-serverless-spark20230808-1.0.1 → alibabacloud_emr-serverless-spark20230808-1.2.0}/setup.py +1 -1
  8. alibabacloud_emr-serverless-spark20230808-1.0.1/ChangeLog.md +0 -3
  9. alibabacloud_emr-serverless-spark20230808-1.0.1/alibabacloud_emr_serverless_spark20230808/__init__.py +0 -1
  10. {alibabacloud_emr-serverless-spark20230808-1.0.1 → alibabacloud_emr-serverless-spark20230808-1.2.0}/LICENSE +0 -0
  11. {alibabacloud_emr-serverless-spark20230808-1.0.1 → alibabacloud_emr-serverless-spark20230808-1.2.0}/MANIFEST.in +0 -0
  12. {alibabacloud_emr-serverless-spark20230808-1.0.1 → alibabacloud_emr-serverless-spark20230808-1.2.0}/README-CN.md +0 -0
  13. {alibabacloud_emr-serverless-spark20230808-1.0.1 → alibabacloud_emr-serverless-spark20230808-1.2.0}/README.md +0 -0
  14. {alibabacloud_emr-serverless-spark20230808-1.0.1 → alibabacloud_emr-serverless-spark20230808-1.2.0}/alibabacloud_emr_serverless_spark20230808.egg-info/SOURCES.txt +0 -0
  15. {alibabacloud_emr-serverless-spark20230808-1.0.1 → alibabacloud_emr-serverless-spark20230808-1.2.0}/alibabacloud_emr_serverless_spark20230808.egg-info/dependency_links.txt +0 -0
  16. {alibabacloud_emr-serverless-spark20230808-1.0.1 → alibabacloud_emr-serverless-spark20230808-1.2.0}/alibabacloud_emr_serverless_spark20230808.egg-info/requires.txt +0 -0
  17. {alibabacloud_emr-serverless-spark20230808-1.0.1 → alibabacloud_emr-serverless-spark20230808-1.2.0}/alibabacloud_emr_serverless_spark20230808.egg-info/top_level.txt +0 -0
  18. {alibabacloud_emr-serverless-spark20230808-1.0.1 → alibabacloud_emr-serverless-spark20230808-1.2.0}/setup.cfg +0 -0
@@ -0,0 +1,18 @@
1
+ 2024-05-20 Version: 1.1.0
2
+ - Support API ListReleaseVersions.
3
+ - Support API ListWorkspaceQueues.
4
+ - Support API ListWorkspaces.
5
+
6
+
7
+ 2024-05-17 Version: 1.0.1
8
+ - Update API CancelJobRun: update param workspaceId.
9
+ - Update API CancelJobRun: update param jobRunId.
10
+ - Update API GetJobRun: update param workspaceId.
11
+ - Update API GetJobRun: update param jobRunId.
12
+ - Update API ListJobRuns: update param workspaceId.
13
+ - Update API StartJobRun: update param workspaceId.
14
+
15
+
16
+ 2024-04-16 Version: 1.0.0
17
+ - Generated python 2023-08-08 for emr-serverless-spark.
18
+
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: alibabacloud_emr-serverless-spark20230808
3
- Version: 1.0.1
3
+ Version: 1.2.0
4
4
  Summary: Alibaba Cloud emr-serverless-spark (20230808) SDK Library for Python
5
5
  Home-page: https://github.com/aliyun/alibabacloud-python-sdk
6
6
  Author: Alibaba Cloud SDK
@@ -433,6 +433,478 @@ class Client(OpenApiClient):
433
433
  headers = {}
434
434
  return await self.list_job_runs_with_options_async(workspace_id, request, headers, runtime)
435
435
 
436
+ def list_release_versions_with_options(
437
+ self,
438
+ request: emr_serverless_spark_20230808_models.ListReleaseVersionsRequest,
439
+ headers: Dict[str, str],
440
+ runtime: util_models.RuntimeOptions,
441
+ ) -> emr_serverless_spark_20230808_models.ListReleaseVersionsResponse:
442
+ """
443
+ @summary 获取发布版本列表
444
+
445
+ @param request: ListReleaseVersionsRequest
446
+ @param headers: map
447
+ @param runtime: runtime options for this request RuntimeOptions
448
+ @return: ListReleaseVersionsResponse
449
+ """
450
+ UtilClient.validate_model(request)
451
+ query = {}
452
+ if not UtilClient.is_unset(request.region_id):
453
+ query['regionId'] = request.region_id
454
+ if not UtilClient.is_unset(request.release_type):
455
+ query['releaseType'] = request.release_type
456
+ if not UtilClient.is_unset(request.release_version):
457
+ query['releaseVersion'] = request.release_version
458
+ if not UtilClient.is_unset(request.release_version_status):
459
+ query['releaseVersionStatus'] = request.release_version_status
460
+ req = open_api_models.OpenApiRequest(
461
+ headers=headers,
462
+ query=OpenApiUtilClient.query(query)
463
+ )
464
+ params = open_api_models.Params(
465
+ action='ListReleaseVersions',
466
+ version='2023-08-08',
467
+ protocol='HTTPS',
468
+ pathname=f'/api/v1/releaseVersions',
469
+ method='GET',
470
+ auth_type='AK',
471
+ style='ROA',
472
+ req_body_type='json',
473
+ body_type='json'
474
+ )
475
+ return TeaCore.from_map(
476
+ emr_serverless_spark_20230808_models.ListReleaseVersionsResponse(),
477
+ self.call_api(params, req, runtime)
478
+ )
479
+
480
+ async def list_release_versions_with_options_async(
481
+ self,
482
+ request: emr_serverless_spark_20230808_models.ListReleaseVersionsRequest,
483
+ headers: Dict[str, str],
484
+ runtime: util_models.RuntimeOptions,
485
+ ) -> emr_serverless_spark_20230808_models.ListReleaseVersionsResponse:
486
+ """
487
+ @summary 获取发布版本列表
488
+
489
+ @param request: ListReleaseVersionsRequest
490
+ @param headers: map
491
+ @param runtime: runtime options for this request RuntimeOptions
492
+ @return: ListReleaseVersionsResponse
493
+ """
494
+ UtilClient.validate_model(request)
495
+ query = {}
496
+ if not UtilClient.is_unset(request.region_id):
497
+ query['regionId'] = request.region_id
498
+ if not UtilClient.is_unset(request.release_type):
499
+ query['releaseType'] = request.release_type
500
+ if not UtilClient.is_unset(request.release_version):
501
+ query['releaseVersion'] = request.release_version
502
+ if not UtilClient.is_unset(request.release_version_status):
503
+ query['releaseVersionStatus'] = request.release_version_status
504
+ req = open_api_models.OpenApiRequest(
505
+ headers=headers,
506
+ query=OpenApiUtilClient.query(query)
507
+ )
508
+ params = open_api_models.Params(
509
+ action='ListReleaseVersions',
510
+ version='2023-08-08',
511
+ protocol='HTTPS',
512
+ pathname=f'/api/v1/releaseVersions',
513
+ method='GET',
514
+ auth_type='AK',
515
+ style='ROA',
516
+ req_body_type='json',
517
+ body_type='json'
518
+ )
519
+ return TeaCore.from_map(
520
+ emr_serverless_spark_20230808_models.ListReleaseVersionsResponse(),
521
+ await self.call_api_async(params, req, runtime)
522
+ )
523
+
524
+ def list_release_versions(
525
+ self,
526
+ request: emr_serverless_spark_20230808_models.ListReleaseVersionsRequest,
527
+ ) -> emr_serverless_spark_20230808_models.ListReleaseVersionsResponse:
528
+ """
529
+ @summary 获取发布版本列表
530
+
531
+ @param request: ListReleaseVersionsRequest
532
+ @return: ListReleaseVersionsResponse
533
+ """
534
+ runtime = util_models.RuntimeOptions()
535
+ headers = {}
536
+ return self.list_release_versions_with_options(request, headers, runtime)
537
+
538
+ async def list_release_versions_async(
539
+ self,
540
+ request: emr_serverless_spark_20230808_models.ListReleaseVersionsRequest,
541
+ ) -> emr_serverless_spark_20230808_models.ListReleaseVersionsResponse:
542
+ """
543
+ @summary 获取发布版本列表
544
+
545
+ @param request: ListReleaseVersionsRequest
546
+ @return: ListReleaseVersionsResponse
547
+ """
548
+ runtime = util_models.RuntimeOptions()
549
+ headers = {}
550
+ return await self.list_release_versions_with_options_async(request, headers, runtime)
551
+
552
+ def list_session_clusters_with_options(
553
+ self,
554
+ workspace_id: str,
555
+ request: emr_serverless_spark_20230808_models.ListSessionClustersRequest,
556
+ headers: Dict[str, str],
557
+ runtime: util_models.RuntimeOptions,
558
+ ) -> emr_serverless_spark_20230808_models.ListSessionClustersResponse:
559
+ """
560
+ @summary 查询run列表
561
+
562
+ @param request: ListSessionClustersRequest
563
+ @param headers: map
564
+ @param runtime: runtime options for this request RuntimeOptions
565
+ @return: ListSessionClustersResponse
566
+ """
567
+ UtilClient.validate_model(request)
568
+ query = {}
569
+ if not UtilClient.is_unset(request.max_results):
570
+ query['maxResults'] = request.max_results
571
+ if not UtilClient.is_unset(request.next_token):
572
+ query['nextToken'] = request.next_token
573
+ if not UtilClient.is_unset(request.queue_name):
574
+ query['queueName'] = request.queue_name
575
+ if not UtilClient.is_unset(request.region_id):
576
+ query['regionId'] = request.region_id
577
+ if not UtilClient.is_unset(request.session_cluster_id):
578
+ query['sessionClusterId'] = request.session_cluster_id
579
+ req = open_api_models.OpenApiRequest(
580
+ headers=headers,
581
+ query=OpenApiUtilClient.query(query)
582
+ )
583
+ params = open_api_models.Params(
584
+ action='ListSessionClusters',
585
+ version='2023-08-08',
586
+ protocol='HTTPS',
587
+ pathname=f'/api/v1/workspaces/{OpenApiUtilClient.get_encode_param(workspace_id)}/sessionClusters',
588
+ method='GET',
589
+ auth_type='AK',
590
+ style='ROA',
591
+ req_body_type='json',
592
+ body_type='json'
593
+ )
594
+ return TeaCore.from_map(
595
+ emr_serverless_spark_20230808_models.ListSessionClustersResponse(),
596
+ self.call_api(params, req, runtime)
597
+ )
598
+
599
+ async def list_session_clusters_with_options_async(
600
+ self,
601
+ workspace_id: str,
602
+ request: emr_serverless_spark_20230808_models.ListSessionClustersRequest,
603
+ headers: Dict[str, str],
604
+ runtime: util_models.RuntimeOptions,
605
+ ) -> emr_serverless_spark_20230808_models.ListSessionClustersResponse:
606
+ """
607
+ @summary 查询run列表
608
+
609
+ @param request: ListSessionClustersRequest
610
+ @param headers: map
611
+ @param runtime: runtime options for this request RuntimeOptions
612
+ @return: ListSessionClustersResponse
613
+ """
614
+ UtilClient.validate_model(request)
615
+ query = {}
616
+ if not UtilClient.is_unset(request.max_results):
617
+ query['maxResults'] = request.max_results
618
+ if not UtilClient.is_unset(request.next_token):
619
+ query['nextToken'] = request.next_token
620
+ if not UtilClient.is_unset(request.queue_name):
621
+ query['queueName'] = request.queue_name
622
+ if not UtilClient.is_unset(request.region_id):
623
+ query['regionId'] = request.region_id
624
+ if not UtilClient.is_unset(request.session_cluster_id):
625
+ query['sessionClusterId'] = request.session_cluster_id
626
+ req = open_api_models.OpenApiRequest(
627
+ headers=headers,
628
+ query=OpenApiUtilClient.query(query)
629
+ )
630
+ params = open_api_models.Params(
631
+ action='ListSessionClusters',
632
+ version='2023-08-08',
633
+ protocol='HTTPS',
634
+ pathname=f'/api/v1/workspaces/{OpenApiUtilClient.get_encode_param(workspace_id)}/sessionClusters',
635
+ method='GET',
636
+ auth_type='AK',
637
+ style='ROA',
638
+ req_body_type='json',
639
+ body_type='json'
640
+ )
641
+ return TeaCore.from_map(
642
+ emr_serverless_spark_20230808_models.ListSessionClustersResponse(),
643
+ await self.call_api_async(params, req, runtime)
644
+ )
645
+
646
+ def list_session_clusters(
647
+ self,
648
+ workspace_id: str,
649
+ request: emr_serverless_spark_20230808_models.ListSessionClustersRequest,
650
+ ) -> emr_serverless_spark_20230808_models.ListSessionClustersResponse:
651
+ """
652
+ @summary 查询run列表
653
+
654
+ @param request: ListSessionClustersRequest
655
+ @return: ListSessionClustersResponse
656
+ """
657
+ runtime = util_models.RuntimeOptions()
658
+ headers = {}
659
+ return self.list_session_clusters_with_options(workspace_id, request, headers, runtime)
660
+
661
+ async def list_session_clusters_async(
662
+ self,
663
+ workspace_id: str,
664
+ request: emr_serverless_spark_20230808_models.ListSessionClustersRequest,
665
+ ) -> emr_serverless_spark_20230808_models.ListSessionClustersResponse:
666
+ """
667
+ @summary 查询run列表
668
+
669
+ @param request: ListSessionClustersRequest
670
+ @return: ListSessionClustersResponse
671
+ """
672
+ runtime = util_models.RuntimeOptions()
673
+ headers = {}
674
+ return await self.list_session_clusters_with_options_async(workspace_id, request, headers, runtime)
675
+
676
+ def list_workspace_queues_with_options(
677
+ self,
678
+ workspace_id: str,
679
+ request: emr_serverless_spark_20230808_models.ListWorkspaceQueuesRequest,
680
+ headers: Dict[str, str],
681
+ runtime: util_models.RuntimeOptions,
682
+ ) -> emr_serverless_spark_20230808_models.ListWorkspaceQueuesResponse:
683
+ """
684
+ @summary 查看工作空间队列列表
685
+
686
+ @param request: ListWorkspaceQueuesRequest
687
+ @param headers: map
688
+ @param runtime: runtime options for this request RuntimeOptions
689
+ @return: ListWorkspaceQueuesResponse
690
+ """
691
+ UtilClient.validate_model(request)
692
+ query = {}
693
+ if not UtilClient.is_unset(request.environment):
694
+ query['environment'] = request.environment
695
+ if not UtilClient.is_unset(request.region_id):
696
+ query['regionId'] = request.region_id
697
+ req = open_api_models.OpenApiRequest(
698
+ headers=headers,
699
+ query=OpenApiUtilClient.query(query)
700
+ )
701
+ params = open_api_models.Params(
702
+ action='ListWorkspaceQueues',
703
+ version='2023-08-08',
704
+ protocol='HTTPS',
705
+ pathname=f'/api/v1/workspaces/{OpenApiUtilClient.get_encode_param(workspace_id)}/queues',
706
+ method='GET',
707
+ auth_type='AK',
708
+ style='ROA',
709
+ req_body_type='json',
710
+ body_type='json'
711
+ )
712
+ return TeaCore.from_map(
713
+ emr_serverless_spark_20230808_models.ListWorkspaceQueuesResponse(),
714
+ self.call_api(params, req, runtime)
715
+ )
716
+
717
+ async def list_workspace_queues_with_options_async(
718
+ self,
719
+ workspace_id: str,
720
+ request: emr_serverless_spark_20230808_models.ListWorkspaceQueuesRequest,
721
+ headers: Dict[str, str],
722
+ runtime: util_models.RuntimeOptions,
723
+ ) -> emr_serverless_spark_20230808_models.ListWorkspaceQueuesResponse:
724
+ """
725
+ @summary 查看工作空间队列列表
726
+
727
+ @param request: ListWorkspaceQueuesRequest
728
+ @param headers: map
729
+ @param runtime: runtime options for this request RuntimeOptions
730
+ @return: ListWorkspaceQueuesResponse
731
+ """
732
+ UtilClient.validate_model(request)
733
+ query = {}
734
+ if not UtilClient.is_unset(request.environment):
735
+ query['environment'] = request.environment
736
+ if not UtilClient.is_unset(request.region_id):
737
+ query['regionId'] = request.region_id
738
+ req = open_api_models.OpenApiRequest(
739
+ headers=headers,
740
+ query=OpenApiUtilClient.query(query)
741
+ )
742
+ params = open_api_models.Params(
743
+ action='ListWorkspaceQueues',
744
+ version='2023-08-08',
745
+ protocol='HTTPS',
746
+ pathname=f'/api/v1/workspaces/{OpenApiUtilClient.get_encode_param(workspace_id)}/queues',
747
+ method='GET',
748
+ auth_type='AK',
749
+ style='ROA',
750
+ req_body_type='json',
751
+ body_type='json'
752
+ )
753
+ return TeaCore.from_map(
754
+ emr_serverless_spark_20230808_models.ListWorkspaceQueuesResponse(),
755
+ await self.call_api_async(params, req, runtime)
756
+ )
757
+
758
+ def list_workspace_queues(
759
+ self,
760
+ workspace_id: str,
761
+ request: emr_serverless_spark_20230808_models.ListWorkspaceQueuesRequest,
762
+ ) -> emr_serverless_spark_20230808_models.ListWorkspaceQueuesResponse:
763
+ """
764
+ @summary 查看工作空间队列列表
765
+
766
+ @param request: ListWorkspaceQueuesRequest
767
+ @return: ListWorkspaceQueuesResponse
768
+ """
769
+ runtime = util_models.RuntimeOptions()
770
+ headers = {}
771
+ return self.list_workspace_queues_with_options(workspace_id, request, headers, runtime)
772
+
773
+ async def list_workspace_queues_async(
774
+ self,
775
+ workspace_id: str,
776
+ request: emr_serverless_spark_20230808_models.ListWorkspaceQueuesRequest,
777
+ ) -> emr_serverless_spark_20230808_models.ListWorkspaceQueuesResponse:
778
+ """
779
+ @summary 查看工作空间队列列表
780
+
781
+ @param request: ListWorkspaceQueuesRequest
782
+ @return: ListWorkspaceQueuesResponse
783
+ """
784
+ runtime = util_models.RuntimeOptions()
785
+ headers = {}
786
+ return await self.list_workspace_queues_with_options_async(workspace_id, request, headers, runtime)
787
+
788
+ def list_workspaces_with_options(
789
+ self,
790
+ request: emr_serverless_spark_20230808_models.ListWorkspacesRequest,
791
+ headers: Dict[str, str],
792
+ runtime: util_models.RuntimeOptions,
793
+ ) -> emr_serverless_spark_20230808_models.ListWorkspacesResponse:
794
+ """
795
+ @summary 查看工作空间列表
796
+
797
+ @param request: ListWorkspacesRequest
798
+ @param headers: map
799
+ @param runtime: runtime options for this request RuntimeOptions
800
+ @return: ListWorkspacesResponse
801
+ """
802
+ UtilClient.validate_model(request)
803
+ query = {}
804
+ if not UtilClient.is_unset(request.max_results):
805
+ query['maxResults'] = request.max_results
806
+ if not UtilClient.is_unset(request.name):
807
+ query['name'] = request.name
808
+ if not UtilClient.is_unset(request.next_token):
809
+ query['nextToken'] = request.next_token
810
+ if not UtilClient.is_unset(request.region_id):
811
+ query['regionId'] = request.region_id
812
+ if not UtilClient.is_unset(request.state):
813
+ query['state'] = request.state
814
+ req = open_api_models.OpenApiRequest(
815
+ headers=headers,
816
+ query=OpenApiUtilClient.query(query)
817
+ )
818
+ params = open_api_models.Params(
819
+ action='ListWorkspaces',
820
+ version='2023-08-08',
821
+ protocol='HTTPS',
822
+ pathname=f'/api/v1/workspaces',
823
+ method='GET',
824
+ auth_type='AK',
825
+ style='ROA',
826
+ req_body_type='json',
827
+ body_type='json'
828
+ )
829
+ return TeaCore.from_map(
830
+ emr_serverless_spark_20230808_models.ListWorkspacesResponse(),
831
+ self.call_api(params, req, runtime)
832
+ )
833
+
834
+ async def list_workspaces_with_options_async(
835
+ self,
836
+ request: emr_serverless_spark_20230808_models.ListWorkspacesRequest,
837
+ headers: Dict[str, str],
838
+ runtime: util_models.RuntimeOptions,
839
+ ) -> emr_serverless_spark_20230808_models.ListWorkspacesResponse:
840
+ """
841
+ @summary 查看工作空间列表
842
+
843
+ @param request: ListWorkspacesRequest
844
+ @param headers: map
845
+ @param runtime: runtime options for this request RuntimeOptions
846
+ @return: ListWorkspacesResponse
847
+ """
848
+ UtilClient.validate_model(request)
849
+ query = {}
850
+ if not UtilClient.is_unset(request.max_results):
851
+ query['maxResults'] = request.max_results
852
+ if not UtilClient.is_unset(request.name):
853
+ query['name'] = request.name
854
+ if not UtilClient.is_unset(request.next_token):
855
+ query['nextToken'] = request.next_token
856
+ if not UtilClient.is_unset(request.region_id):
857
+ query['regionId'] = request.region_id
858
+ if not UtilClient.is_unset(request.state):
859
+ query['state'] = request.state
860
+ req = open_api_models.OpenApiRequest(
861
+ headers=headers,
862
+ query=OpenApiUtilClient.query(query)
863
+ )
864
+ params = open_api_models.Params(
865
+ action='ListWorkspaces',
866
+ version='2023-08-08',
867
+ protocol='HTTPS',
868
+ pathname=f'/api/v1/workspaces',
869
+ method='GET',
870
+ auth_type='AK',
871
+ style='ROA',
872
+ req_body_type='json',
873
+ body_type='json'
874
+ )
875
+ return TeaCore.from_map(
876
+ emr_serverless_spark_20230808_models.ListWorkspacesResponse(),
877
+ await self.call_api_async(params, req, runtime)
878
+ )
879
+
880
+ def list_workspaces(
881
+ self,
882
+ request: emr_serverless_spark_20230808_models.ListWorkspacesRequest,
883
+ ) -> emr_serverless_spark_20230808_models.ListWorkspacesResponse:
884
+ """
885
+ @summary 查看工作空间列表
886
+
887
+ @param request: ListWorkspacesRequest
888
+ @return: ListWorkspacesResponse
889
+ """
890
+ runtime = util_models.RuntimeOptions()
891
+ headers = {}
892
+ return self.list_workspaces_with_options(request, headers, runtime)
893
+
894
+ async def list_workspaces_async(
895
+ self,
896
+ request: emr_serverless_spark_20230808_models.ListWorkspacesRequest,
897
+ ) -> emr_serverless_spark_20230808_models.ListWorkspacesResponse:
898
+ """
899
+ @summary 查看工作空间列表
900
+
901
+ @param request: ListWorkspacesRequest
902
+ @return: ListWorkspacesResponse
903
+ """
904
+ runtime = util_models.RuntimeOptions()
905
+ headers = {}
906
+ return await self.list_workspaces_with_options_async(request, headers, runtime)
907
+
436
908
  def start_job_run_with_options(
437
909
  self,
438
910
  workspace_id: str,