|
1 ## |
|
2 ## uuid -- OpenPKG UUID Update Utility |
|
3 ## Copyright (c) 2000-2007 OpenPKG Foundation e.V. <http://openpkg.net/> |
|
4 ## Copyright (c) 2000-2007 Ralf S. Engelschall <http://engelschall.com/> |
|
5 ## |
|
6 ## Permission to use, copy, modify, and distribute this software for |
|
7 ## any purpose with or without fee is hereby granted, provided that |
|
8 ## the above copyright notice and this permission notice appear in all |
|
9 ## copies. |
|
10 ## |
|
11 ## THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED |
|
12 ## WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF |
|
13 ## MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. |
|
14 ## IN NO EVENT SHALL THE AUTHORS AND COPYRIGHT HOLDERS AND THEIR |
|
15 ## CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
|
16 ## SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
|
17 ## LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF |
|
18 ## USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND |
|
19 ## ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, |
|
20 ## OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT |
|
21 ## OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF |
|
22 ## SUCH DAMAGE. |
|
23 ## |
|
24 |
|
25 =pod |
|
26 |
|
27 =head1 NAME |
|
28 |
|
29 B<openpkg uuid> - OpenPKG UUID Update Utility |
|
30 |
|
31 =head1 SYNOPSIS |
|
32 |
|
33 B<openpkg uuid> [B<--verbose>] [B<--multicast>] B<reset>|B<update>|B<info> |
|
34 |
|
35 =head1 DESCRIPTION |
|
36 |
|
37 The B<openpkg uuid> command is the maintenance utility for the DCE 1.1 |
|
38 and ISO/IEC 11578:1996 compliant I<Universally Unique Identifiers> |
|
39 (UUID) of an B<OpenPKG> instance. It is internally based on B<OSSP |
|
40 uuid>. |
|
41 |
|
42 UUIDs are 128 bit numbers which are intended to have a high likelihood |
|
43 of uniqueness over space and time and are computationally difficult |
|
44 to guess. They are globally unique identifiers which can be locally |
|
45 generated without contacting a global registration authority. UUIDs are |
|
46 intended as unique identifiers for both mass tagging objects with an |
|
47 extremely short lifetime and to reliably identifying very persistent |
|
48 objects across a network. The three classical UUID variants are DCE 1.1 |
|
49 UUIDs of version 1 (time and node based), version 3 (name based) and |
|
50 version 4 (random number based). |
|
51 |
|
52 For an B<OpenPKG> instance, three different UUIDs are used: |
|
53 |
|
54 =over 3 |
|
55 |
|
56 =item 1. B<OpenPKG Registry> (C<UUID_REGISTRY>) |
|
57 |
|
58 This is a version 1 UUID which uniquely identifiers the B<OpenPKG> |
|
59 instance for global registration purposes. It is generated just once in |
|
60 the lifetime of the B<OpenPKG> instance. The value of this UUID cannot |
|
61 be recalculated deterministically. |
|
62 |
|
63 =item 2. B<OpenPKG Instance> (C<UUID_INSTANCE>) |
|
64 |
|
65 This is a version 3 UUID which summarizes the B<OpenPKG> |
|
66 instance parameters. Currently the values of the following |
|
67 particular OpenPKG RPM macros are uses as input: |
|
68 |
|
69 %{l_openpkg_release} %{l_prefix} |
|
70 %{l_susr} %{l_suid} %{l_sgrp} %{l_sgid} |
|
71 %{l_musr} %{l_muid} %{l_mgrp} %{l_mgid} |
|
72 %{l_rusr} %{l_ruid} %{l_rgrp} %{l_rgid} |
|
73 %{l_nusr} %{l_nuid} %{l_ngrp} %{l_ngid} |
|
74 |
|
75 The value of this UUID can be recalculated deterministically and will |
|
76 not chance as long as none of the values of the above macro do not |
|
77 change. This UUID can be used for detecting OpenPKG release upgrades, |
|
78 accidentally changed UIDs or GIDs, etc. Notice that version 3 UUIDs are |
|
79 message digests (actually MD5 based) and so are one-way functions which do |
|
80 not allow one to recalculate the input values from the UUID. |
|
81 |
|
82 =item 3. B<OpenPKG Platform> (C<UUID_PLATFORM>) |
|
83 |
|
84 This is a version 3 UUID which summarizes the B<OpenPKG> platform |
|
85 parameters. Currently the OpenPKG RPM platform id plus the FQDN and IP |
|
86 address of the underlying host are used as input. This UUID can be used |
|
87 for detecting operating system and host changes. Notice that version |
|
88 3 UUIDs are message digests (actually MD5 based) and so are one-way |
|
89 functions which do not allow one to recalculate the input values from |
|
90 the UUID. |
|
91 |
|
92 =back |
|
93 |
|
94 =head1 OPTIONS |
|
95 |
|
96 =over 4 |
|
97 |
|
98 =item B<--verbose> |
|
99 |
|
100 Print verbose messages during operation. |
|
101 |
|
102 =item B<--multicast> |
|
103 |
|
104 Generate a random multicast MAC address instead of using the real IEEE |
|
105 802 MAC address of the underlying host when generating the version 1 |
|
106 UUID C<UUID_REGISTRY>. |
|
107 |
|
108 =back |
|
109 |
|
110 =head1 COMMANDS |
|
111 |
|
112 =over 4 |
|
113 |
|
114 =item B<reset> |
|
115 |
|
116 This resets the three UUIDs C<UUID_REGISTRY>, C<UUID_INSTANCE> and |
|
117 C<UUID_PLATFORM> to the "Nil UUID". They are then automatically |
|
118 regenerated within one day if already done explicitly afterward with |
|
119 "C<openpkg uuid update>". |
|
120 |
|
121 =item B<update> |
|
122 |
|
123 This updates the three UUIDs C<UUID_REGISTRY>, C<UUID_INSTANCE> and |
|
124 C<UUID_PLATFORM> to the "Nil UUID". C<UUID_REGISTRY> is kept unless it |
|
125 is the "Nil UUID" (see "C<openpkg uuid reset>" command above). The UUIDs |
|
126 C<UUID_INSTANCE> and C<UUID_PLATFORM> are updated only if their input |
|
127 values (and this way the resulting UUIDs) have changed. This operation |
|
128 is performed daily automatically. |
|
129 |
|
130 =item B<info> |
|
131 |
|
132 This print summary page of identification information, including all |
|
133 UUIDs and all of their calculation inputs. |
|
134 |
|
135 =back |
|
136 |
|
137 =head1 FILES |
|
138 |
|
139 The three UUIDs of the B<OpenPKG> instance are stored in the file |
|
140 C<@l_prefix@/etc/openpkg/uuid> in Bourne-Shell syntax. An example |
|
141 content is: |
|
142 |
|
143 UUID_REGISTRY="81eca44e-4d18-11d8-a837-0090272ff725" |
|
144 UUID_INSTANCE="c55a8d2d-31bb-3ae0-9edb-68337af61acc" |
|
145 UUID_PLATFORM="05ec2532-9e3f-37dc-a7ed-b291c2c463ed" |
|
146 |
|
147 =head1 CAVEATS |
|
148 |
|
149 By default and in full compliance with DCE 1.1 and ISO/IEC 11578:1996, |
|
150 the OpenPKG Registry UUID (C<UUID_REGISTRY>) contains the IEEE 802 MAC |
|
151 address of the underlying host. If this is not acceptable by local |
|
152 security policies you can easily at any time generate a new OpenPKG |
|
153 Registry UUID with a random multicast MAC address instead by running: |
|
154 |
|
155 $ openpkg uuid reset |
|
156 $ openpkg uuid --multicast update |
|
157 |
|
158 =head1 SEE ALSO |
|
159 |
|
160 B<OSSP uuid> E<lt>http://www.ossp.org/pkg/lib/uuid/E<gt>. |
|
161 |
|
162 =head1 HISTORY |
|
163 |
|
164 The B<openpkg uuid> command first appeared in B<OpenPKG 2.0>. |
|
165 |
|
166 =cut |
|
167 |