[Rt-commit] rt branch, 4.0/encode-and-decode-docs, created. rt-4.0.18-121-g929b423
Kevin Falcone
falcone at bestpractical.com
Tue Dec 17 18:21:12 EST 2013
The branch, 4.0/encode-and-decode-docs has been created
at 929b4231ac5787e1fc996cad10f9c8dd006e87ed (commit)
- Log -----------------------------------------------------------------
commit 750bdd77bd46df724bba9761df2bcd1d21cfb915
Author: Kevin Falcone <falcone at bestpractical.com>
Date: Mon Dec 16 16:09:42 2013 -0500
Correct missing arguments in _EnclodeLOB docs
6b12b8f added $Filename but didn't update the docs.
This commit also added the special return condition without documenting
it.
diff --git a/lib/RT/Record.pm b/lib/RT/Record.pm
index 66a6d65..2e61141 100644
--- a/lib/RT/Record.pm
+++ b/lib/RT/Record.pm
@@ -729,9 +729,12 @@ sub _Accessible {
}
-=head2 _EncodeLOB BODY MIME_TYPE
+=head2 _EncodeLOB BODY MIME_TYPE FILENAME
-Takes a potentially large attachment. Returns (ContentEncoding, EncodedBody) based on system configuration and selected database
+Takes a potentially large attachment. Returns (ContentEncoding,
+EncodedBody, MimeType, Filename) based on system configuration and
+selected database. Returns a custom (short) text/plain message if
+DropLongAttachments causes an attachment to not be stored.
=cut
commit 929b4231ac5787e1fc996cad10f9c8dd006e87ed
Author: Kevin Falcone <falcone at bestpractical.com>
Date: Mon Dec 16 16:11:20 2013 -0500
Document _DecodeLOB. Improve the _EncodeLOB docs
In particular, call out their return and expected values in case you're
trying to pass the return from _DecodeLOB back into _EncodeLOB, which
RT::Migrate does.
diff --git a/lib/RT/Record.pm b/lib/RT/Record.pm
index 2e61141..ce75e57 100644
--- a/lib/RT/Record.pm
+++ b/lib/RT/Record.pm
@@ -736,6 +736,14 @@ EncodedBody, MimeType, Filename) based on system configuration and
selected database. Returns a custom (short) text/plain message if
DropLongAttachments causes an attachment to not be stored.
+Encodes your data as base64 or Quoted-Printable as needed based on your
+Databases's restrictions and the UTF-8ness of the data being passed in. Since
+we are storing in columns marked UTF8, we must ensure that binary data is
+encoded on databases which are strict.
+
+This function expects to receive an octet string in order to properly
+evaluate and encode it. It will return an octet string.
+
=cut
sub _EncodeLOB {
@@ -807,6 +815,27 @@ sub _EncodeLOB {
}
+=head2 _DecodeLOB
+
+Unpacks data stored in the database, which may be base64 or QP encoded
+because of our need to store binary and badly encoded data in columns
+marked as UTF-8. Databases such as PostgreSQL and Oracle care that you
+are feeding them invalid UTF-8 and will refuse the content. This
+function handles unpacking the encoded data.
+
+It returns textual data as a UTF-8 string which has been processed by Encode's
+PERLQQ filter which will replace the invalid bytes with \x{HH} so you can see
+the invalid byte but won't run into problems treating the data as UTF-8 later.
+
+This is similar to how we filter all data coming in via the web UI in
+RT::Interface::Web::DecodeARGS. This filter should only end up being
+applied to old data from less UTF-8-safe versions of RT.
+
+Important Note - This function expects an octet string and returns a
+character string for non-binary data.
+
+=cut
+
sub _DecodeLOB {
my $self = shift;
my $ContentType = shift || '';
-----------------------------------------------------------------------
More information about the rt-commit
mailing list