Table of Contents
Document Type Definition for the Lire Report Specification Markup Language.
This DTD defines a grammar that is used to specify reports
   that can be generated by Lire. Elements of this DTD uses the
   http://www.logreport.org/LRSML/ namespace that is
   usually mapped to the lire prefix.
  
The latest version of that DTD is 2.1 and its public identifier is -//LogReport.ORG//DTD Lire Report Specification Markup Language V2.1//EN™. Its canonical system identifier is http://www.logreport.org/LRSML/2.1/lrsml.dtd.
<!--                    
                                                                   -->
<!--                    Namespace prefix for validation using the
                        DTD                                        -->
<!ENTITY % LIRE.xmlns.pfx    "lire"                                  >
<!ENTITY % LIRE.pfx          "%LIRE.xmlns.pfx;:"                     >
<!ENTITY % LIRE.xmlns.attr.name "xmlns:%LIRE.xmlns.pfx;"             >
<!ENTITY % LIRE.xmlns.attr
  "%LIRE.xmlns.attr.name; CDATA #FIXED 'http://www.logreport.org/LRSML/'">
<!ENTITY % LRCML.xmlns.pfx    "lrcml"                                 >
<!ENTITY % LRCML.pfx          "%LRCML.xmlns.pfx;:"                    >
<!ENTITY % LRCML.xmlns.attr.name "xmlns:%LRCML.xmlns.pfx;">
<!ENTITY % LRCML.xmlns.attr
  "%LRCML.xmlns.attr.name; CDATA #FIXED 'http://www.logreport.org/LRCML/'">
  This DTD uses the common modules lire-types.mod which defines the data types recognized by Lire and lire-desc.mod which is used to include a subset of DocBook in description and text elements.
  
<!ENTITY % lire-types.mod PUBLIC
    "-//LogReport.ORG//ENTITIES Lire Data Types V1.0//EN"
    "lire-types.mod">
%lire-types.mod;
<!ENTITY % lire-desc.mod PUBLIC
    "-//LogReport.ORG//ELEMENTS Lire Description Elements V2.0//EN"
    "lire-desc.mod">
%lire-desc.mod;
   
  Each report specification is a XML document which has one
   report-spec as its root element. This DTD can
   also be used for filter specification which have one
   global-filter-spec as root element.
  
