forked from github/plane
Merge branch 'chore/api_endpoints' of github.com:makeplane/plane into chore/api_endpoints
This commit is contained in:
commit
a85e5df592
@ -27,8 +27,8 @@ class GPTIntegrationEndpoint(BaseAPIView):
|
|||||||
|
|
||||||
# Get the configuration value
|
# Get the configuration value
|
||||||
instance_configuration = InstanceConfiguration.objects.values("key", "value")
|
instance_configuration = InstanceConfiguration.objects.values("key", "value")
|
||||||
api_key = get_configuration_value(instance_configuration, "OPENAI_API_KEY")
|
api_key = get_configuration_value(instance_configuration, "OPENAI_API_KEY", os.environ.get("OPENAI_API_KEY"))
|
||||||
gpt_engine = get_configuration_value(instance_configuration, "GPT_ENGINE")
|
gpt_engine = get_configuration_value(instance_configuration, "GPT_ENGINE", os.environ.get("GPT_ENGINE", "gpt-3.5-turbo"))
|
||||||
|
|
||||||
# Check the keys
|
# Check the keys
|
||||||
if not api_key or not gpt_engine:
|
if not api_key or not gpt_engine:
|
||||||
@ -47,10 +47,6 @@ class GPTIntegrationEndpoint(BaseAPIView):
|
|||||||
|
|
||||||
final_text = task + "\n" + prompt
|
final_text = task + "\n" + prompt
|
||||||
|
|
||||||
instance_configuration = InstanceConfiguration.objects.values("key", "value")
|
|
||||||
|
|
||||||
gpt_engine = get_configuration_value(instance_configuration, "GPT_ENGINE")
|
|
||||||
|
|
||||||
client = OpenAI(
|
client = OpenAI(
|
||||||
api_key=api_key,
|
api_key=api_key,
|
||||||
)
|
)
|
||||||
|
@ -388,7 +388,7 @@ class ProjectInvitationsViewset(BaseViewSet):
|
|||||||
{"error": "You cannot invite a user with higher role"},
|
{"error": "You cannot invite a user with higher role"},
|
||||||
status=status.HTTP_400_BAD_REQUEST,
|
status=status.HTTP_400_BAD_REQUEST,
|
||||||
)
|
)
|
||||||
|
|
||||||
workspace = Workspace.objects.get(slug=slug)
|
workspace = Workspace.objects.get(slug=slug)
|
||||||
|
|
||||||
project_invitations = []
|
project_invitations = []
|
||||||
@ -424,7 +424,7 @@ class ProjectInvitationsViewset(BaseViewSet):
|
|||||||
project_invitations = ProjectMemberInvite.objects.bulk_create(
|
project_invitations = ProjectMemberInvite.objects.bulk_create(
|
||||||
project_invitations, batch_size=10, ignore_conflicts=True
|
project_invitations, batch_size=10, ignore_conflicts=True
|
||||||
)
|
)
|
||||||
current_site = request.META.get('HTTP_ORIGIN')
|
current_site = request.META.get("HTTP_ORIGIN")
|
||||||
|
|
||||||
# Send invitations
|
# Send invitations
|
||||||
for invitation in project_invitations:
|
for invitation in project_invitations:
|
||||||
@ -469,6 +469,13 @@ class UserProjectInvitationsViewset(BaseViewSet):
|
|||||||
workspace_role = workspace_member.role
|
workspace_role = workspace_member.role
|
||||||
workspace = workspace_member.workspace
|
workspace = workspace_member.workspace
|
||||||
|
|
||||||
|
# If the user was already part of workspace
|
||||||
|
_ = ProjectMember.objects.filter(
|
||||||
|
workspace__slug=slug,
|
||||||
|
project_id__in=project_ids,
|
||||||
|
member=request.user,
|
||||||
|
).update(is_active=True)
|
||||||
|
|
||||||
ProjectMember.objects.bulk_create(
|
ProjectMember.objects.bulk_create(
|
||||||
[
|
[
|
||||||
ProjectMember(
|
ProjectMember(
|
||||||
@ -1040,4 +1047,4 @@ class ProjectDeployBoardViewSet(BaseViewSet):
|
|||||||
project_deploy_board.save()
|
project_deploy_board.save()
|
||||||
|
|
||||||
serializer = ProjectDeployBoardSerializer(project_deploy_board)
|
serializer = ProjectDeployBoardSerializer(project_deploy_board)
|
||||||
return Response(serializer.data, status=status.HTTP_200_OK)
|
return Response(serializer.data, status=status.HTTP_200_OK)
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
# Python imports
|
# Python imports
|
||||||
import csv
|
import csv
|
||||||
import io
|
import io
|
||||||
|
import os
|
||||||
|
|
||||||
# Django imports
|
# Django imports
|
||||||
from django.core.mail import EmailMultiAlternatives, get_connection
|
from django.core.mail import EmailMultiAlternatives, get_connection
|
||||||
@ -32,7 +33,7 @@ row_mapping = {
|
|||||||
"priority": "Priority",
|
"priority": "Priority",
|
||||||
"estimate": "Estimate",
|
"estimate": "Estimate",
|
||||||
"issue_cycle__cycle_id": "Cycle",
|
"issue_cycle__cycle_id": "Cycle",
|
||||||
"issue_module__module_id": "Module"
|
"issue_module__module_id": "Module",
|
||||||
}
|
}
|
||||||
|
|
||||||
ASSIGNEE_ID = "assignees__id"
|
ASSIGNEE_ID = "assignees__id"
|
||||||
@ -51,17 +52,55 @@ def send_export_email(email, slug, csv_buffer):
|
|||||||
csv_buffer.seek(0)
|
csv_buffer.seek(0)
|
||||||
|
|
||||||
# Configure email connection from the database
|
# Configure email connection from the database
|
||||||
instance_configuration = InstanceConfiguration.objects.filter(key__startswith='EMAIL_').values("key", "value")
|
instance_configuration = InstanceConfiguration.objects.filter(
|
||||||
|
key__startswith="EMAIL_"
|
||||||
|
).values("key", "value")
|
||||||
connection = get_connection(
|
connection = get_connection(
|
||||||
host=get_configuration_value(instance_configuration, "EMAIL_HOST"),
|
host=get_configuration_value(
|
||||||
port=int(get_configuration_value(instance_configuration, "EMAIL_PORT", "587")),
|
instance_configuration, "EMAIL_HOST", os.environ.get("EMAIL_HOST")
|
||||||
username=get_configuration_value(instance_configuration, "EMAIL_HOST_USER"),
|
),
|
||||||
password=get_configuration_value(instance_configuration, "EMAIL_HOST_PASSWORD"),
|
port=int(
|
||||||
use_tls=bool(get_configuration_value(instance_configuration, "EMAIL_USE_TLS", "1")),
|
get_configuration_value(
|
||||||
use_ssl=bool(get_configuration_value(instance_configuration, "EMAIL_USE_SSL", "0")),
|
instance_configuration, "EMAIL_PORT", os.environ.get("EMAIL_PORT")
|
||||||
|
)
|
||||||
|
),
|
||||||
|
username=get_configuration_value(
|
||||||
|
instance_configuration,
|
||||||
|
"EMAIL_HOST_USER",
|
||||||
|
os.environ.get("EMAIL_HOST_USER"),
|
||||||
|
),
|
||||||
|
password=get_configuration_value(
|
||||||
|
instance_configuration,
|
||||||
|
"EMAIL_HOST_PASSWORD",
|
||||||
|
os.environ.get("EMAIL_HOST_PASSWORD"),
|
||||||
|
),
|
||||||
|
use_tls=bool(
|
||||||
|
get_configuration_value(
|
||||||
|
instance_configuration,
|
||||||
|
"EMAIL_USE_TLS",
|
||||||
|
os.environ.get("EMAIL_USE_TLS", "1"),
|
||||||
|
)
|
||||||
|
),
|
||||||
|
use_ssl=bool(
|
||||||
|
get_configuration_value(
|
||||||
|
instance_configuration,
|
||||||
|
"EMAIL_USE_SSL",
|
||||||
|
os.environ.get("EMAIL_USE_SSL", "0"),
|
||||||
|
)
|
||||||
|
),
|
||||||
)
|
)
|
||||||
|
|
||||||
msg = EmailMultiAlternatives(subject=subject, body=text_content, from_email=get_configuration_value(instance_configuration, "EMAIL_FROM"), to=[email], connection=connection)
|
msg = EmailMultiAlternatives(
|
||||||
|
subject=subject,
|
||||||
|
body=text_content,
|
||||||
|
from_email=get_configuration_value(
|
||||||
|
instance_configuration,
|
||||||
|
"EMAIL_FROM",
|
||||||
|
os.environ.get("EMAIL_FROM", "Team Plane <team@mailer.plane.so>"),
|
||||||
|
),
|
||||||
|
to=[email],
|
||||||
|
connection=connection,
|
||||||
|
)
|
||||||
msg.attach(f"{slug}-analytics.csv", csv_buffer.getvalue())
|
msg.attach(f"{slug}-analytics.csv", csv_buffer.getvalue())
|
||||||
msg.send(fail_silently=False)
|
msg.send(fail_silently=False)
|
||||||
|
|
||||||
|
@ -1,3 +1,6 @@
|
|||||||
|
# Python imports
|
||||||
|
import os
|
||||||
|
|
||||||
# Django imports
|
# Django imports
|
||||||
from django.core.mail import EmailMultiAlternatives, get_connection
|
from django.core.mail import EmailMultiAlternatives, get_connection
|
||||||
from django.template.loader import render_to_string
|
from django.template.loader import render_to_string
|
||||||
@ -14,9 +17,9 @@ from sentry_sdk import capture_exception
|
|||||||
from plane.license.models import InstanceConfiguration
|
from plane.license.models import InstanceConfiguration
|
||||||
from plane.license.utils.instance_value import get_configuration_value
|
from plane.license.utils.instance_value import get_configuration_value
|
||||||
|
|
||||||
|
|
||||||
@shared_task
|
@shared_task
|
||||||
def email_verification(first_name, email, token, current_site):
|
def email_verification(first_name, email, token, current_site):
|
||||||
|
|
||||||
try:
|
try:
|
||||||
realtivelink = "/request-email-verification/" + "?token=" + str(token)
|
realtivelink = "/request-email-verification/" + "?token=" + str(token)
|
||||||
abs_url = current_site + realtivelink
|
abs_url = current_site + realtivelink
|
||||||
@ -33,17 +36,56 @@ def email_verification(first_name, email, token, current_site):
|
|||||||
text_content = strip_tags(html_content)
|
text_content = strip_tags(html_content)
|
||||||
|
|
||||||
# Configure email connection from the database
|
# Configure email connection from the database
|
||||||
instance_configuration = InstanceConfiguration.objects.filter(key__startswith='EMAIL_').values("key", "value")
|
instance_configuration = InstanceConfiguration.objects.filter(
|
||||||
|
key__startswith="EMAIL_"
|
||||||
|
).values("key", "value")
|
||||||
connection = get_connection(
|
connection = get_connection(
|
||||||
host=get_configuration_value(instance_configuration, "EMAIL_HOST"),
|
host=get_configuration_value(
|
||||||
port=int(get_configuration_value(instance_configuration, "EMAIL_PORT", "587")),
|
instance_configuration, "EMAIL_HOST", os.environ.get("EMAIL_HOST")
|
||||||
username=get_configuration_value(instance_configuration, "EMAIL_HOST_USER"),
|
),
|
||||||
password=get_configuration_value(instance_configuration, "EMAIL_HOST_PASSWORD"),
|
port=int(
|
||||||
use_tls=bool(get_configuration_value(instance_configuration, "EMAIL_USE_TLS", "1")),
|
get_configuration_value(
|
||||||
|
instance_configuration, "EMAIL_PORT", os.environ.get("EMAIL_PORT")
|
||||||
|
)
|
||||||
|
),
|
||||||
|
username=get_configuration_value(
|
||||||
|
instance_configuration,
|
||||||
|
"EMAIL_HOST_USER",
|
||||||
|
os.environ.get("EMAIL_HOST_USER"),
|
||||||
|
),
|
||||||
|
password=get_configuration_value(
|
||||||
|
instance_configuration,
|
||||||
|
"EMAIL_HOST_PASSWORD",
|
||||||
|
os.environ.get("EMAIL_HOST_PASSWORD"),
|
||||||
|
),
|
||||||
|
use_tls=bool(
|
||||||
|
get_configuration_value(
|
||||||
|
instance_configuration,
|
||||||
|
"EMAIL_USE_TLS",
|
||||||
|
os.environ.get("EMAIL_USE_TLS", "1"),
|
||||||
|
)
|
||||||
|
),
|
||||||
|
use_ssl=bool(
|
||||||
|
get_configuration_value(
|
||||||
|
instance_configuration,
|
||||||
|
"EMAIL_USE_SSL",
|
||||||
|
os.environ.get("EMAIL_USE_SSL", "0"),
|
||||||
|
)
|
||||||
|
),
|
||||||
)
|
)
|
||||||
|
|
||||||
# Initiate email alternatives
|
# Initiate email alternatives
|
||||||
msg = EmailMultiAlternatives(subject=subject, body=text_content, from_email=get_configuration_value(instance_configuration, "EMAIL_FROM"), to=[email], connection=connection)
|
msg = EmailMultiAlternatives(
|
||||||
|
subject=subject,
|
||||||
|
body=text_content,
|
||||||
|
from_email=get_configuration_value(
|
||||||
|
instance_configuration,
|
||||||
|
"EMAIL_FROM",
|
||||||
|
os.environ.get("EMAIL_FROM", "Team Plane <team@mailer.plane.so>"),
|
||||||
|
),
|
||||||
|
to=[email],
|
||||||
|
connection=connection,
|
||||||
|
)
|
||||||
msg.attach_alternative(html_content, "text/html")
|
msg.attach_alternative(html_content, "text/html")
|
||||||
msg.send()
|
msg.send()
|
||||||
return
|
return
|
||||||
|
@ -1,3 +1,6 @@
|
|||||||
|
# Python import
|
||||||
|
import os
|
||||||
|
|
||||||
# Django imports
|
# Django imports
|
||||||
from django.core.mail import EmailMultiAlternatives, get_connection
|
from django.core.mail import EmailMultiAlternatives, get_connection
|
||||||
from django.template.loader import render_to_string
|
from django.template.loader import render_to_string
|
||||||
@ -32,14 +35,51 @@ def forgot_password(first_name, email, uidb64, token, current_site):
|
|||||||
|
|
||||||
instance_configuration = InstanceConfiguration.objects.filter(key__startswith='EMAIL_').values("key", "value")
|
instance_configuration = InstanceConfiguration.objects.filter(key__startswith='EMAIL_').values("key", "value")
|
||||||
connection = get_connection(
|
connection = get_connection(
|
||||||
host=get_configuration_value(instance_configuration, "EMAIL_HOST"),
|
host=get_configuration_value(
|
||||||
port=int(get_configuration_value(instance_configuration, "EMAIL_PORT", "587")),
|
instance_configuration, "EMAIL_HOST", os.environ.get("EMAIL_HOST")
|
||||||
username=get_configuration_value(instance_configuration, "EMAIL_HOST_USER"),
|
),
|
||||||
password=get_configuration_value(instance_configuration, "EMAIL_HOST_PASSWORD"),
|
port=int(
|
||||||
use_tls=bool(get_configuration_value(instance_configuration, "EMAIL_USE_TLS", "1")),
|
get_configuration_value(
|
||||||
|
instance_configuration, "EMAIL_PORT", os.environ.get("EMAIL_PORT")
|
||||||
|
)
|
||||||
|
),
|
||||||
|
username=get_configuration_value(
|
||||||
|
instance_configuration,
|
||||||
|
"EMAIL_HOST_USER",
|
||||||
|
os.environ.get("EMAIL_HOST_USER"),
|
||||||
|
),
|
||||||
|
password=get_configuration_value(
|
||||||
|
instance_configuration,
|
||||||
|
"EMAIL_HOST_PASSWORD",
|
||||||
|
os.environ.get("EMAIL_HOST_PASSWORD"),
|
||||||
|
),
|
||||||
|
use_tls=bool(
|
||||||
|
get_configuration_value(
|
||||||
|
instance_configuration,
|
||||||
|
"EMAIL_USE_TLS",
|
||||||
|
os.environ.get("EMAIL_USE_TLS", "1"),
|
||||||
|
)
|
||||||
|
),
|
||||||
|
use_ssl=bool(
|
||||||
|
get_configuration_value(
|
||||||
|
instance_configuration,
|
||||||
|
"EMAIL_USE_SSL",
|
||||||
|
os.environ.get("EMAIL_USE_SSL", "0"),
|
||||||
|
)
|
||||||
|
),
|
||||||
|
)
|
||||||
|
|
||||||
|
msg = EmailMultiAlternatives(
|
||||||
|
subject=subject,
|
||||||
|
body=text_content,
|
||||||
|
from_email=get_configuration_value(
|
||||||
|
instance_configuration,
|
||||||
|
"EMAIL_FROM",
|
||||||
|
os.environ.get("EMAIL_FROM", "Team Plane <team@mailer.plane.so>"),
|
||||||
|
),
|
||||||
|
to=[email],
|
||||||
|
connection=connection,
|
||||||
)
|
)
|
||||||
# Initiate email alternatives
|
|
||||||
msg = EmailMultiAlternatives(subject=subject, body=text_content, from_email=get_configuration_value(instance_configuration, "EMAIL_FROM"), to=[email], connection=connection)
|
|
||||||
msg.attach_alternative(html_content, "text/html")
|
msg.attach_alternative(html_content, "text/html")
|
||||||
msg.send()
|
msg.send()
|
||||||
return
|
return
|
||||||
|
@ -1,3 +1,6 @@
|
|||||||
|
# Python imports
|
||||||
|
import os
|
||||||
|
|
||||||
# Django imports
|
# Django imports
|
||||||
from django.core.mail import EmailMultiAlternatives, get_connection
|
from django.core.mail import EmailMultiAlternatives, get_connection
|
||||||
from django.template.loader import render_to_string
|
from django.template.loader import render_to_string
|
||||||
@ -12,6 +15,7 @@ from sentry_sdk import capture_exception
|
|||||||
from plane.license.models import InstanceConfiguration
|
from plane.license.models import InstanceConfiguration
|
||||||
from plane.license.utils.instance_value import get_configuration_value
|
from plane.license.utils.instance_value import get_configuration_value
|
||||||
|
|
||||||
|
|
||||||
@shared_task
|
@shared_task
|
||||||
def magic_link(email, key, token, current_site):
|
def magic_link(email, key, token, current_site):
|
||||||
try:
|
try:
|
||||||
@ -26,17 +30,55 @@ def magic_link(email, key, token, current_site):
|
|||||||
|
|
||||||
text_content = strip_tags(html_content)
|
text_content = strip_tags(html_content)
|
||||||
|
|
||||||
instance_configuration = InstanceConfiguration.objects.filter(key__startswith='EMAIL_').values("key", "value")
|
instance_configuration = InstanceConfiguration.objects.filter(
|
||||||
|
key__startswith="EMAIL_"
|
||||||
|
).values("key", "value")
|
||||||
connection = get_connection(
|
connection = get_connection(
|
||||||
host=get_configuration_value(instance_configuration, "EMAIL_HOST"),
|
host=get_configuration_value(
|
||||||
port=int(get_configuration_value(instance_configuration, "EMAIL_PORT", "587")),
|
instance_configuration, "EMAIL_HOST", os.environ.get("EMAIL_HOST")
|
||||||
username=get_configuration_value(instance_configuration, "EMAIL_HOST_USER"),
|
),
|
||||||
password=get_configuration_value(instance_configuration, "EMAIL_HOST_PASSWORD"),
|
port=int(
|
||||||
use_tls=bool(get_configuration_value(instance_configuration, "EMAIL_USE_TLS", "1")),
|
get_configuration_value(
|
||||||
|
instance_configuration, "EMAIL_PORT", os.environ.get("EMAIL_PORT")
|
||||||
|
)
|
||||||
|
),
|
||||||
|
username=get_configuration_value(
|
||||||
|
instance_configuration,
|
||||||
|
"EMAIL_HOST_USER",
|
||||||
|
os.environ.get("EMAIL_HOST_USER"),
|
||||||
|
),
|
||||||
|
password=get_configuration_value(
|
||||||
|
instance_configuration,
|
||||||
|
"EMAIL_HOST_PASSWORD",
|
||||||
|
os.environ.get("EMAIL_HOST_PASSWORD"),
|
||||||
|
),
|
||||||
|
use_tls=bool(
|
||||||
|
get_configuration_value(
|
||||||
|
instance_configuration,
|
||||||
|
"EMAIL_USE_TLS",
|
||||||
|
os.environ.get("EMAIL_USE_TLS", "1"),
|
||||||
|
)
|
||||||
|
),
|
||||||
|
use_ssl=bool(
|
||||||
|
get_configuration_value(
|
||||||
|
instance_configuration,
|
||||||
|
"EMAIL_USE_SSL",
|
||||||
|
os.environ.get("EMAIL_USE_SSL", "0"),
|
||||||
|
)
|
||||||
|
),
|
||||||
)
|
)
|
||||||
|
|
||||||
# Initiate email alternatives
|
msg = EmailMultiAlternatives(
|
||||||
msg = EmailMultiAlternatives(subject=subject, body=text_content, from_email=get_configuration_value(instance_configuration, "EMAIL_FROM"), to=[email], connection=connection)
|
subject=subject,
|
||||||
|
body=text_content,
|
||||||
|
from_email=get_configuration_value(
|
||||||
|
instance_configuration,
|
||||||
|
"EMAIL_FROM",
|
||||||
|
os.environ.get("EMAIL_FROM", "Team Plane <team@mailer.plane.so>"),
|
||||||
|
),
|
||||||
|
to=[email],
|
||||||
|
connection=connection,
|
||||||
|
)
|
||||||
msg.attach_alternative(html_content, "text/html")
|
msg.attach_alternative(html_content, "text/html")
|
||||||
msg.send()
|
msg.send()
|
||||||
return
|
return
|
||||||
|
@ -1,3 +1,6 @@
|
|||||||
|
# Python import
|
||||||
|
import os
|
||||||
|
|
||||||
# Django imports
|
# Django imports
|
||||||
from django.core.mail import EmailMultiAlternatives, get_connection
|
from django.core.mail import EmailMultiAlternatives, get_connection
|
||||||
from django.template.loader import render_to_string
|
from django.template.loader import render_to_string
|
||||||
@ -46,14 +49,52 @@ def project_invitation(email, project_id, token, current_site, invitor):
|
|||||||
# Configure email connection from the database
|
# Configure email connection from the database
|
||||||
instance_configuration = InstanceConfiguration.objects.filter(key__startswith='EMAIL_').values("key", "value")
|
instance_configuration = InstanceConfiguration.objects.filter(key__startswith='EMAIL_').values("key", "value")
|
||||||
connection = get_connection(
|
connection = get_connection(
|
||||||
host=get_configuration_value(instance_configuration, "EMAIL_HOST"),
|
host=get_configuration_value(
|
||||||
port=int(get_configuration_value(instance_configuration, "EMAIL_PORT", "587")),
|
instance_configuration, "EMAIL_HOST", os.environ.get("EMAIL_HOST")
|
||||||
username=get_configuration_value(instance_configuration, "EMAIL_HOST_USER"),
|
),
|
||||||
password=get_configuration_value(instance_configuration, "EMAIL_HOST_PASSWORD"),
|
port=int(
|
||||||
use_tls=bool(get_configuration_value(instance_configuration, "EMAIL_USE_TLS", "1")),
|
get_configuration_value(
|
||||||
|
instance_configuration, "EMAIL_PORT", os.environ.get("EMAIL_PORT")
|
||||||
|
)
|
||||||
|
),
|
||||||
|
username=get_configuration_value(
|
||||||
|
instance_configuration,
|
||||||
|
"EMAIL_HOST_USER",
|
||||||
|
os.environ.get("EMAIL_HOST_USER"),
|
||||||
|
),
|
||||||
|
password=get_configuration_value(
|
||||||
|
instance_configuration,
|
||||||
|
"EMAIL_HOST_PASSWORD",
|
||||||
|
os.environ.get("EMAIL_HOST_PASSWORD"),
|
||||||
|
),
|
||||||
|
use_tls=bool(
|
||||||
|
get_configuration_value(
|
||||||
|
instance_configuration,
|
||||||
|
"EMAIL_USE_TLS",
|
||||||
|
os.environ.get("EMAIL_USE_TLS", "1"),
|
||||||
|
)
|
||||||
|
),
|
||||||
|
use_ssl=bool(
|
||||||
|
get_configuration_value(
|
||||||
|
instance_configuration,
|
||||||
|
"EMAIL_USE_SSL",
|
||||||
|
os.environ.get("EMAIL_USE_SSL", "0"),
|
||||||
|
)
|
||||||
|
),
|
||||||
)
|
)
|
||||||
# Initiate email alternatives
|
|
||||||
msg = EmailMultiAlternatives(subject=subject, body=text_content, from_email=get_configuration_value(instance_configuration, "EMAIL_FROM"), to=[email], connection=connection)
|
msg = EmailMultiAlternatives(
|
||||||
|
subject=subject,
|
||||||
|
body=text_content,
|
||||||
|
from_email=get_configuration_value(
|
||||||
|
instance_configuration,
|
||||||
|
"EMAIL_FROM",
|
||||||
|
os.environ.get("EMAIL_FROM", "Team Plane <team@mailer.plane.so>"),
|
||||||
|
),
|
||||||
|
to=[email],
|
||||||
|
connection=connection,
|
||||||
|
)
|
||||||
|
|
||||||
msg.attach_alternative(html_content, "text/html")
|
msg.attach_alternative(html_content, "text/html")
|
||||||
msg.send()
|
msg.send()
|
||||||
return
|
return
|
||||||
|
@ -1,3 +1,6 @@
|
|||||||
|
# Python imports
|
||||||
|
import os
|
||||||
|
|
||||||
# Django imports
|
# Django imports
|
||||||
from django.core.mail import EmailMultiAlternatives, get_connection
|
from django.core.mail import EmailMultiAlternatives, get_connection
|
||||||
from django.template.loader import render_to_string
|
from django.template.loader import render_to_string
|
||||||
@ -55,23 +58,48 @@ def workspace_invitation(email, workspace_id, token, current_site, invitor):
|
|||||||
key__startswith="EMAIL_"
|
key__startswith="EMAIL_"
|
||||||
).values("key", "value")
|
).values("key", "value")
|
||||||
connection = get_connection(
|
connection = get_connection(
|
||||||
host=get_configuration_value(instance_configuration, "EMAIL_HOST"),
|
host=get_configuration_value(
|
||||||
port=int(
|
instance_configuration, "EMAIL_HOST", os.environ.get("EMAIL_HOST")
|
||||||
get_configuration_value(instance_configuration, "EMAIL_PORT", "587")
|
),
|
||||||
|
port=int(
|
||||||
|
get_configuration_value(
|
||||||
|
instance_configuration, "EMAIL_PORT", os.environ.get("EMAIL_PORT")
|
||||||
|
)
|
||||||
|
),
|
||||||
|
username=get_configuration_value(
|
||||||
|
instance_configuration,
|
||||||
|
"EMAIL_HOST_USER",
|
||||||
|
os.environ.get("EMAIL_HOST_USER"),
|
||||||
),
|
),
|
||||||
username=get_configuration_value(instance_configuration, "EMAIL_HOST_USER"),
|
|
||||||
password=get_configuration_value(
|
password=get_configuration_value(
|
||||||
instance_configuration, "EMAIL_HOST_PASSWORD"
|
instance_configuration,
|
||||||
|
"EMAIL_HOST_PASSWORD",
|
||||||
|
os.environ.get("EMAIL_HOST_PASSWORD"),
|
||||||
),
|
),
|
||||||
use_tls=bool(
|
use_tls=bool(
|
||||||
get_configuration_value(instance_configuration, "EMAIL_USE_TLS", "1")
|
get_configuration_value(
|
||||||
|
instance_configuration,
|
||||||
|
"EMAIL_USE_TLS",
|
||||||
|
os.environ.get("EMAIL_USE_TLS", "1"),
|
||||||
|
)
|
||||||
|
),
|
||||||
|
use_ssl=bool(
|
||||||
|
get_configuration_value(
|
||||||
|
instance_configuration,
|
||||||
|
"EMAIL_USE_SSL",
|
||||||
|
os.environ.get("EMAIL_USE_SSL", "0"),
|
||||||
|
)
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
# Initiate email alternatives
|
|
||||||
msg = EmailMultiAlternatives(
|
msg = EmailMultiAlternatives(
|
||||||
subject=subject,
|
subject=subject,
|
||||||
body=text_content,
|
body=text_content,
|
||||||
from_email=get_configuration_value(instance_configuration, "EMAIL_FROM"),
|
from_email=get_configuration_value(
|
||||||
|
instance_configuration,
|
||||||
|
"EMAIL_FROM",
|
||||||
|
os.environ.get("EMAIL_FROM", "Team Plane <team@mailer.plane.so>"),
|
||||||
|
),
|
||||||
to=[email],
|
to=[email],
|
||||||
connection=connection,
|
connection=connection,
|
||||||
)
|
)
|
||||||
|
Loading…
Reference in New Issue
Block a user