File: append-transform-plugin.en.rst

package info (click to toggle)
trafficserver 9.2.5%2Bds-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 53,008 kB
  • sloc: cpp: 345,484; ansic: 31,134; python: 24,200; sh: 7,271; makefile: 3,045; perl: 2,261; java: 277; pascal: 119; sql: 94; xml: 2
file content (146 lines) | stat: -rw-r--r-- 5,185 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
.. Licensed to the Apache Software Foundation (ASF) under one
   or more contributor license agreements.  See the NOTICE file
   distributed with this work for additional information
   regarding copyright ownership.  The ASF licenses this file
   to you under the Apache License, Version 2.0 (the
   "License"); you may not use this file except in compliance
   with the License.  You may obtain a copy of the License at

   http://www.apache.org/licenses/LICENSE-2.0

   Unless required by applicable law or agreed to in writing,
   software distributed under the License is distributed on an
   "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
   KIND, either express or implied.  See the License for the
   specific language governing permissions and limitations
   under the License.

.. include:: ../../../common.defs

.. _developer-plugins-http-transformations-append:

Append Transform Plugin
***********************

The append_transform plugin appends text to the body of an HTTP
response. It obtains this text from a file; the name of the file
containing the append text is a parameter you specify in
``plugin.config``, as follows:

::

    append_transform.so path/to/file

The append_transform plugin is based on ``null_transform.c``. The only
difference is that after the plugin feeds the document through the
transformation, it adds text to the response.

Below is a list of the functions in ``append_transform.c``, in the order
they appear in the source code. Below each entry is a description of
what the function does:

-  **``my_data_alloc``**

   Allocates and initializes a ``MyData`` structure. The plugin defines
   a struct, ``MyData``, as follows:

   .. code-block:: c

       typedef struct {
           TSVIO output_vio;
           TSIOBuffer output_buffer;
           TSIOBufferReader output_reader;
           int append_needed;
       } MyData;

   The ``MyData`` structure is used to represent data that the
   transformation (vconnection) needs. The transformation's data pointer
   is set to a ``MyData`` pointer using ``TSContDataSet`` in the
   ``handle_transform`` routine.

-  **``my_data_destroy``**

   Destroys objects of type ``MyData``. To deallocate the transform's
   data, the ``append_transform`` routine (see below) calls
   ``my_data_destroy`` when the transformation is complete.

-  **``handle_transform``**

   This function does the actual data transformation. The transformation
   is created in ``transform_add`` (see below). ``handle_transform`` is
   called by ``append_transform``.

-  **``append_transform``**

   This is the handler function for the transformation vconnection
   created in ``transform_add``. It is the implementation of the
   vconnection.

   -  If the transformation vconnection has been closed, then
      ``append_transform`` calls ``my_data_destroy`` to destroy the
      vconnection.

   -  If ``append_transform`` receives an error event, then it calls
      back the continuation to let it know it has completed the write
      operation.

   -  If it receives a ``WRITE_COMPLETE`` event, then it shuts down the
      write portion of its vconnection.

   -  If it receives a ``WRITE_READY`` or any other event (such as
      ``TS_HTTP_RESPONSE_TRANSFORM_HOOK``), then it calls
      ``handle_transform`` to attempt to transform more data.

-  **``transformable``**

   The plugin transforms only documents that have a content type of
   ``text/html``. This function examines the ``Content-Type`` MIME
   header field in the response header. If the value of the MIME field
   is ``text/html``, then the function returns 1; otherwise, it returns
   zero.

-  **``transform_add``**

   Creates the transformation for the current transaction and sets up a
   transformation hook. The handler function for the transformation is
   ``append_transform``.

-  **``transform_plugin``**

   This is the handler function for the main continuation for the
   plugin. Traffic Server calls this function whenever it reads an HTTP
   response header. ``transform_plugin`` does the following:

   -  Gets a handle to the HTTP transaction being processed

   -  Calls ``transformable`` to determine whether the response document
      content is of type ``text/html``

   -  If the content is transformable, then it calls ``transform_add``
      to create the transformation.

   -  Calls ``TSHttpTxnReenable`` to continue the transaction

-  **``load``**

   Opens the file containing the text to be appended and loads the
   contents of the file into an ``TSIOBuffer`` called ``append_buffer``.

-  **``TSPluginInit``**

   Does the following:

   -  Checks to make sure that the required configuration information
      (the append text filename) is entered in ``plugin.config``
      correctly.

   -  If there is a filename, then ``TSPluginInit`` calls load to load
      the text.

   -  Creates a continuation for the plugin. The handler for this
      continuation is ``transform_plugin``.

   -  Adds the plugin's continuation to
      ``TS_HTTP_READ_RESPONSE_HDR_HOOK``. In other words, it sets up a
      callback of the plugin's continuation when Traffic Server reads
      HTTP response headers.