<!ENTITY % LIRE.report-spec     "%LIRE.pfx;report-spec"              >
<!ENTITY % LIRE.global-filter-spec "%LIRE.pfx;global-filter-spec">
<!ENTITY % LIRE.display-spec    "%LIRE.pfx;display-spec"             >
<!ENTITY % LIRE.param-spec      "%LIRE.pfx;param-spec"               >
<!ENTITY % LIRE.param           "%LIRE.pfx;param"                    >
<!ENTITY % LIRE.chart-configs   "%LIRE.pfx;chart-configs"            >
<!ENTITY % LRCML.param          "%LRCML.pfx;param"                   >
<!ENTITY % LIRE.filter-spec     "%LIRE.pfx;filter-spec"              >
<!ENTITY % LIRE.report-calc-spec "%LIRE.pfx;report-calc-spec"        >
<!ELEMENT %LRCML.param; (#PCDATA|%LRCML.param;)*                     >
<!ATTLIST %LRCML.param;
             name      NMTOKEN                             #REQUIRED
             value     CDATA                               #IMPLIED  >
  Root element of a report specification. It contains
    descriptive elements about the report specification
    (title, description). It
    contains the display elements that will be in the generated report
    (display-spec).
   
It contains specification for the parameters that can be used
    to customize the report generated from this specification
    (param-spec). Finally, it contains elements to specify a filter
    expression which can be used to select a subset of the records
    (filter-spec) and the expression to build the
    report (report-calc-spec). 
   
report-spec's attributes
the name of the superservice for which this report is available : i.e. email, www, dns, etc.
The DLF schema used by the report. This defaults to the superservice's schema, but can be one of its derived or extended schema.
A whitespace delimited list of additional schemas that will be joined for this report. This will make all fields define in these schemas available for the operators. The schemas that can be joined depends on the specification's schema.
An unique identifier for the report specification
<!ELEMENT %LIRE.report-spec;
                        (%LIRE.title;, %LIRE.description;,
                         (%LIRE.param-spec;)?, %LIRE.display-spec;,
                        (%LIRE.filter-spec;)?, (%LIRE.chart-configs;)?,
                        %LIRE.report-calc-spec;)    
                                                                     >
<!ATTLIST %LIRE.report-spec;
             id             ID                              #REQUIRED
             superservice   %superservice.type;             #REQUIRED
             schema         NMTOKEN                         #IMPLIED
             joined-schemas NMTOKENS                        #IMPLIED
             %LIRE.xmlns.attr;                                       
             %LRCML.xmlns.attr;                                       >
   Root element of a filter specification. It contains
    descriptive elements about the filter specification
    (title, description). It
    contains the display elements that will be used when that filter
    is used in a generated report (display-spec).
    It contains specification for the parameters that can be used to
    customize the filter generated from this specification
    (param-spec). Finally, it contains element to
    specify the filter expression which can be used to select a subset
    of the records (filter-spec).
   
global-filter-spec's attributes
the name of the superservice for which this filter is available : i.e. email, www, dns, etc.
the DLF schema used by the report. This defaults to the superservice's schema, but can be one of its derived or extended schema.
A whitespace delimited list of additional schemas that will be joined for this report. This will make all fields define in these schemas available for the operators. The schemas that can be joined depends on the specification's schema.
An unique identifier for the filter specification
<!ELEMENT %LIRE.global-filter-spec;
                        (%LIRE.title;, %LIRE.description;,
                         (%LIRE.param-spec;)?, %LIRE.display-spec;,
                        (%LIRE.filter-spec;))    
                                                                     >
<!ATTLIST %LIRE.global-filter-spec;
             id             ID                              #REQUIRED
             superservice   %superservice.type;             #REQUIRED
             schema         NMTOKEN                         #IMPLIED
             joined-schemas NMTOKENS                        #IMPLIED
             %LIRE.xmlns.attr;                                       >
   This element contains the descriptive element that will appear in the generated report.
It contains one title and may contains one description which will be used as help message
This element has no attribute.
<!ELEMENT %LIRE.display-spec; (%LIRE.title;, (%LIRE.description;)?) >
This element contains the parameters than can be customized in this report specification.
This element doesn't have any attribute.
<!ELEMENT %LIRE.param-spec; (%LIRE.param;)+ >
This element contains the specification for a parameter than can be used to customize this report.
This element can contains a description
    element which can be used to explain the parameter's
    purpose.
It is an error to define a parameter with the same name than one of the superservice's field.
param's attributes
the name of the parameter.
the parameter's data type
the parameter's default value
<!ELEMENT %LIRE.param; (%LIRE.description;)?                         >
<!ATTLIST  %LIRE.param;
             name       ID                                 #REQUIRED 
             type       (%lire.types;)                     #REQUIRED
             default    CDATA                              #IMPLIED  >
   This element contains one or more chart configurations that should be copied to the generated subreport. These chart configurations are specified using the Lire Report Configuration Markup Language.
This element has no attribute.
<!ELEMENT %LIRE.chart-configs; (%LRCML.param;)+ >
<!ENTITY % LIRE.eq      "%LIRE.pfx;eq"                               >
<!ENTITY % LIRE.ne      "%LIRE.pfx;ne"                               >
<!ENTITY % LIRE.gt      "%LIRE.pfx;gt"                               >
<!ENTITY % LIRE.ge      "%LIRE.pfx;ge"                               >
<!ENTITY % LIRE.lt      "%LIRE.pfx;lt"                               >
<!ENTITY % LIRE.le      "%LIRE.pfx;le"                               >
<!ENTITY % LIRE.and     "%LIRE.pfx;and"                              >
<!ENTITY % LIRE.or      "%LIRE.pfx;or"                               >
<!ENTITY % LIRE.not     "%LIRE.pfx;not"                              >
<!ENTITY % LIRE.match   "%LIRE.pfx;match"                            >
<!ENTITY % LIRE.value   "%LIRE.pfx;value"                            >
<!ENTITY % expr "%LIRE.eq; | %LIRE.ne; | 
                 %LIRE.gt; | %LIRE.lt; | %LIRE.ge; | %LIRE.le; | 
                 %LIRE.and; | %LIRE.or; | %LIRE.not; | 
                 %LIRE.match; | %LIRE.value;"                        >
   This element is used to select the subset of the records that will be used to generate the report. If this element is missing, all records will be used to generate the report.
The content of this element are expression element which defines an expression which will evaluate to true or false for each record. The subset used for to generate the report are all records for which the expression evaluates to true.
The value used to evaluate the expressions are either literal, value of parameter or value of one of the field of the record. Parameter and field starts with a $ followed by the name of the parameter or field. All other values are interpreted as literals.
This element doesn't have any attribute.
 
<!ELEMENT %LIRE.filter-spec; (%expr;)                                >
    This expression element to false if the 'value' attribute is undefined, the empty string or 0. It evaluate to true otherwise.
value's attributes
The value that should be evaluated for a boolean context.
<!ELEMENT %LIRE.value;  EMPTY                                        >
<!ATTLIST %LIRE.value;
             value      CDATA                              #REQUIRED >
    
<!ELEMENT %LIRE.eq;     EMPTY                                        >
<!ATTLIST %LIRE.eq;
             arg1       CDATA                              #REQUIRED   
             arg2       CDATA                              #REQUIRED >
    
<!ELEMENT %LIRE.ne;     EMPTY                                        >
<!ATTLIST %LIRE.ne;
             arg1       CDATA                              #REQUIRED   
             arg2       CDATA                              #REQUIRED >
    
<!ELEMENT %LIRE.gt;     EMPTY                                        >
<!ATTLIST %LIRE.gt;
             arg1       CDATA                              #REQUIRED   
             arg2       CDATA                              #REQUIRED >
    
<!ELEMENT %LIRE.ge;     EMPTY                                        >
<!ATTLIST %LIRE.ge;
             arg1       CDATA                              #REQUIRED   
             arg2       CDATA                              #REQUIRED >
    
<!ELEMENT %LIRE.lt;     EMPTY                                        >
<!ATTLIST %LIRE.lt;
             arg1       CDATA                              #REQUIRED   
             arg2       CDATA                              #REQUIRED >
    
<!ELEMENT %LIRE.le;     EMPTY                                        >
<!ATTLIST %LIRE.le;
             arg1       CDATA                              #REQUIRED   
             arg2       CDATA                              #REQUIRED >
    The match expression element tries to match a POSIX 1003.2 extended regular expression to a value and return true if there is a match and false otherwise.
match's attributes
the value which should matched
A POSIX 1003.2 extended regular expression.
Is the regex sensitive to case. Defaults to true.
<!ELEMENT %LIRE.match;  EMPTY                                        >
<!ATTLIST %LIRE.match;
             value          CDATA                          #REQUIRED   
             re             CDATA                          #REQUIRED 
             case-sensitive (%bool.type;)                  'true'    >
    
<!ENTITY % LIRE.timegroup   "%LIRE.pfx;timegroup"                    >
<!ENTITY % LIRE.group       "%LIRE.pfx;group"                        >
<!ENTITY % LIRE.rangegroup  "%LIRE.pfx;rangegroup"                   >
<!ENTITY % LIRE.timeslot    "%LIRE.pfx;timeslot"                     >
<!ENTITY % LIRE.field       "%LIRE.pfx;field"                        >
<!ENTITY % LIRE.sum         "%LIRE.pfx;sum"                          >
<!ENTITY % LIRE.avg         "%LIRE.pfx;avg"                          >
<!ENTITY % LIRE.min         "%LIRE.pfx;min"                          >
<!ENTITY % LIRE.max         "%LIRE.pfx;max"                          >
<!ENTITY % LIRE.first       "%LIRE.pfx;first"                        >
<!ENTITY % LIRE.last        "%LIRE.pfx;last"                         >
<!ENTITY % LIRE.count       "%LIRE.pfx;count"                        >
<!ENTITY % LIRE.records     "%LIRE.pfx;records"                      >
<!-- Empty group operator                                          -->
<!ENTITY % LIRE.empty-ops   "%LIRE.sum; | %LIRE.avg; | %LIRE.count; |
                             %LIRE.min; | %LIRE.max; | %LIRE.first; |
			     %LIRE.last; | %LIRE.records;"           >
<!-- Group operations that are also aggregators                    -->
<!ENTITY % LIRE.nestable-aggr
                            "%LIRE.group; | %LIRE.timegroup; | 
                             %LIRE.timeslot; | %LIRE.rangegroup;"    >
<!-- Group operations                                              -->
<!ENTITY % LIRE.group-ops   "%LIRE.empty-ops;| %LIRE.nestable-aggr;" >
<!-- Containers for group operations                               -->
<!ENTITY % LIRE.aggregator  "%LIRE.nestable-aggr;"                   >
   This element describes the computation needs to generate the report.
It contains one aggregator element.
This element doesn't have any attributes.
<!ELEMENT %LIRE.report-calc-spec; (%LIRE.aggregator;)                >
    All elements which will create a column in the resulting report have a label attribute that will be used as the column label. When this attribute is omitted, the name attribute content will be used as column label.
<!ENTITY % label.attr "label CDATA #IMPLIED">
    All operation elements may have a name attribute which can be used to reference that column. (It is required in the case of aggrage functions). The primary usage is for controlling the sort order of the rows in the generated report.
<!ENTITY % name.attr	  "name ID      #IMPLIED">
<!ENTITY % name.attr.req  "name ID      #REQUIRED">
    The group element generates a report where records are grouped by some field values and aggregate statistics are computed on those group of records.
It contains the field that should be used for grouping and the statistics that should be computed.
The sort order in the report is controlled by the 'sort' attribute.
group's attributes
An identifier that can be used to reference this operation from other elements. This name will most often be used in the parent's sort attribute. If omitted a default name will be generated.
whitespace delimited list of fields name that should used
	to sort the records. Field names can be prefixed by
	- to specify reverse sort order, otherwise
	ascending sort order is used. The name can also refer to the
	name attribute of the statistics element.
       
limit the number of records that will be in the generated report. It can be either a positive integer or the name of a user supplied param.
<!ELEMENT %LIRE.group;      ((%LIRE.field;)+, (%LIRE.group-ops;)+)   >
<!ATTLIST %LIRE.group;
	     %name.attr;
             sort       NMTOKENS                           #IMPLIED  
             limit      CDATA                              #IMPLIED  >
    The timegroup element generates a report
     where records are grouped by time range (hour, day, etc.).
     Statistics are then computed on these records grouped by period.
    
timegroup's attributes
An identifier that can be used to reference this operation from other elements. This name will most often be used in the parent's sort attribute. If omitted a default name will be generated.
Sets the column label that will be used for column generated by this element. If omitted a default label will be generated.
the name of the field which is used to group records. This should be a field which is of one of the time types (timestamp, date, time). It defaults to the default timestamp field if unspecified.
This is the timeperiod over which records should be grouped. Valid period looks like (hour, day, 1h, 30m, etc). It can also be the name of a user supplied param.
<!ELEMENT %LIRE.timegroup;  (%LIRE.group-ops;)+                      >
<!ATTLIST %LIRE.timegroup;
	     %name.attr;
	     %label.attr;
             field      NMTOKEN                            #IMPLIED
             period     CDATA                             #REQUIRED  >
    The timeslot element generates a report
     where records are grouped according to a cyclic unit of time. The
     duration unit used won't fall over to the next higher unit. For
     example, this means that using a unit of 1d will generate a
     report where the stats will be by day of the week, 8h will
     generate a report by third of day, etc. The statistics are then
     computed over the records in the same timeslot.
Example 11.2. timeslot with 2m unit
Specifying unit="2m" would generate
      a line for each two months, giving a yearly view.
timeslot's attributes
An identifier that can be used to reference this operation from other elements. This name will most often be used in the parent's sort attribute. If omitted a default name will be generated.
Sets the column label that will be used for column generated by this element. If omitted a default label will be generated.
the name of the field which is used to group records. This should be a field which is of one of the time types (timestamp, date, time). It defaults to the default 'timestamp' field if unspecified.
This is the cyclic unit of time in which units the records are aggregated. It can be any duration value. (hour, day, 1h, 30m, etc). It can also be the name of a user supplied param.
<!ELEMENT %LIRE.timeslot;  (%LIRE.group-ops;)+                       >
<!ATTLIST %LIRE.timeslot;
	     %name.attr;
	     %label.attr;
             field      NMTOKEN                            #IMPLIED
             unit       CDATA                             #REQUIRED  >
    The rangegroup element generates a report
     where records are grouped into distinct class delimited by a
     range. This element can be used to aggregates continuous numeric
     values like duration or bytes. Statistics are then computed on
     these records grouped in range class.
    
rangegroup's attributes
An identifier that can be used to reference this operation from other elements. This name will most often be used in the parent's sort attribute. If omitted a default name will be generated.
Sets the column label that will be used for column generated by this element. If omitted a default label will be generated.
the name of the field which is used to group records. This should be a field which is of a continuous numeric type (bytes, duration, int, number). Time types aggregation should use the timegroup element or timeslot.
The starting index of the first class. Defaults to 0. This won't be used a the lower limit of the class. It is only used to specify relatively at which values the classes delimitation start. For example, if the range-start is 1, and the range-size is 5, a class ranging -4 to 0 will be created if values are in that range. It can be supplied in any continuous unit (i.e 10k, 5m, etc.) This can also be the name of a user supplied param.
This is the size of class. It can be supplied in any continuous unit (i.e 10k, 5m, etc.) It can also be the name of a user supplied param.
All value lower then this boundary value will be considered to be equal to this value. If this parameter isn't set, the ranges won't be bounded on the left side.
All value greater then this boundary value will be considered to be equal to this value. If this parameter isn't set, the ranges won't be bounded on the right side.
The rate at which the size scale from one class to another. If it is different then 1, this will create a logarithmic distribution. For example, setting this to 2, each successive class will be twice larger then the precedent : 0-9, 10-29, 30-69, etc.
<!ELEMENT %LIRE.rangegroup;  (%LIRE.group-ops;)+                     >
<!ATTLIST %LIRE.rangegroup;
	     %name.attr;
	     %label.attr;
             field          NMTOKEN                       #REQUIRED
             range-start    CDATA                         #IMPLIED
             range-size     CDATA                         #REQUIRED 
             min-value      CDATA                         #IMPLIED   
             max-value      CDATA                         #IMPLIED 
             size-scale     CDATA                         #IMPLIED   >
    This element reference a DLF field which value will be
     displayed in a separate column in the resulting report. Its used
     to specify the grouping fields in the group
     element and to specify the fields to output in the
     records element.
    
field's attribute
The name of the DLF field that will be used as key for grouping.
Sets the column label that will be used for column generated by this element. If omitted a default label will be generated.
<!ELEMENT %LIRE.field;  EMPTY                                        >
<!ATTLIST %LIRE.field;
             name   NMTOKEN				    #REQUIRED
	     %label.attr;                                            >
    The sum element sums the value of a field
     in the group.
    
sum's attributes
An identifier that can be used to reference this operation from other elements. This name will most often be used in the parent's sort attribute.
Sets the column label that will be used for column generated by this element. If omitted a default label will be generated.
the field that should be summed.
This attribute can be used to display the sum as a ratio
	of the group or table total. If the attribute is set to
	group the resulting value will be the
	ratio on the group's total sum. If the attribute is set to
	table, it will be expressed as a ratio of
	the total sum of the table. The defaults is
	none which will not convert the sum to a
	ratio.
       
This optional attribute can be used to create a weighted sum. It should contain a numerical DLF field name. The content of that field will be used to multiply each field value before summing them.
<!ELEMENT %LIRE.sum;    EMPTY                                        >
<!ATTLIST %LIRE.sum;
             %name.attr.req;
	     %label.attr;
	     ratio	(none | group |table)              'none'
             field      NMTOKEN                            #REQUIRED 
	     weight	NMTOKEN				   #IMPLIED >
    The avg element calculate average of all
     value of a field in the group. The average will be computed
     either on the number of records if the
     by-field attribute is left empty, or by the
     number of different values that there are in the
     by-fields.
    
avg's attributes
An identifier that can be used to reference this operation from other elements. This name will most often be used in the parent's sort attribute.
Sets the column label that will be used for column generated by this element. If omitted a default label will be generated.
the field that should be averaged. If left unspecified the number of record will be counted.
the fields that will be used to dermine the count over which the average is computed.
This optional attribute can be used to create a weighted average. It should contain a numerical DLF field name. The content of that field will be used to multiply each field value before summing them. Its that weighted sum that will be used to calculate the average.
 
<!ELEMENT %LIRE.avg;    EMPTY                                        >
<!ATTLIST %LIRE.avg;
             %name.attr.req;
	     %label.attr;
             field      NMTOKEN                            #IMPLIED 
             by-fields  NMTOKENS                           #IMPLIED 
	     weight	NMTOKEN				   #IMPLIED >
    The max element calculates the maximum
     value for a field in all the group's records.
    
max's attributes
An identifier that can be used to reference this operation from other elements. This name will most often be used in the parent's sort attribute.
Sets the column label that will be used for column generated by this element. If omitted a default label will be generated.
the field for which the maximum value should found.
 
<!ELEMENT %LIRE.max;    EMPTY                                        >
<!ATTLIST %LIRE.max;
             %name.attr.req;
	     %label.attr;
             field      NMTOKEN                            #REQUIRED >
    The min element calculates the minimum
     value for a field in all the group's records.
    
min's attributes
An identifier that can be used to reference this operation from other elements. This name will most often be used in the parent's sort attribute.
Sets the column label that will be used for column generated by this element. If omitted a default label will be generated.
the field for which the minimum value should found.
 
<!ELEMENT %LIRE.min;    EMPTY                                        >
<!ATTLIST %LIRE.min;
             %name.attr.req;
	     %label.attr;
             field      NMTOKEN                            #REQUIRED >
    The first element will display the value
     of the value of one field of the first DLF record within its
     group. The sort order is controlled through the
     sort attribute..
    
first's attributes
An identifier that can be used to reference this operation from other elements. This name will most often be used in the parent's sort attribute.
Sets the column label that will be used for column generated by this element. If omitted a default label will be generated.
the DLF field which will be displayed.
whitespace delimited list of fields name that should used
	to sort the records. Field names can be prefixed by
	- to specify reverse sort order, otherwise
	ascending sort order is used. If this attribute is omitted,
	the records will be sort in ascending order of the default
	timestamp field.
       
 
<!ELEMENT %LIRE.first;    EMPTY                                        >
<!ATTLIST %LIRE.first;
             %name.attr.req;
	     %label.attr;
             field      NMTOKEN                            #REQUIRED 
             sort       NMTOKENS                           #IMPLIED  
	     >
    The last element will display the value
     of the value of one field of the last DLF record within its
     group. The sort order is controlled through the
     sort attribute..
    
last's attributes
An identifier that can be used to reference this operation from other elements. This name will most often be used in the parent's sort attribute.
Sets the column label that will be used for column generated by this element. If omitted a default label will be generated.
the DLF field which will be displayed.
whitespace delimited list of fields name that should used
	to sort the records. Field names can be prefixed by
	- to specify reverse sort order, otherwise
	ascending sort order is used. If this attribute is omitted,
	the records will be sort in ascending order of the default
	timestamp field.
       
 
<!ELEMENT %LIRE.last;    EMPTY                                        >
<!ATTLIST %LIRE.last;
             %name.attr.req;
	     %label.attr;
             field      NMTOKEN                            #REQUIRED 
             sort       NMTOKENS                           #IMPLIED  
	     >
    The count element counts the number of
     records in the group if the fields attribute
     is left empty. Otherwise, it will count the number of different
     values in the fields specified.
    
count's attributes
An identifier that can be used to reference this operation from other elements. This name will most often be used in the parent's sort attribute.
Sets the column label that will be used for column generated by this element. If omitted a default label will be generated.
Which fields to count. If unspecified all records in the group are counted. If not, only different fields' value will be counted.
This attribute can be used to display the frequency as a
	ratio of the group or table total. If the attribute is set to 
	group the resulting value will be the
	ratio on the group's total frequency. If the attribute is set
	to table, it will be expressed as a
	ratio of the total frequency of the table. The defaults is
	none which will not convert the frequency
	to a ratio.
       
<!ELEMENT %LIRE.count;  EMPTY                                        >
<!ATTLIST %LIRE.count;
             %name.attr.req;
             %label.attr;
	     ratio	(none | group |table)              'none'
             fields     NMTOKENS                           #IMPLIED  >
    The records element will put the content
     of selected fields in the report. This can be used in reports
     that shows events matching certain criteria. The fields that will
     be included in the report for each record is specified by the
     field element. 
    
records's attribute
whitespace delimited list of fields name that should included in the report.
<!ELEMENT %LIRE.records; EMPTY                                       >
<!ATTLIST %LIRE.records;
             fields      NMTOKENS                          #REQUIRED >