spaceforge 0.0.14__py3-none-any.whl → 0.0.17__py3-none-any.whl

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.
@@ -28,7 +28,7 @@ version_tuple: VERSION_TUPLE
28
28
  commit_id: COMMIT_ID
29
29
  __commit_id__: COMMIT_ID
30
30
 
31
- __version__ = version = '0.0.14'
32
- __version_tuple__ = version_tuple = (0, 0, 14)
31
+ __version__ = version = '0.0.17'
32
+ __version_tuple__ = version_tuple = (0, 0, 17)
33
33
 
34
34
  __commit_id__ = commit_id = None
spaceforge/plugin.py CHANGED
@@ -35,19 +35,22 @@ class SpaceforgePlugin(ABC):
35
35
  self._run_id = os.environ.get("TF_VAR_spacelift_run_id", "local")
36
36
  self._is_local = self._run_id == "local"
37
37
  self.logger = self._setup_logger()
38
+ self.spacelift_domain = os.environ.get(
39
+ "TF_VAR_spacelift_graphql_endpoint", ""
40
+ ).replace("/graphql", "")
38
41
 
39
42
  self._api_token = os.environ.get("SPACELIFT_API_TOKEN") or False
40
- self.spacelift_domain = (
43
+ self._api_endpoint = (
41
44
  os.environ.get("TF_VAR_spacelift_graphql_endpoint") or False
42
45
  )
43
- self._api_enabled = bool(self._api_token and self.spacelift_domain)
46
+ self._api_enabled = bool(self._api_token and self._api_endpoint)
44
47
  self._workspace_root = os.getcwd()
45
48
  self._spacelift_markdown_endpoint = None
46
49
  self._markdown_endpoint_token = os.environ.get("SPACELIFT_API_TOKEN") or False
47
50
 
48
51
  # This should be the last thing we do in the constructor
49
52
  # because we set api_enabled to false if the domain is set up incorrectly.
50
- if self.spacelift_domain and isinstance(self.spacelift_domain, str):
53
+ if self._api_endpoint and isinstance(self._api_endpoint, str):
51
54
  # this must occur after we check if spacelift domain is false
52
55
  # because the domain could be set but not start with https://
53
56
  # if self.spacelift_domain.startswith("https://"):
@@ -60,7 +63,7 @@ class SpaceforgePlugin(ABC):
60
63
  # self._api_enabled = False
61
64
 
62
65
  if self._api_enabled:
63
- self._spacelift_markdown_endpoint = self.spacelift_domain.replace(
66
+ self._spacelift_markdown_endpoint = self._api_endpoint.replace(
64
67
  "/graphql", "/worker/plugin_logs_url"
65
68
  )
66
69
 
@@ -111,10 +114,7 @@ class SpaceforgePlugin(ABC):
111
114
  return logger
112
115
 
113
116
  def use_user_token(self, id: str, token: str) -> None:
114
- headers = {
115
- "Content-Type": "application/json",
116
- "Authorization": f"Bearer {self._api_token}",
117
- }
117
+ headers = {"Content-Type": "application/json"}
118
118
 
119
119
  query = """
120
120
  mutation requestApiKey($id: ID!, $secret: String!){
@@ -130,12 +130,12 @@ class SpaceforgePlugin(ABC):
130
130
  }
131
131
 
132
132
  req = urllib.request.Request(
133
- self.spacelift_domain, # type: ignore[arg-type]
133
+ self._api_endpoint, # type: ignore[arg-type]
134
134
  json.dumps(data).encode("utf-8"),
135
135
  headers,
136
136
  )
137
137
 
138
- self.logger.debug(f"Sending request to url: {self.spacelift_domain}")
138
+ self.logger.debug(f"Sending request to url: {self._api_endpoint}")
139
139
  try:
140
140
  with urllib.request.urlopen(req) as response:
141
141
  resp: Dict[str, Any] = json.loads(response.read().decode("utf-8"))
@@ -252,12 +252,12 @@ class SpaceforgePlugin(ABC):
252
252
  data["variables"] = variables
253
253
 
254
254
  req = urllib.request.Request(
255
- self.spacelift_domain, # type: ignore[arg-type]
255
+ self._api_endpoint, # type: ignore[arg-type]
256
256
  json.dumps(data).encode("utf-8"),
257
257
  headers,
258
258
  )
259
259
 
260
- self.logger.debug(f"Sending request to url: {self.spacelift_domain}")
260
+ self.logger.debug(f"Sending request to url: {self._api_endpoint}")
261
261
  try:
262
262
  with urllib.request.urlopen(req) as response:
263
263
  resp: Dict[str, Any] = json.loads(response.read().decode("utf-8"))
spaceforge/test_plugin.py CHANGED
@@ -21,7 +21,7 @@
21
21
  #
22
22
  # # Assert
23
23
  # assert plugin._api_token is False
24
- # assert plugin.spacelift_domain is False
24
+ # assert plugin._api_endpoint is False
25
25
  # assert plugin._api_enabled is False
26
26
  # assert plugin._workspace_root == os.getcwd()
27
27
  # assert isinstance(plugin.logger, logging.Logger)
@@ -36,7 +36,7 @@
36
36
  #
37
37
  # # Assert
38
38
  # assert plugin._api_token == "test_token"
39
- # assert plugin.spacelift_domain == "https://test.spacelift.io"
39
+ # assert plugin._api_endpoint == "https://test.spacelift.io"
40
40
  # assert plugin._api_enabled is True
41
41
  # assert plugin._workspace_root == os.getcwd()
42
42
  #
@@ -53,7 +53,7 @@
53
53
  # plugin = SpaceforgePlugin()
54
54
  #
55
55
  # # Assert
56
- # assert plugin.spacelift_domain == "https://test.spacelift.io"
56
+ # assert plugin._api_endpoint == "https://test.spacelift.io"
57
57
  # assert plugin._api_enabled is True
58
58
  #
59
59
  # def test_should_disable_api_when_domain_has_no_https_prefix(self) -> None:
@@ -69,7 +69,7 @@
69
69
  # plugin = SpaceforgePlugin()
70
70
  #
71
71
  # # Assert
72
- # assert plugin.spacelift_domain == "test.spacelift.io"
72
+ # assert plugin._api_endpoint == "test.spacelift.io"
73
73
  # assert plugin._api_enabled is False
74
74
  #
75
75
  # def test_should_disable_api_when_only_token_provided(self) -> None:
@@ -271,7 +271,7 @@
271
271
  # plugin = SpaceforgePlugin()
272
272
  # plugin._api_enabled = True
273
273
  # plugin._api_token = "test_token"
274
- # plugin.spacelift_domain = "https://test.spacelift.io"
274
+ # plugin._api_endpoint = "https://test.spacelift.io"
275
275
  #
276
276
  # expected_data = {"data": {"test": "result"}}
277
277
  # mock_api_response.read.return_value = json.dumps(expected_data).encode("utf-8")
@@ -305,7 +305,7 @@
305
305
  # plugin = SpaceforgePlugin()
306
306
  # plugin._api_enabled = True
307
307
  # plugin._api_token = "test_token"
308
- # plugin.spacelift_domain = "https://test.spacelift.io"
308
+ # plugin._api_endpoint = "https://test.spacelift.io"
309
309
  #
310
310
  # mock_response_data = {"data": {"test": "result"}}
311
311
  # mock_response = Mock()
@@ -331,7 +331,7 @@
331
331
  # plugin = SpaceforgePlugin()
332
332
  # plugin._api_enabled = True
333
333
  # plugin._api_token = "test_token"
334
- # plugin.spacelift_domain = "https://test.spacelift.io"
334
+ # plugin._api_endpoint = "https://test.spacelift.io"
335
335
  #
336
336
  # mock_response_data = {"errors": [{"message": "Test error"}]}
337
337
  # mock_response = Mock()
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: spaceforge
3
- Version: 0.0.14
3
+ Version: 0.0.17
4
4
  Summary: A Python framework for building Spacelift plugins
5
5
  Home-page: https://github.com/spacelift-io/plugins
6
6
  Author: Spacelift
@@ -2,11 +2,11 @@ spaceforge/README.md,sha256=8o1Nuyasb4OxX3E7ZycyducOrR4J19bZcHrLvFeoFNg,7730
2
2
  spaceforge/__init__.py,sha256=TU-vvm15dK1ucixNW0V42eTT72x3_hmKSyxP4MC1Occ,589
3
3
  spaceforge/__main__.py,sha256=c3nAw4WBnHXIcfMlRV6Ja7r87pEhSeK-SAqiSYIasIY,643
4
4
  spaceforge/_version.py,sha256=RP_LfUd4ODnrfwn9nam8wB6bR3lM4VwmoRxK08Tkiiw,2155
5
- spaceforge/_version_scm.py,sha256=YDX9ERYoOeE60PulkdUCy2JxmS89Xb_igX2wwbidLMQ,706
5
+ spaceforge/_version_scm.py,sha256=S11KPmKYJXKQX0D8GWJ9ou0JkWsMIQoAxzWzBzTnRp4,706
6
6
  spaceforge/cls.py,sha256=8jZ0noS-kIBQWHp7pWHOX6yzs5N30gIEm6-slWgBaKI,6182
7
7
  spaceforge/conftest.py,sha256=U-xCavCsgRAQXqflIIOMeq9pcGbeqRviUNkEXgZol8g,2141
8
8
  spaceforge/generator.py,sha256=7tt0zpqrD2pZsoVxQa0BfzBH1ZtGr6o3r_LmpBjrOJk,16739
9
- spaceforge/plugin.py,sha256=fuATKzkkev2hNKWpQYMwJs1ZHgYKxEXGdlqHQ_wmpZ4,16057
9
+ spaceforge/plugin.py,sha256=CdpdmFQ6sXPE86dqDnPpHsjRZd0ZQBqE9rp5NxmHfD8,16083
10
10
  spaceforge/runner.py,sha256=aBQQLG8MFVrqCzM0X8HgERYbhLKbmlOHUPKjV7-xvpA,3163
11
11
  spaceforge/schema.json,sha256=F0STokM3YYT0xzcNdtnELZJJgpyi49mwk9Oj8ueD39s,10631
12
12
  spaceforge/test_cls.py,sha256=nXAgbnFnGdFxrtA7vNXiePjNUASuoYW-lEuQGx9WMGs,468
@@ -15,7 +15,7 @@ spaceforge/test_generator_binaries.py,sha256=X_7pPLGE45eQt-Kv9_ku__LsyLgOvViHc_B
15
15
  spaceforge/test_generator_core.py,sha256=gOqRx0rnME-srGMHun4KidXMN-iaqfKKTyoQ0Tw6b9Q,6253
16
16
  spaceforge/test_generator_hooks.py,sha256=2lJs8dYlFb7QehWcYF0O4qg38s5UudEpzJyBi1XiS3k,2542
17
17
  spaceforge/test_generator_parameters.py,sha256=77az9rcocFny2AC4O2eTzjCW712fR1DBHzGrgBKeR4w,1878
18
- spaceforge/test_plugin.py,sha256=Ufr9I9hz3hR9ATnOrkbH7Ouev9cDcdrw2iQJG5l2T2A,13676
18
+ spaceforge/test_plugin.py,sha256=jp3Nmq-DgYDMlQrell3nInEsp4xQ5NP6R0THqcPX6kM,13655
19
19
  spaceforge/test_plugin_file_operations.py,sha256=B0qvIo5EcfKMiHLhBv-hAnpSonn83ojcmJHXasydojA,3782
20
20
  spaceforge/test_plugin_hooks.py,sha256=rNCZZyd_SDMkm1x3yl5mjQ5tBMGm3YNd1U6h_niWRQs,2962
21
21
  spaceforge/test_plugin_inheritance.py,sha256=WHfvU5s-2GtfcI9-1bHXH7bacr77ikq68V3Z3BBQKvQ,3617
@@ -25,9 +25,9 @@ spaceforge/test_runner_core.py,sha256=eNR9YOwJwv7LsMtNQ4WXXMPIW6RE_A7hUp4bCpzz1R
25
25
  spaceforge/test_runner_execution.py,sha256=BRlOApCmlpjE9YYvqHc8creSRu2vyPubzOCVXv-on0w,5335
26
26
  spaceforge/templates/binary_install.sh.j2,sha256=UjP_kAdvkkATKds2nqk4ouqLhuIfCgM_x0WQIl1hbIo,477
27
27
  spaceforge/templates/ensure_spaceforge_and_run.sh.j2,sha256=g5BldIEve0IkZ-mCzTXfB_rFvyWqUJqymRRaaMrpp0s,550
28
- spaceforge-0.0.14.dist-info/licenses/LICENSE,sha256=wyljRrfnWY2ggQKkSCg3Nw2hxwPMmupopaKs9Kpgys8,1065
29
- spaceforge-0.0.14.dist-info/METADATA,sha256=zT9cFLQOwMjkHyrXeUDN4a0Pm_elJI2dpMhrvWetjZc,16804
30
- spaceforge-0.0.14.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
31
- spaceforge-0.0.14.dist-info/entry_points.txt,sha256=qawuuKBSNTGg-njnQnhxxFldFvXYAPej6bF_f3iyQ48,56
32
- spaceforge-0.0.14.dist-info/top_level.txt,sha256=eVw-Lw4Th0oHM8Gx1Y8YetyNgbNbMBU00yWs-kwGeSs,11
33
- spaceforge-0.0.14.dist-info/RECORD,,
28
+ spaceforge-0.0.17.dist-info/licenses/LICENSE,sha256=wyljRrfnWY2ggQKkSCg3Nw2hxwPMmupopaKs9Kpgys8,1065
29
+ spaceforge-0.0.17.dist-info/METADATA,sha256=wx9eANlUUju04Vx4qnEFSdaVruUvr2qOdeq0Nqq6edk,16804
30
+ spaceforge-0.0.17.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
31
+ spaceforge-0.0.17.dist-info/entry_points.txt,sha256=qawuuKBSNTGg-njnQnhxxFldFvXYAPej6bF_f3iyQ48,56
32
+ spaceforge-0.0.17.dist-info/top_level.txt,sha256=eVw-Lw4Th0oHM8Gx1Y8YetyNgbNbMBU00yWs-kwGeSs,11
33
+ spaceforge-0.0.17.dist-info/RECORD,,