fractal-server 2.10.4__py3-none-any.whl → 2.10.6__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.
@@ -1 +1 @@
1
- __VERSION__ = "2.10.4"
1
+ __VERSION__ = "2.10.6"
@@ -254,10 +254,15 @@ class UserManager(IntegerIDMixin, BaseUserManager[UserOAuth, int]):
254
254
 
255
255
  if this_user.oauth_accounts and settings.MAIL_SETTINGS is not None:
256
256
  try:
257
+ logger.info(
258
+ "START sending email about new signup to "
259
+ f"{settings.MAIL_SETTINGS.recipients}."
260
+ )
257
261
  mail_new_oauth_signup(
258
262
  msg=f"New user registered: '{this_user.email}'.",
259
263
  mail_settings=settings.MAIL_SETTINGS,
260
264
  )
265
+ logger.info("END sending email about new signup.")
261
266
  except Exception as e:
262
267
  logger.error(
263
268
  "ERROR sending notification email after oauth "
@@ -13,7 +13,7 @@ def mail_new_oauth_signup(msg: str, mail_settings: MailSettings):
13
13
  mail_msg = EmailMessage()
14
14
  mail_msg.set_content(msg)
15
15
  mail_msg["From"] = formataddr((mail_settings.sender, mail_settings.sender))
16
- mail_msg["To"] = ",".join(
16
+ mail_msg["To"] = ", ".join(
17
17
  [
18
18
  formataddr((recipient, recipient))
19
19
  for recipient in mail_settings.recipients
fractal_server/logger.py CHANGED
@@ -109,7 +109,10 @@ def set_logger(
109
109
  if isinstance(handler, logging.FileHandler)
110
110
  ]
111
111
  if len(current_file_handlers) > 1:
112
- logger.warning(f"Logger {logger_name} has multiple file handlers.")
112
+ logger.warning(
113
+ f"Logger {logger_name} has multiple file handlers: "
114
+ f"{current_file_handlers}"
115
+ )
113
116
 
114
117
  return logger
115
118
 
@@ -33,8 +33,6 @@ from fractal_server.tasks.v2.utils_templates import (
33
33
  from fractal_server.tasks.v2.utils_templates import SCRIPTS_SUBFOLDER
34
34
  from fractal_server.utils import get_timestamp
35
35
 
36
- LOGGER_NAME = __name__
37
-
38
36
 
39
37
  def collect_local(
40
38
  *,
@@ -59,6 +57,8 @@ def collect_local(
59
57
  wheel_file:
60
58
  """
61
59
 
60
+ LOGGER_NAME = f"{__name__}.ID{task_group_activity_id}"
61
+
62
62
  with TemporaryDirectory() as tmpdir:
63
63
  log_file_path = get_log_path(Path(tmpdir))
64
64
  logger = set_logger(
@@ -21,8 +21,6 @@ from fractal_server.tasks.v2.utils_background import get_current_log
21
21
  from fractal_server.tasks.v2.utils_templates import SCRIPTS_SUBFOLDER
22
22
  from fractal_server.utils import get_timestamp
23
23
 
24
- LOGGER_NAME = __name__
25
-
26
24
 
27
25
  def deactivate_local(
28
26
  *,
@@ -40,6 +38,8 @@ def deactivate_local(
40
38
  task_group_activity_id:
41
39
  """
42
40
 
41
+ LOGGER_NAME = f"{__name__}.ID{task_group_activity_id}"
42
+
43
43
  with TemporaryDirectory() as tmpdir:
44
44
  log_file_path = get_log_path(Path(tmpdir))
45
45
  logger = set_logger(
@@ -23,9 +23,6 @@ from fractal_server.tasks.v2.utils_templates import SCRIPTS_SUBFOLDER
23
23
  from fractal_server.utils import get_timestamp
24
24
 
25
25
 
26
- LOGGER_NAME = __name__
27
-
28
-
29
26
  def reactivate_local(
30
27
  *,
31
28
  task_group_activity_id: int,
@@ -42,6 +39,8 @@ def reactivate_local(
42
39
  task_group_activity_id:
43
40
  """
44
41
 
42
+ LOGGER_NAME = f"{__name__}.ID{task_group_activity_id}"
43
+
45
44
  with TemporaryDirectory() as tmpdir:
46
45
  log_file_path = get_log_path(Path(tmpdir))
47
46
  logger = set_logger(
@@ -30,8 +30,6 @@ from fractal_server.tasks.v2.utils_templates import (
30
30
  from fractal_server.tasks.v2.utils_templates import SCRIPTS_SUBFOLDER
31
31
  from fractal_server.utils import get_timestamp
32
32
 
33
- LOGGER_NAME = __name__
34
-
35
33
 
36
34
  def collect_ssh(
37
35
  *,
@@ -62,6 +60,8 @@ def collect_ssh(
62
60
  wheel_file:
63
61
  """
64
62
 
63
+ LOGGER_NAME = f"{__name__}.ID{task_group_activity_id}"
64
+
65
65
  # Work within a temporary folder, where also logs will be placed
66
66
  with TemporaryDirectory() as tmpdir:
67
67
  LOGGER_NAME = "task_collection_ssh"
@@ -22,8 +22,6 @@ from fractal_server.tasks.v2.utils_background import get_current_log
22
22
  from fractal_server.tasks.v2.utils_templates import SCRIPTS_SUBFOLDER
23
23
  from fractal_server.utils import get_timestamp
24
24
 
25
- LOGGER_NAME = __name__
26
-
27
25
 
28
26
  def deactivate_ssh(
29
27
  *,
@@ -47,6 +45,8 @@ def deactivate_ssh(
47
45
  `user_settings.ssh_tasks_dir`.
48
46
  """
49
47
 
48
+ LOGGER_NAME = f"{__name__}.ID{task_group_activity_id}"
49
+
50
50
  with TemporaryDirectory() as tmpdir:
51
51
  log_file_path = get_log_path(Path(tmpdir))
52
52
  logger = set_logger(
@@ -22,8 +22,6 @@ from fractal_server.tasks.v2.utils_python_interpreter import (
22
22
  from fractal_server.tasks.v2.utils_templates import SCRIPTS_SUBFOLDER
23
23
  from fractal_server.utils import get_timestamp
24
24
 
25
- LOGGER_NAME = __name__
26
-
27
25
 
28
26
  def reactivate_ssh(
29
27
  *,
@@ -47,6 +45,8 @@ def reactivate_ssh(
47
45
  `user_settings.ssh_tasks_dir`.
48
46
  """
49
47
 
48
+ LOGGER_NAME = f"{__name__}.ID{task_group_activity_id}"
49
+
50
50
  with TemporaryDirectory() as tmpdir:
51
51
  log_file_path = get_log_path(Path(tmpdir))
52
52
  logger = set_logger(
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.3
2
2
  Name: fractal-server
3
- Version: 2.10.4
3
+ Version: 2.10.6
4
4
  Summary: Backend component of the Fractal analytics platform
5
5
  Home-page: https://github.com/fractal-analytics-platform/fractal-server
6
6
  License: BSD-3-Clause
@@ -1,4 +1,4 @@
1
- fractal_server/__init__.py,sha256=SpR6dFPN1o2qOtKLrw5k3LkAdAJmWRd66Z2nXQfCN_4,23
1
+ fractal_server/__init__.py,sha256=a7_sazZoCnsqPILpPj1L3cASrJQAtTkPgpVlFA0CJpY,23
2
2
  fractal_server/__main__.py,sha256=D2YTmSowmXNyvqOjW_HeItCZT2UliWlySl_owicaZg0,8026
3
3
  fractal_server/alembic.ini,sha256=MWwi7GzjzawI9cCAK1LW7NxIBQDUqD12-ptJoq5JpP0,3153
4
4
  fractal_server/app/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
@@ -160,8 +160,8 @@ fractal_server/app/schemas/v2/task_collection.py,sha256=9c_yyFcVBXdAZpQQniy1bROh
160
160
  fractal_server/app/schemas/v2/task_group.py,sha256=EPQ1WHjIA8WDrpsTfvfRESjwUVzu6jKiaKZx45b36N4,3215
161
161
  fractal_server/app/schemas/v2/workflow.py,sha256=-KWvXnbHBFA3pj5n7mfSyLKJQSqkJmoziIEe7mpLl3M,1875
162
162
  fractal_server/app/schemas/v2/workflowtask.py,sha256=FthKErVgx3a-k7WVk3nqJe1G-fl_iHND4rVrDXJ0F84,5942
163
- fractal_server/app/security/__init__.py,sha256=UmFnFFGM9WB_7b0itBi0b9uOIUWx_tcA2rCRaTNXErU,13778
164
- fractal_server/app/security/signup_email.py,sha256=hzzHxoEizl6IPVeB0j9Ek_tKIalGRxH6npzWUyGkCc4,1164
163
+ fractal_server/app/security/__init__.py,sha256=qn6idYgl-p5HWea0gTVnz4JnkoxGEkmQjPzvKpDWT0I,14035
164
+ fractal_server/app/security/signup_email.py,sha256=DrL51UdTSrgjleynMD5CRZwTSOpPrZ96fasRV0fvxDE,1165
165
165
  fractal_server/app/user_settings.py,sha256=OP1yiYKtPadxwM51_Q0hdPk3z90TCN4z1BLpQsXyWiU,1316
166
166
  fractal_server/config.py,sha256=9rAzw7OO6ZeHEz-I8NJHuGoHf4xCHxfFLyRNZQD9ytY,27019
167
167
  fractal_server/data_migrations/README.md,sha256=_3AEFvDg9YkybDqCLlFPdDmGJvr6Tw7HRI14aZ3LOIw,398
@@ -170,7 +170,7 @@ fractal_server/gunicorn_fractal.py,sha256=u6U01TLGlXgq1v8QmEpLih3QnsInZD7CqphgJ_
170
170
  fractal_server/images/__init__.py,sha256=xO6jTLE4EZKO6cTDdJsBmK9cdeh9hFTaSbSuWgQg7y4,196
171
171
  fractal_server/images/models.py,sha256=UlWazUOFQtpS3pZuROjcJXviG_Ai453jqUDHdzuvD5w,4170
172
172
  fractal_server/images/tools.py,sha256=gxeniYy4Z-cp_ToK2LHPJUTVVUUrdpogYdcBUvBuLiY,2209
173
- fractal_server/logger.py,sha256=zwg_AjIHkNP0ruciXjm5lI5UFP3n6tMHullsM9lDjz4,5039
173
+ fractal_server/logger.py,sha256=5Z3rfsFwl8UysVljTOaaIvt8Pyp6CVH492ez3jE8WAw,5113
174
174
  fractal_server/main.py,sha256=gStLT9Du5QMpc9SyvRvtKU21EKwp-dG4HL3zGHzE06A,4908
175
175
  fractal_server/migrations/env.py,sha256=9t_OeKVlhM8WRcukmTrLbWNup-imiBGP_9xNgwCbtpI,2730
176
176
  fractal_server/migrations/naming_convention.py,sha256=htbKrVdetx3pklowb_9Cdo5RqeF0fJ740DNecY5de_M,265
@@ -216,14 +216,14 @@ fractal_server/tasks/v1/utils.py,sha256=HYFyNAyZofmf--mVgdwGC5TJpGShIWIDaS01yRr4
216
216
  fractal_server/tasks/v2/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
217
217
  fractal_server/tasks/v2/local/__init__.py,sha256=9RVItnS7OyLsJOuJjWMCicaky4ASUPQEYD4SzDs0hOE,141
218
218
  fractal_server/tasks/v2/local/_utils.py,sha256=EvhmVwYjqaNyDCUMEsTWYOUXLgEwR1xr6bu32apCEI8,2491
219
- fractal_server/tasks/v2/local/collect.py,sha256=JuMplfREqrPvVEGlT5kJhcmZXC_iYlwvNlkgFrCaCC0,12107
220
- fractal_server/tasks/v2/local/deactivate.py,sha256=SOFtOaR5yYm3IkbOw48TrQgzEpONQ9647KvyD_zImr8,9899
221
- fractal_server/tasks/v2/local/reactivate.py,sha256=MeUZHx8IKrfTEf-pXlfYms8I4o-26co3jdNgSNAvw60,6053
219
+ fractal_server/tasks/v2/local/collect.py,sha256=Mr4BzscBY8zBRCzWq8ozTjFYy1-VFPXrMCBF7vd9Ods,12143
220
+ fractal_server/tasks/v2/local/deactivate.py,sha256=uAV-tBgfKiN4chkfk6dYCZfF67POwhNizyxuCk_WJK8,9935
221
+ fractal_server/tasks/v2/local/reactivate.py,sha256=DwtOZrSk6jhUHEmAiMcstK3YzqPQ12pfgxmUNdrSgfk,6088
222
222
  fractal_server/tasks/v2/ssh/__init__.py,sha256=aSQbVi6Ummt9QzcSLWNmSqYjfdxrn9ROmqgH6bDpI7k,135
223
223
  fractal_server/tasks/v2/ssh/_utils.py,sha256=LjaEYVUJDChilu3YuhxuGWYRNnVJ_zqNE9SDHdRTIHY,2824
224
- fractal_server/tasks/v2/ssh/collect.py,sha256=2XXEPpl4LS22A75v_k4Bd46k46tmnLNZfceHyPi3kXo,13457
225
- fractal_server/tasks/v2/ssh/deactivate.py,sha256=D8rfnC46davmDKZCipPdWZHDD4TIZ-4nr9vxZSV2aC0,11261
226
- fractal_server/tasks/v2/ssh/reactivate.py,sha256=cmdT2P1J0FwS1NYYRrhxHsSRyUZ5uu78hS3fDrSVbKo,7837
224
+ fractal_server/tasks/v2/ssh/collect.py,sha256=yLVcilvU7uMH8woc__qG_3a0wyT2mNTCuq9I93HVKNM,13493
225
+ fractal_server/tasks/v2/ssh/deactivate.py,sha256=bFlcpZpGiTZcwG845YiLEIIYpiG7vslcSp6_NkXtHGw,11297
226
+ fractal_server/tasks/v2/ssh/reactivate.py,sha256=RoXM5HpIc0rVz4-8UCr3uWv-9zA8bobGSTNJamYsMOo,7873
227
227
  fractal_server/tasks/v2/templates/1_create_venv.sh,sha256=PK0jdHKtQpda1zULebBaVPORt4t6V17wa4N1ohcj5ac,548
228
228
  fractal_server/tasks/v2/templates/2_pip_install.sh,sha256=Gpk2io8u9YaflFUlQu2NgkDQw5AA4m4AOVG1sB4yrHQ,1822
229
229
  fractal_server/tasks/v2/templates/3_pip_freeze.sh,sha256=JldREScEBI4cD_qjfX4UK7V4aI-FnX9ZvVNxgpSOBFc,168
@@ -238,8 +238,8 @@ fractal_server/tasks/v2/utils_templates.py,sha256=07TZpJ0Mh_A4lXVXrrH2o1VLFFGwxe
238
238
  fractal_server/urls.py,sha256=QjIKAC1a46bCdiPMu3AlpgFbcv6a4l3ABcd5xz190Og,471
239
239
  fractal_server/utils.py,sha256=utvmBx8K9I8hRWFquxna2pBaOqe0JifDL_NVPmihEJI,3525
240
240
  fractal_server/zip_tools.py,sha256=GjDgo_sf6V_DDg6wWeBlZu5zypIxycn_l257p_YVKGc,4876
241
- fractal_server-2.10.4.dist-info/LICENSE,sha256=QKAharUuhxL58kSoLizKJeZE3mTCBnX6ucmz8W0lxlk,1576
242
- fractal_server-2.10.4.dist-info/METADATA,sha256=oEdEOyPOLPqYkCxgyXF1S_RKX5k4PGQWC7ZpwBmikU0,4562
243
- fractal_server-2.10.4.dist-info/WHEEL,sha256=RaoafKOydTQ7I_I3JTrPCg6kUmTgtm4BornzOqyEfJ8,88
244
- fractal_server-2.10.4.dist-info/entry_points.txt,sha256=8tV2kynvFkjnhbtDnxAqImL6HMVKsopgGfew0DOp5UY,58
245
- fractal_server-2.10.4.dist-info/RECORD,,
241
+ fractal_server-2.10.6.dist-info/LICENSE,sha256=QKAharUuhxL58kSoLizKJeZE3mTCBnX6ucmz8W0lxlk,1576
242
+ fractal_server-2.10.6.dist-info/METADATA,sha256=51h1I8zU4HexWwOkqbObhEXf6pFk7mqi0ET7uUUxW2g,4562
243
+ fractal_server-2.10.6.dist-info/WHEEL,sha256=RaoafKOydTQ7I_I3JTrPCg6kUmTgtm4BornzOqyEfJ8,88
244
+ fractal_server-2.10.6.dist-info/entry_points.txt,sha256=8tV2kynvFkjnhbtDnxAqImL6HMVKsopgGfew0DOp5UY,58
245
+ fractal_server-2.10.6.dist-info/RECORD,,