Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
OLAT CI-CD Testing Project
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Requirements
Code
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Locked files
Deploy
Package Registry
Container Registry
Model registry
Operate
Terraform modules
Monitor
Service Desk
Analyze
Contributor analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
Lars Oliver Dam
OLAT CI-CD Testing Project
Commits
0626b223
Commit
0626b223
authored
5 years ago
by
srosse
Browse files
Options
Downloads
Patches
Plain Diff
OO-4404: remove ([]) from contact list names
parent
f1aba23d
No related branches found
Branches containing commit
No related tags found
Tags containing commit
No related merge requests found
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
src/main/java/org/olat/core/util/mail/ContactList.java
+15
-12
15 additions, 12 deletions
src/main/java/org/olat/core/util/mail/ContactList.java
src/main/java/org/olat/core/util/mail/manager/MailManagerImpl.java
+17
-32
17 additions, 32 deletions
...java/org/olat/core/util/mail/manager/MailManagerImpl.java
with
32 additions
and
44 deletions
src/main/java/org/olat/core/util/mail/ContactList.java
+
15
−
12
View file @
0626b223
...
...
@@ -154,7 +154,7 @@ public class ContactList {
rfc2047name
=
javax
.
mail
.
internet
.
MimeUtility
.
encodeWord
(
name
,
"UTF-8"
,
null
);
}
catch
(
java
.
io
.
UnsupportedEncodingException
e
)
{
log
.
warn
(
"Error MIME-encoding name: "
+
e
,
e
);
log
.
warn
(
"Error MIME-encoding name: "
,
e
);
rfc2047name
=
name
;
}
...
...
@@ -208,7 +208,7 @@ public class ContactList {
if
(
emailPrioInstitutional
)
{
for
(
Iterator
<
Identity
>
it
=
copy
.
iterator
();
it
.
hasNext
();
)
{
Identity
tmp
=
it
.
next
();
if
(
tmp
.
getStatus
()
==
Identity
.
STATUS_LOGIN_DENIED
)
{
if
(
Identity
.
STATUS_LOGIN_DENIED
.
equals
(
tmp
.
getStatus
())
)
{
continue
;
}
...
...
@@ -223,7 +223,7 @@ public class ContactList {
* loops over the (remaining) identities, fetches the user email.
*/
for
(
Identity
tmp
:
copy
){
if
(
tmp
.
getStatus
()
==
Identity
.
STATUS_LOGIN_DENIED
)
{
if
(
Identity
.
STATUS_LOGIN_DENIED
.
equals
(
tmp
.
getStatus
())
)
{
continue
;
}
String
email
=
tmp
.
getUser
().
getProperty
(
UserConstants
.
EMAIL
,
null
);
...
...
@@ -304,16 +304,19 @@ public class ContactList {
}
private
void
setName
(
String
nameP
)
{
if
(!
StringHelper
.
containsNoneOfCoDouSemi
(
nameP
)){
log
.
warn
(
"Contact list name \""
+
nameP
+
"\" doesn't match "
+
StringHelper
.
ALL_WITHOUT_COMMA_2POINT_STRPNT
);
if
(!
StringHelper
.
containsNoneOfCoDouSemi
(
nameP
)
||
nameP
.
contains
(
"("
)
||
nameP
.
contains
(
")"
)
||
nameP
.
contains
(
"["
)
||
nameP
.
contains
(
"]"
))
{
log
.
warn
(
"Contact list name \"{}\" doesn't match {}"
,
nameP
,
StringHelper
.
ALL_WITHOUT_COMMA_2POINT_STRPNT
);
//replace bad chars with bad char in rfc compliant comments
nameP
=
nameP
.
replaceAll
(
":"
,
"¦"
);
nameP
=
nameP
.
replaceAll
(
";"
,
"_"
);
nameP
=
nameP
.
replaceAll
(
","
,
"-"
);
}
nameP
=
nameP
.
replace
(
":"
,
"¦"
)
.
replace
(
";"
,
"_"
)
.
replace
(
","
,
"-"
)
.
replace
(
"("
,
"_"
)
.
replace
(
")"
,
"_"
)
.
replace
(
"["
,
"_"
)
.
replace
(
"]"
,
"_"
);
}
this
.
name
=
nameP
;
}
}
\ No newline at end of file
This diff is collapsed.
Click to expand it.
src/main/java/org/olat/core/util/mail/manager/MailManagerImpl.java
+
17
−
32
View file @
0626b223
...
...
@@ -30,6 +30,7 @@ import java.io.OutputStream;
import
java.io.StringReader
;
import
java.io.StringWriter
;
import
java.io.UnsupportedEncodingException
;
import
java.nio.charset.StandardCharsets
;
import
java.util.ArrayList
;
import
java.util.Arrays
;
import
java.util.Collections
;
...
...
@@ -66,12 +67,10 @@ import javax.persistence.TypedQuery;
import
org.apache.commons.io.FileUtils
;
import
org.apache.commons.io.IOUtils
;
import
org.apache.logging.log4j.Logger
;
import
org.apache.velocity.VelocityContext
;
import
org.apache.velocity.app.VelocityEngine
;
import
org.apache.velocity.context.Context
;
import
org.apache.velocity.exception.MethodInvocationException
;
import
org.apache.velocity.exception.ParseErrorException
;
import
org.apache.velocity.exception.ResourceNotFoundException
;
import
org.apache.velocity.runtime.RuntimeConstants
;
import
org.olat.basesecurity.IdentityImpl
;
import
org.olat.basesecurity.IdentityRef
;
...
...
@@ -88,7 +87,6 @@ import org.olat.core.helpers.Settings;
import
org.olat.core.id.Identity
;
import
org.olat.core.id.OLATResourceable
;
import
org.olat.core.id.UserConstants
;
import
org.apache.logging.log4j.Logger
;
import
org.olat.core.logging.Tracing
;
import
org.olat.core.util.Encoder
;
import
org.olat.core.util.StringHelper
;
...
...
@@ -189,8 +187,7 @@ public class MailManagerImpl implements MailManager, InitializingBean {
public
PublisherData
getPublisherData
()
{
String
data
=
""
;
String
businessPath
=
"[Inbox:0]"
;
PublisherData
publisherData
=
new
PublisherData
(
"Inbox"
,
data
,
businessPath
);
return
publisherData
;
return
new
PublisherData
(
"Inbox"
,
data
,
businessPath
);
}
@Override
...
...
@@ -285,8 +282,8 @@ public class MailManagerImpl implements MailManager, InitializingBean {
TypedQuery
<
DBMailAttachment
>
query
=
dbInstance
.
getCurrentEntityManager
()
.
createQuery
(
sb
.
toString
(),
DBMailAttachment
.
class
)
.
setParameter
(
"checksum"
,
new
Long
(
checksum
))
.
setParameter
(
"size"
,
new
Long
(
size
))
.
setParameter
(
"checksum"
,
Long
.
valueOf
(
checksum
))
.
setParameter
(
"size"
,
Long
.
valueOf
(
size
))
.
setParameter
(
"name"
,
name
);
if
(
mimetype
!=
null
)
{
query
.
setParameter
(
"mimetype"
,
mimetype
);
...
...
@@ -402,7 +399,7 @@ public class MailManagerImpl implements MailManager, InitializingBean {
marked
=
Boolean
.
FALSE
;
}
if
(!
marked
.
equals
(
recipient
.
getMarked
()))
{
recipient
.
setMarked
(
marked
.
booleanValue
()
);
recipient
.
setMarked
(
marked
);
dbInstance
.
updateObject
(
recipient
);
changed
|=
true
;
}
...
...
@@ -603,7 +600,7 @@ public class MailManagerImpl implements MailManager, InitializingBean {
File
template
=
new
File
(
baseFolder
,
"mail_template.html"
);
if
(
template
.
exists
())
{
try
(
InputStream
in
=
new
FileInputStream
(
template
))
{
return
IOUtils
.
toString
(
in
,
"UTF-8"
);
return
IOUtils
.
toString
(
in
,
StandardCharsets
.
UTF_8
);
}
catch
(
IOException
e
)
{
log
.
error
(
""
,
e
);
}
...
...
@@ -621,7 +618,7 @@ public class MailManagerImpl implements MailManager, InitializingBean {
File
templateFile
=
new
File
(
baseFolder
,
"mail_template.html"
);
try
(
OutputStream
out
=
new
FileOutputStream
(
templateFile
);)
{
StringReader
reader
=
new
StringReader
(
template
);
IOUtils
.
copy
(
reader
,
out
,
"UTF-8"
);
IOUtils
.
copy
(
reader
,
out
,
StandardCharsets
.
UTF_8
);
}
catch
(
IOException
e
)
{
log
.
error
(
""
,
e
);
}
...
...
@@ -643,7 +640,7 @@ public class MailManagerImpl implements MailManager, InitializingBean {
@Override
public
String
getDefaultMailTemplate
()
{
try
(
InputStream
in
=
MailModule
.
class
.
getResourceAsStream
(
"_content/mail_template.html"
))
{
return
IOUtils
.
toString
(
in
,
"UTF-8"
);
return
IOUtils
.
toString
(
in
,
StandardCharsets
.
UTF_8
);
}
catch
(
IOException
e
)
{
log
.
error
(
"Cannot read the default mail template"
,
e
);
return
null
;
...
...
@@ -861,15 +858,6 @@ public class MailManagerImpl implements MailManager, InitializingBean {
// template is empty
mailerResult
.
setReturnCode
(
MailerResult
.
OK
);
}
}
catch
(
ParseErrorException
e
)
{
log
.
warn
(
"can't send email from user template"
,
e
);
mailerResult
.
setReturnCode
(
MailerResult
.
TEMPLATE_PARSE_ERROR
);
}
catch
(
MethodInvocationException
e
)
{
log
.
warn
(
"can't send email from user template"
,
e
);
mailerResult
.
setReturnCode
(
MailerResult
.
TEMPLATE_GENERAL_ERROR
);
}
catch
(
ResourceNotFoundException
e
)
{
log
.
warn
(
"can't send email from user template"
,
e
);
mailerResult
.
setReturnCode
(
MailerResult
.
TEMPLATE_GENERAL_ERROR
);
}
catch
(
Exception
e
)
{
log
.
warn
(
"can't send email from user template"
,
e
);
mailerResult
.
setReturnCode
(
MailerResult
.
TEMPLATE_GENERAL_ERROR
);
...
...
@@ -992,13 +980,13 @@ public class MailManagerImpl implements MailManager, InitializingBean {
mail
.
setMetaId
(
metaId
);
String
subject
=
content
.
getSubject
();
if
(
subject
!=
null
&&
subject
.
length
()
>
500
)
{
log
.
warn
(
"Cut a too long subkect in name. Size:
"
+
subject
.
length
());
log
.
warn
(
"Cut a too long subkect in name. Size:
{}"
,
subject
.
length
());
subject
=
subject
.
substring
(
0
,
500
);
}
mail
.
setSubject
(
subject
);
String
body
=
content
.
getBody
();
if
(
body
!=
null
&&
body
.
length
()
>
16777210
)
{
log
.
warn
(
"Cut a too long body in mail. Size:
"
+
body
.
length
());
log
.
warn
(
"Cut a too long body in mail. Size:
{}"
,
body
.
length
());
body
=
body
.
substring
(
0
,
16000000
);
}
mail
.
setBody
(
body
);
...
...
@@ -1009,7 +997,7 @@ public class MailManagerImpl implements MailManager, InitializingBean {
if
(
ores
!=
null
)
{
String
resName
=
ores
.
getResourceableTypeName
();
if
(
resName
!=
null
&&
resName
.
length
()
>
50
)
{
log
.
warn
(
"Cut a too long resourceable type name in mail context:
"
+
resName
);
log
.
warn
(
"Cut a too long resourceable type name in mail context:
{}"
,
resName
);
resName
=
resName
.
substring
(
0
,
49
);
}
mail
.
getContext
().
setResName
(
ores
.
getResourceableTypeName
());
...
...
@@ -1018,14 +1006,14 @@ public class MailManagerImpl implements MailManager, InitializingBean {
String
resSubPath
=
context
.
getResSubPath
();
if
(
resSubPath
!=
null
&&
resSubPath
.
length
()
>
2000
)
{
log
.
warn
(
"Cut a too long resSubPath in mail context:
"
+
resSubPath
);
log
.
warn
(
"Cut a too long resSubPath in mail context:
{}"
,
resSubPath
);
resSubPath
=
resSubPath
.
substring
(
0
,
2000
);
}
mail
.
getContext
().
setResSubPath
(
resSubPath
);
String
businessPath
=
context
.
getBusinessPath
();
if
(
businessPath
!=
null
&&
businessPath
.
length
()
>
2000
)
{
log
.
warn
(
"Cut a too long resSubPath in mail context:
"
+
businessPath
);
log
.
warn
(
"Cut a too long resSubPath in mail context:
{}"
,
businessPath
);
businessPath
=
businessPath
.
substring
(
0
,
2000
);
}
mail
.
getContext
().
setBusinessPath
(
businessPath
);
...
...
@@ -1383,8 +1371,7 @@ public class MailManagerImpl implements MailManager, InitializingBean {
}
try
{
Address
add
=
new
InternetAddress
(
address
);
return
add
;
return
new
InternetAddress
(
address
);
}
catch
(
AddressException
e
)
{
result
.
setReturnCode
(
MailerResult
.
SENDER_ADDRESS_ERROR
);
throw
e
;
...
...
@@ -1556,8 +1543,7 @@ public class MailManagerImpl implements MailManager, InitializingBean {
// abort if attachment does not exist
if
(
attachment
==
null
||
attachment
.
getSize
()
<=
0
)
{
result
.
setReturnCode
(
MailerResult
.
ATTACHMENT_INVALID
);
log
.
error
(
"Tried to send mail wit attachment that does not exist::"
+
(
attachment
==
null
?
null
:
attachment
.
getName
()));
log
.
error
(
"Tried to send mail wit attachment that does not exist:: {}"
,
(
attachment
==
null
?
null
:
attachment
.
getName
()));
return
msg
;
}
BodyPart
messageBodyPart
=
new
MimeBodyPart
();
...
...
@@ -1737,8 +1723,7 @@ public class MailManagerImpl implements MailManager, InitializingBean {
// abort if attachment does not exist
if
(
attachmentFile
==
null
||
!
attachmentFile
.
exists
())
{
result
.
setReturnCode
(
MailerResult
.
ATTACHMENT_INVALID
);
log
.
error
(
"Tried to send mail wit attachment that does not exist::"
+
(
attachmentFile
==
null
?
null
:
attachmentFile
.
getAbsolutePath
()));
log
.
error
(
"Tried to send mail wit attachment that does not exist::{}"
,
(
attachmentFile
==
null
?
null
:
attachmentFile
.
getAbsolutePath
()));
return
msg
;
}
BodyPart
filePart
=
new
MimeBodyPart
();
...
...
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment