Ticket #18160: kea.patch

File kea.patch, 18.7 KB (added by thomas, 22 months ago)
  • TabularUnified general/genlib/genlib.xml

    diff --git a/general/genlib/genlib.xml b/general/genlib/genlib.xml
    index 9d755a0061..58ac2e9390 100644
    a b  
    143143<!-- systemd only -->
    144144<!--  <xi:include xmlns:xi="http://www.w3.org/2001/XInclude" href="libzeitgeist.xml"/> -->
    145145
     146  <xi:include xmlns:xi="http://www.w3.org/2001/XInclude" href="log4cplus.xml"/>
    146147  <xi:include xmlns:xi="http://www.w3.org/2001/XInclude" href="lzo.xml"/>
    147148  <xi:include xmlns:xi="http://www.w3.org/2001/XInclude" href="mtdev.xml"/>
    148149  <xi:include xmlns:xi="http://www.w3.org/2001/XInclude" href="nodejs.xml"/>
  • TabularUnified new file general/genlib/log4cplus.xml

    diff --git a/general/genlib/log4cplus.xml b/general/genlib/log4cplus.xml
    new file mode 100644
    index 0000000000..65faf1742c
    - +  
     1<?xml version="1.0" encoding="ISO-8859-1"?>
     2<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
     3   "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
     4  <!ENTITY % general-entities SYSTEM "../../general.ent">
     5  %general-entities;
     6
     7  <!ENTITY log4cplus-download-http "https://github.com/log4cplus/log4cplus/releases/download/REL_&log4cplus-release;/log4cplus-&log4cplus-version;.tar.xz">
     8  <!ENTITY log4cplus-download-ftp  " ">
     9  <!ENTITY log4cplus-md5sum        "62928d480ebec1476fe74b900f2a1672">
     10  <!ENTITY log4cplus-size          "919 KB">
     11  <!ENTITY log4cplus-buildsize     "72.4 MB">
     12  <!ENTITY log4cplus-time          "0.5 SBU">
     13]>
     14
     15<sect1 id="log4cplus" xreflabel="log4cplus-&log4cplus-version;">
     16  <?dbhtml filename="log4cplus.html"?>
     17
     18
     19  <title>log4cplus-&log4cplus-version;</title>
     20
     21  <indexterm zone="log4cplus">
     22    <primary sortas="a-log4cplus">log4cplus</primary>
     23  </indexterm>
     24
     25  <sect2 role="package">
     26    <title>Introduction to log4cplus</title>
     27
     28    <para>
     29      <application>log4cplus</application> is a simple to use C++20
     30      logging API providing thread--safe, flexible, and arbitrarily
     31      granular control over log management and configuration. It is
     32      modeled after the Java log4j API.
     33    </para>
     34
     35    &lfs113_checked;
     36
     37    <bridgehead renderas="sect3">Package Information</bridgehead>
     38    <itemizedlist spacing="compact">
     39      <listitem>
     40        <para>
     41          Download (HTTP): <ulink url="&log4cplus-download-http;"/>
     42        </para>
     43      </listitem>
     44      <listitem>
     45        <para>
     46          Download (FTP): <ulink url="&log4cplus-download-ftp;"/>
     47        </para>
     48      </listitem>
     49      <listitem>
     50        <para>
     51          Download MD5 sum: &log4cplus-md5sum;
     52        </para>
     53      </listitem>
     54      <listitem>
     55        <para>
     56          Download size: &log4cplus-size;
     57        </para>
     58      </listitem>
     59      <listitem>
     60        <para>
     61          Estimated disk space required: &log4cplus-buildsize;
     62        </para>
     63      </listitem>
     64      <listitem>
     65        <para>
     66          Estimated build time: &log4cplus-time;
     67        </para>
     68      </listitem>
     69    </itemizedlist>
     70
     71    <para condition="html" role="usernotes">User Notes:
     72      <ulink url="&blfs-wiki;/log4cplus"/>
     73    </para>
     74  </sect2>
     75
     76  <sect2 role="installation">
     77    <title>Installation of log4cplus</title>
     78
     79    <para>
     80      Build <application>log4cplus</application> by running the following
     81      command:
     82    </para>
     83
     84<screen><userinput>./configure --prefix=/usr &amp;&amp;
     85make</userinput></screen>
     86
     87    <para>
     88      To test the results, issue: <command>make check</command>.
     89    </para>
     90
     91    <para>
     92      Now, install the package as the
     93      <systemitem class="username">root</systemitem> user:
     94    </para>
     95
     96<screen role="root"><userinput>make install</userinput></screen>
     97
     98  </sect2>
     99
     100  <sect2 role="content">
     101    <title>Contents</title>
     102
     103    <segmentedlist>
     104      <segtitle>Installed Programs</segtitle>
     105      <segtitle>Installed Library</segtitle>
     106      <segtitle>Installed Directories</segtitle>
     107
     108      <seglistitem>
     109        <seg>
     110          None
     111        </seg>
     112        <seg>
     113          log4cplus.so
     114        </seg>
     115        <seg>
     116          None
     117        </seg>
     118      </seglistitem>
     119    </segmentedlist>
     120
     121    <variablelist>
     122      <bridgehead renderas="sect3">Short Descriptions</bridgehead>
     123      <?dbfo list-presentation="list"?>
     124      <?dbhtml list-presentation="table"?>
     125
     126      <varlistentry id="log4cplus-lib">
     127        <term><filename class="libraryfile">log4cplus.so</filename></term>
     128        <listitem>
     129          <para>
     130            is the log4cplus library
     131          </para>
     132          <indexterm zone="log4cplus log4cplus-lib">
     133            <primary sortas="c-log4cplus">log4cplus.so</primary>
     134          </indexterm>
     135        </listitem>
     136      </varlistentry>
     137
     138    </variablelist>
     139
     140  </sect2>
     141
     142</sect1>
  • TabularUnified networking/connect/connect.xml

    diff --git a/networking/connect/connect.xml b/networking/connect/connect.xml
    index 85705fc733..af8d2de88e 100644
    a b  
    3737
    3838  <xi:include xmlns:xi="http://www.w3.org/2001/XInclude" href="dhcpcd.xml"/>
    3939  <xi:include xmlns:xi="http://www.w3.org/2001/XInclude" href="dhcp.xml"/>
     40  <xi:include xmlns:xi="http://www.w3.org/2001/XInclude" href="kea.xml"/>
    4041
    4142</chapter>
  • TabularUnified new file networking/connect/kea.xml

    diff --git a/networking/connect/kea.xml b/networking/connect/kea.xml
    new file mode 100644
    index 0000000000..5f19ceac18
    - +  
     1<?xml version="1.0" encoding="ISO-8859-1"?>
     2<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
     3   "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
     4  <!ENTITY % general-entities SYSTEM "../../general.ent">
     5  %general-entities;
     6
     7  <!ENTITY kea-download-http "https://downloads.isc.org/isc/kea/&kea-dhcp-version;/kea-&kea-dhcp-version;.tar.gz">
     8  <!ENTITY kea-download-ftp  "ftp://ftp.isc.org/isc/kea/&kea-dhcp-version;/kea-&kea-dhcp-version;.tar.gz">
     9  <!ENTITY kea-md5sum        "a0dae4b38288cb8c6fca4ff71b9c9c73">
     10  <!ENTITY kea-size          "9.8 MB">
     11  <!ENTITY kea-buildsize     "1.9 GB">
     12  <!ENTITY kea-time          "5 SBU"> <!-- CHECK -->
     13]>
     14
     15<sect1 id="kea" xreflabel="KEA-&kea-dhcp-version;">
     16  <?dbhtml filename="kea.html"?>
     17
     18
     19  <title>Kea &kea-dhcp-version;</title>
     20
     21  <indexterm zone="kea">
     22    <primary sortas="a-KEA">Kea</primary>
     23  </indexterm>
     24
     25  <sect2 role="package">
     26    <title>Introduction to ISC Kea</title>
     27
     28    <para>
     29      The <application>ISC Kea</application> package contains the
     30      server programs for DHCP. It is the successor of the
     31      <xref linkend="dhcp"/> server which is end-of-life since December 2022.
     32    </para>
     33
     34    &lfs113_checked;
     35
     36    <bridgehead renderas="sect3">Package Information</bridgehead>
     37    <itemizedlist spacing="compact">
     38      <listitem>
     39        <para>
     40          Download (HTTP): <ulink url="&kea-download-http;"/>
     41        </para>
     42      </listitem>
     43      <listitem>
     44        <para>
     45          Download (FTP): <ulink url="&kea-download-ftp;"/>
     46        </para>
     47      </listitem>
     48      <listitem>
     49        <para>
     50          Download MD5 sum: &kea-md5sum;
     51        </para>
     52      </listitem>
     53      <listitem>
     54        <para>
     55          Download size: &kea-size;
     56        </para>
     57      </listitem>
     58      <listitem>
     59        <para>
     60          Estimated disk space required: &kea-buildsize;
     61        </para>
     62      </listitem>
     63      <listitem>
     64        <para>
     65          Estimated build time: &kea-time;
     66        </para>
     67      </listitem>
     68    </itemizedlist>
     69
     70    <bridgehead renderas="sect3">Kea Dependencies</bridgehead>
     71
     72    <bridgehead renderas="sect4">Required</bridgehead>
     73    <para role="required">
     74      <xref linkend="log4cplus"/>
     75    </para>
     76   
     77    <para condition="html" role="usernotes">User Notes:
     78      <ulink url="&blfs-wiki;/kea"/>
     79    </para>
     80  </sect2>
     81
     82  <sect2 role="kernel" id="kea-dhcp-kernel">
     83    <title>Kernel Configuration</title>
     84
     85    <para>
     86      You must have Packet Socket support. IPv6 support is optional.
     87    </para>
     88
     89<screen><literal>[*] Networking support ---&gt;        [CONFIG_NET]
     90      Networking options ---&gt;
     91        &lt;*&gt; Packet socket          [CONFIG_PACKET]
     92        &lt;*&gt; The IPv6 Protocol ---&gt; [CONFIG_IPV6]</literal></screen>
     93    <indexterm zone="kea kea-dhcp-kernel">
     94      <primary sortas="k-KEA">Kea</primary>
     95    </indexterm>
     96
     97  </sect2>
     98
     99  <sect2 role="installation">
     100    <title>Installation of ISC Kea DHCP</title>
     101
     102    <para>
     103      Install <application>ISC Kea DHCP</application> by running
     104      the following commands:
     105    </para>
     106
     107<screen><userinput>./configure --prefix=/usr        \
     108            --sysconfdir=/etc    \
     109            --docdir=/usr/share/doc/kea-&kea-dhcp-version; \
     110            --localstatedir=/var \
     111            --enable-shell       \
     112            --with-openssl &amp;&amp;
     113make</userinput></screen>
     114
     115    <para>
     116      To test the results, issue: <command>make check</command>.
     117    </para>
     118
     119    <para>
     120      To install the <application>ISC Kea DHCP</application> suite,
     121      issue the following commands as the
     122      <systemitem class="username">root</systemitem> user:
     123    </para>
     124
     125<screen role="root"><userinput>make -j1 install</userinput></screen>
     126
     127  </sect2>
     128
     129  <sect2 role="commands">
     130    <title>Command Explanations</title>
     131
     132    <para>
     133      <parameter>make -j1 install</parameter>: ISC doesn not recomment any form of
     134      parallel or job server options when doing the install.
     135    </para>
     136
     137  </sect2>
     138 
     139  <sect2 role="configuration">
     140    <title>Configuring ISC Kea DHCP</title>
     141
     142    <para>Consult the
     143    <ulink url="https://kea.readthedocs.io/en/kea-2.2.0/">Kea Administrator Reference Manual</ulink>
     144    for detailled information about the configuration of Kea.</para>
     145
     146    <para>The support of IPv4, IPv6 and DDNS has been splitted into
     147    separate servers which runs independently from each other. Each
     148    of them has its own configuration file. Additional configuration
     149    files come from the keactrl agent which is uses to control the
     150    servers in an easy way.</para>
     151   
     152    <sect3 id="kea-dhcp-config">
     153      <title>Config Files</title>
     154
     155      <para>
     156        <filename>/etc/kea/keactrl.conf</filename>,
     157        <filename>/etc/kea/kea-ctrl-agent.conf</filename>,
     158        <filename>/etc/kea/kea-dhcp4.conf</filename>,
     159        <filename>/etc/kea/kea-dhcp6.conf</filename> and
     160        <filename>/etc/kea/kea-dhcp-ddns.conf</filename>
     161      </para>
     162
     163      <indexterm zone="kea keactrl-config">
     164        <primary sortas="e-etc-kea-keactrl.conf">/etc/kea/keactrl.conf</primary>
     165      </indexterm>
     166<!--
     167      <indexterm zone="kea kea-ctrl-agent-config">
     168        <primary sortas="e-etc-kea-kea-ctrl-agent.conf">/etc/kea/kea-ctrl-agent.conf</primary>
     169      </indexterm>
     170-->
     171      <indexterm zone="kea kea-dhcp4-config">
     172        <primary sortas="e-etc-kea-dhcp4.conf">/etc/kea/kea-dhcp4.conf</primary>
     173      </indexterm>
     174<!--
     175      <indexterm zone="kea kea-dhcp6-config">
     176        <primary sortas="e-etc-kea-dhcp6.conf">/etc/kea/kea-dhcp6.conf</primary>
     177      </indexterm>
     178
     179      <indexterm zone="kea kea-dhcp-ddns-config">
     180        <primary sortas="e-etc-kea-dhcp-ddns.conf">/etc/kea/kea-dhcp-ddns.conf</primary>
     181      </indexterm>
     182-->
     183    </sect3>
     184
     185    <sect3 id="keactrl-config">
     186      <title>Kea Control Configuration</title>
     187
     188      <para><command>keactrl</command> is used to control the
     189      independend servers (IPv4, IPv6, DDNS). Its configuration file
     190      <filename>/etc/kea/keactrl.conf</filename> is installed by
     191      default and includes many path settings which are defined
     192      due to the <command>configure</command> at build time. It also
     193      includes settings to specify which of the servers should be
     194      started.</para>
     195
     196      <itemizedlist>
     197        <listitem>
     198          <para>IPv4 DHCP server</para>
     199          <para>This daemon handles requests for IPv4 addresses.
     200          Set <literal>dhcp4=yes</literal> to start it, set
     201          <literal>dhcp4=no</literal> in case DHCP service for IPv4
     202          is not wanted.</para>
     203        </listitem>
     204        <listitem>
     205          <para>IPv6 DHCP server</para>
     206          <para>This daemon handles requests for IPv6 addresses.
     207          Set <literal>dhcp6=yes</literal> to start it, set
     208          <literal>dhcp6=no</literal> in case DHCP service for IPv6
     209          is not wanted.</para>
     210        </listitem>
     211        <listitem>
     212          <para>Dynamic DNS</para>
     213          <para>This daemon is used to update a DNS server dynamically
     214          when Kea assignes an IP address to a device.
     215          Set <literal>dhcp_ddns=yes</literal> to enable it, set
     216          <literal>dhcp_ddns=no</literal> in case dynamic DNS updates
     217          are not wanted.</para>
     218        </listitem>
     219        <listitem>
     220          <para>Control Agent</para>
     221          <para>The Control Agent is a daemon which allows the
     222          (re)configuration of the Kea DHCP service via REST API.
     223          Set <literal>ctrl_agent=yes</literal> to start the
     224          control agent (service providing a REST API), set
     225          <literal>ctrl_agent=no</literal> in case the control agent
     226          is not wanted.</para>
     227        </listitem>
     228      </itemizedlist>
     229
     230      <para>The Netconf service is not installed because required
     231      dependencies are not covered by the current BLFS book.</para>
     232
     233      <para>With the following command, Kea will be configured to
     234      start the dhcp service for IPv4 and the
     235      dynamic DNS update, while the control agent and
     236      the dhcp service for IPv6 remains down. Tweak the command to
     237      match your needs on started services and execute as the
     238      <systemitem class="username">root</systemitem> user:</para>
     239
     240<screen><userinput role="root">sed -e "s/^dhcp4=.*/dhcp4=yes/" \
     241    -e "s/^dhcp6=.*/dhcp6=no/" \
     242    -e "s/^dhcp_ddns=.*/dhcp_ddns=yes/" \
     243    -e "s/^ctrl_agent=.*/ctrl_agent=no/" \
     244    -i /etc/kea/keactrl.conf
     245</userinput></screen>
     246
     247    </sect3>
     248
     249    <sect3 id="kea-dhcp4-config">
     250      <title>IPv4 Server Configuration</title>
     251
     252      <para>
     253        A sample configuration file is created in <filename>/etc/kea/kea-dhcpd4.conf</filename>.
     254        Adjust the file to suit your needs or overwrite it by using
     255        the following sample as the <systemitem class="username">root</systemitem>
     256        user:
     257      </para>
     258
     259<screen role="nodump" ><userinput>cat &gt; /etc/kea/kea-dhcpd4.conf &lt;&lt; "EOF"
     260<literal>// Begin /etc/kea/kea-dhcpd4.conf
     261{
     262"Dhcp4": {
     263    "interfaces-config": {
     264        "interfaces": [ "eth0" ]
     265    },
     266    "control-socket": {
     267        "socket-type": "unix",
     268        "socket-name": "/run/kea/kea4-ctrl-socket"
     269    },
     270    "lease-database": {
     271        "type": "memfile",
     272        "lfc-interval": 3600
     273    },
     274    "renew-timer": 900,
     275    "rebind-timer": 1800,
     276    "valid-lifetime": 3600,
     277    "option-data": [
     278        {
     279            "name": "domain-name-servers",
     280            "data": "192.168.2.1, 192.168.2.2"
     281        },
     282        {
     283            "name": "domain-search",
     284            "data": "mydomain.example.org, example.org"
     285        }
     286    ],
     287    "subnet4": [
     288        {
     289            "subnet": "192.168.2.0/24",
     290            "pools": [
     291                {
     292                    "pool": "192.168.2.16 - 192.168.2.64"
     293                }
     294            ],
     295            "option-data": [
     296                {
     297                    "name: "routers",
     298                    "value": "192.168.2.254"
     299                }
     300            ],
     301            "reservations": [
     302                {
     303                    "hw-address": "00:11:22:33:44:55",
     304                    "ip-address": "192.168.2.65",
     305                    "hostname": "host-2-65"
     306                },
     307                {
     308                    "hw-address": "00:00:00:00:00:01",
     309                    "ip-address": "192.168.2.253",
     310                    "hostname": "special-host",
     311                    "option-data": [
     312                        {
     313                            "name": "domain-name-servers",
     314                            "data": "192.168.1.1"
     315                        }
     316                    ]
     317                }
     318            ]
     319        }
     320    ]
     321}
     322}
     323// End /etc/kea/kea-dhcpd4.conf</literal>
     324EOF</userinput></screen>
     325
     326      <para>The configuration for IPv6 is similar to the configuration
     327      of IPv4. The configuration file is <filename>/etc/kea/kea-dhcpd6.conf</filename>.</para>
     328
     329      <para>
     330        If you want to start the DHCP Server at boot, install the
     331        <phrase revision="sysv"><filename>/etc/rc.d/init.d/kea-dhcpd</filename>
     332        init script</phrase>
     333        <phrase revision="systemd"><filename>kea-dhcpd.service</filename>
     334        unit</phrase> included in the
     335        <xref linkend="bootscripts" revision="sysv"/>
     336        <xref linkend="systemd-units" revision="systemd"/>
     337        package:
     338      </para>
     339
     340<screen role="root"><userinput>make install-kea-dhcpd</userinput></screen>
     341
     342    </sect3>
     343
     344  </sect2>
     345
     346  <sect2 role="content">
     347    <title>Contents</title>
     348
     349    <segmentedlist>
     350      <segtitle>Installed Programs</segtitle>
     351      <segtitle>Installed Libraries</segtitle>
     352      <segtitle>Installed Directories</segtitle>
     353
     354      <seglistitem>
     355        <seg>
     356          keactrl, kea-admin, kea-ctrl-agent, kea-dhcp4, kea-dhcp6,
     357          kea-dhcp-ddns, kea-lfc, kea-shell
     358        </seg>
     359        <seg>
     360          libkea-*
     361        </seg>
     362        <seg>
     363          /etc/kea,
     364          /usr/include/kea,
     365          /var/lib/kea
     366        </seg>
     367      </seglistitem>
     368    </segmentedlist>
     369
     370    <variablelist>
     371      <bridgehead renderas="sect3">Short Descriptions</bridgehead>
     372      <?dbfo list-presentation="list"?>
     373      <?dbhtml list-presentation="table"?>
     374
     375      <varlistentry id="keactrl">
     376        <term><command>keactrl</command></term>
     377        <listitem>
     378          <para>
     379            Tool to control the server processes
     380          </para>
     381          <indexterm zone="kea keactrl">
     382            <primary sortas="b-keactrl">keactrl</primary>
     383          </indexterm>
     384        </listitem>
     385      </varlistentry>
     386
     387      <!-- ... -->
     388
     389    </variablelist>
     390
     391  </sect2>
     392
     393</sect1>
  • TabularUnified packages.ent

    diff --git a/packages.ent b/packages.ent
    index 8e831b5d91..401f8d8849 100644
    a b to avoid building libxml2 twice, which is slow with all deps -->  
    171171<!ENTITY libxslt-version              "1.1.38">
    172172<!ENTITY libwacom-version             "2.7.0">
    173173<!ENTITY libwpe-version               "1.14.1">
     174<!ENTITY log4cplus-version            "2.1.0">
     175  <!ENTITY log4cplus-release          "2_1_0">
    174176<!ENTITY lzo-version                  "2.10">
    175177<!ENTITY mtdev-version                "1.1.6">
    176178<!ENTITY nodejs-version               "18.16.0">
    to avoid building libxml2 twice, which is slow with all deps -->  
    649651<!-- Chapter 14 -->
    650652<!ENTITY dhcpcd-version               "10.0.1">
    651653<!ENTITY dhcp-version                 "4.4.3-P1">
     654<!ENTITY kea-dhcp-version             "2.3.7">
    652655
    653656<!-- Chapter 15 -->
    654657<!ENTITY bridgeutils-version          "1.7.1">