EVP_RAND.7ossl 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401
  1. .\" Automatically generated by Pod::Man 4.14 (Pod::Simple 3.42)
  2. .\"
  3. .\" Standard preamble:
  4. .\" ========================================================================
  5. .de Sp \" Vertical space (when we can't use .PP)
  6. .if t .sp .5v
  7. .if n .sp
  8. ..
  9. .de Vb \" Begin verbatim text
  10. .ft CW
  11. .nf
  12. .ne \\$1
  13. ..
  14. .de Ve \" End verbatim text
  15. .ft R
  16. .fi
  17. ..
  18. .\" Set up some character translations and predefined strings. \*(-- will
  19. .\" give an unbreakable dash, \*(PI will give pi, \*(L" will give a left
  20. .\" double quote, and \*(R" will give a right double quote. \*(C+ will
  21. .\" give a nicer C++. Capital omega is used to do unbreakable dashes and
  22. .\" therefore won't be available. \*(C` and \*(C' expand to `' in nroff,
  23. .\" nothing in troff, for use with C<>.
  24. .tr \(*W-
  25. .ds C+ C\v'-.1v'\h'-1p'\s-2+\h'-1p'+\s0\v'.1v'\h'-1p'
  26. .ie n \{\
  27. . ds -- \(*W-
  28. . ds PI pi
  29. . if (\n(.H=4u)&(1m=24u) .ds -- \(*W\h'-12u'\(*W\h'-12u'-\" diablo 10 pitch
  30. . if (\n(.H=4u)&(1m=20u) .ds -- \(*W\h'-12u'\(*W\h'-8u'-\" diablo 12 pitch
  31. . ds L" ""
  32. . ds R" ""
  33. . ds C` ""
  34. . ds C' ""
  35. 'br\}
  36. .el\{\
  37. . ds -- \|\(em\|
  38. . ds PI \(*p
  39. . ds L" ``
  40. . ds R" ''
  41. . ds C`
  42. . ds C'
  43. 'br\}
  44. .\"
  45. .\" Escape single quotes in literal strings from groff's Unicode transform.
  46. .ie \n(.g .ds Aq \(aq
  47. .el .ds Aq '
  48. .\"
  49. .\" If the F register is >0, we'll generate index entries on stderr for
  50. .\" titles (.TH), headers (.SH), subsections (.SS), items (.Ip), and index
  51. .\" entries marked with X<> in POD. Of course, you'll have to process the
  52. .\" output yourself in some meaningful fashion.
  53. .\"
  54. .\" Avoid warning from groff about undefined register 'F'.
  55. .de IX
  56. ..
  57. .nr rF 0
  58. .if \n(.g .if rF .nr rF 1
  59. .if (\n(rF:(\n(.g==0)) \{\
  60. . if \nF \{\
  61. . de IX
  62. . tm Index:\\$1\t\\n%\t"\\$2"
  63. ..
  64. . if !\nF==2 \{\
  65. . nr % 0
  66. . nr F 2
  67. . \}
  68. . \}
  69. .\}
  70. .rr rF
  71. .\"
  72. .\" Accent mark definitions (@(#)ms.acc 1.5 88/02/08 SMI; from UCB 4.2).
  73. .\" Fear. Run. Save yourself. No user-serviceable parts.
  74. . \" fudge factors for nroff and troff
  75. .if n \{\
  76. . ds #H 0
  77. . ds #V .8m
  78. . ds #F .3m
  79. . ds #[ \f1
  80. . ds #] \fP
  81. .\}
  82. .if t \{\
  83. . ds #H ((1u-(\\\\n(.fu%2u))*.13m)
  84. . ds #V .6m
  85. . ds #F 0
  86. . ds #[ \&
  87. . ds #] \&
  88. .\}
  89. . \" simple accents for nroff and troff
  90. .if n \{\
  91. . ds ' \&
  92. . ds ` \&
  93. . ds ^ \&
  94. . ds , \&
  95. . ds ~ ~
  96. . ds /
  97. .\}
  98. .if t \{\
  99. . ds ' \\k:\h'-(\\n(.wu*8/10-\*(#H)'\'\h"|\\n:u"
  100. . ds ` \\k:\h'-(\\n(.wu*8/10-\*(#H)'\`\h'|\\n:u'
  101. . ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'^\h'|\\n:u'
  102. . ds , \\k:\h'-(\\n(.wu*8/10)',\h'|\\n:u'
  103. . ds ~ \\k:\h'-(\\n(.wu-\*(#H-.1m)'~\h'|\\n:u'
  104. . ds / \\k:\h'-(\\n(.wu*8/10-\*(#H)'\z\(sl\h'|\\n:u'
  105. .\}
  106. . \" troff and (daisy-wheel) nroff accents
  107. .ds : \\k:\h'-(\\n(.wu*8/10-\*(#H+.1m+\*(#F)'\v'-\*(#V'\z.\h'.2m+\*(#F'.\h'|\\n:u'\v'\*(#V'
  108. .ds 8 \h'\*(#H'\(*b\h'-\*(#H'
  109. .ds o \\k:\h'-(\\n(.wu+\w'\(de'u-\*(#H)/2u'\v'-.3n'\*(#[\z\(de\v'.3n'\h'|\\n:u'\*(#]
  110. .ds d- \h'\*(#H'\(pd\h'-\w'~'u'\v'-.25m'\f2\(hy\fP\v'.25m'\h'-\*(#H'
  111. .ds D- D\\k:\h'-\w'D'u'\v'-.11m'\z\(hy\v'.11m'\h'|\\n:u'
  112. .ds th \*(#[\v'.3m'\s+1I\s-1\v'-.3m'\h'-(\w'I'u*2/3)'\s-1o\s+1\*(#]
  113. .ds Th \*(#[\s+2I\s-2\h'-\w'I'u*3/5'\v'-.3m'o\v'.3m'\*(#]
  114. .ds ae a\h'-(\w'a'u*4/10)'e
  115. .ds Ae A\h'-(\w'A'u*4/10)'E
  116. . \" corrections for vroff
  117. .if v .ds ~ \\k:\h'-(\\n(.wu*9/10-\*(#H)'\s-2\u~\d\s+2\h'|\\n:u'
  118. .if v .ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'\v'-.4m'^\v'.4m'\h'|\\n:u'
  119. . \" for low resolution devices (crt and lpr)
  120. .if \n(.H>23 .if \n(.V>19 \
  121. \{\
  122. . ds : e
  123. . ds 8 ss
  124. . ds o a
  125. . ds d- d\h'-1'\(ga
  126. . ds D- D\h'-1'\(hy
  127. . ds th \o'bp'
  128. . ds Th \o'LP'
  129. . ds ae ae
  130. . ds Ae AE
  131. .\}
  132. .rm #[ #] #H #V #F C
  133. .\" ========================================================================
  134. .\"
  135. .IX Title "EVP_RAND 7ossl"
  136. .TH EVP_RAND 7ossl "2024-09-03" "3.3.2" "OpenSSL"
  137. .\" For nroff, turn off justification. Always turn off hyphenation; it makes
  138. .\" way too many mistakes in technical documents.
  139. .if n .ad l
  140. .nh
  141. .SH "NAME"
  142. EVP_RAND \- the random bit generator
  143. .SH "SYNOPSIS"
  144. .IX Header "SYNOPSIS"
  145. .Vb 2
  146. \& #include <openssl/evp.h>
  147. \& #include <rand.h>
  148. .Ve
  149. .SH "DESCRIPTION"
  150. .IX Header "DESCRIPTION"
  151. The default OpenSSL \s-1RAND\s0 method is based on the \s-1EVP_RAND\s0 classes to provide
  152. non-deterministic inputs to other cryptographic algorithms.
  153. .PP
  154. While the \s-1RAND API\s0 is the 'frontend' which is intended to be used by
  155. application developers for obtaining random bytes, the \s-1EVP_RAND API\s0
  156. serves as the 'backend', connecting the former with the operating
  157. systems's entropy sources and providing access to deterministic random
  158. bit generators (\s-1DRBG\s0) and their configuration parameters.
  159. A \s-1DRBG\s0 is a certain type of cryptographically-secure pseudo-random
  160. number generator (\s-1CSPRNG\s0), which is described in
  161. [\s-1NIST SP 800\-90A\s0 Rev. 1].
  162. .SS "Disclaimer"
  163. .IX Subsection "Disclaimer"
  164. Unless you have very specific requirements for your random generator,
  165. it is in general not necessary to utilize the \s-1EVP_RAND API\s0 directly.
  166. The usual way to obtain random bytes is to use \fBRAND_bytes\fR\|(3) or
  167. \&\fBRAND_priv_bytes\fR\|(3), see also \s-1\fBRAND\s0\fR\|(7).
  168. .SS "Typical Use Cases"
  169. .IX Subsection "Typical Use Cases"
  170. Typical examples for such special use cases are the following:
  171. .IP "\(bu" 2
  172. You want to use your own private \s-1DRBG\s0 instances.
  173. Multiple \s-1DRBG\s0 instances which are accessed only by a single thread provide
  174. additional security (because their internal states are independent) and
  175. better scalability in multithreaded applications (because they don't need
  176. to be locked).
  177. .IP "\(bu" 2
  178. You need to integrate a previously unsupported entropy source.
  179. Refer to \fBprovider\-rand\fR\|(7) for the implementation details to support adding
  180. randomness sources to \s-1EVP_RAND.\s0
  181. .IP "\(bu" 2
  182. You need to change the default settings of the standard OpenSSL \s-1RAND\s0
  183. implementation to meet specific requirements.
  184. .SH "EVP_RAND CHAINING"
  185. .IX Header "EVP_RAND CHAINING"
  186. An \s-1EVP_RAND\s0 instance can be used as the entropy source of another
  187. \&\s-1EVP_RAND\s0 instance, provided it has itself access to a valid entropy source.
  188. The \s-1EVP_RAND\s0 instance which acts as entropy source is called the \fIparent\fR,
  189. the other instance the \fIchild\fR. Typically, the child will be a \s-1DRBG\s0 because
  190. it does not make sense for the child to be an entropy source.
  191. .PP
  192. This is called chaining. A chained \s-1EVP_RAND\s0 instance is created by passing
  193. a pointer to the parent \s-1EVP_RAND_CTX\s0 as argument to the \fBEVP_RAND_CTX_new()\fR call.
  194. It is possible to create chains of more than two \s-1DRBG\s0 in a row.
  195. It is also possible to use any \s-1EVP_RAND_CTX\s0 class as the parent, however, only
  196. a live entropy source may ignore and not use its parent.
  197. .SH "THE THREE SHARED DRBG INSTANCES"
  198. .IX Header "THE THREE SHARED DRBG INSTANCES"
  199. Currently, there are three shared \s-1DRBG\s0 instances,
  200. the <primary>, <public>, and <private> \s-1DRBG.\s0
  201. While the <primary> \s-1DRBG\s0 is a single global instance, the <public> and <private>
  202. \&\s-1DRBG\s0 are created per thread and accessed through thread-local storage.
  203. .PP
  204. By default, the functions \fBRAND_bytes\fR\|(3) and \fBRAND_priv_bytes\fR\|(3) use
  205. the thread-local <public> and <private> \s-1DRBG\s0 instance, respectively.
  206. .SS "The <primary> \s-1DRBG\s0 instance"
  207. .IX Subsection "The <primary> DRBG instance"
  208. The <primary> \s-1DRBG\s0 is not used directly by the application, only for reseeding
  209. the two other two \s-1DRBG\s0 instances. It reseeds itself by obtaining randomness
  210. either from os entropy sources or by consuming randomness which was added
  211. previously by \fBRAND_add\fR\|(3).
  212. .SS "The <public> \s-1DRBG\s0 instance"
  213. .IX Subsection "The <public> DRBG instance"
  214. This instance is used per default by \fBRAND_bytes\fR\|(3).
  215. .SS "The <private> \s-1DRBG\s0 instance"
  216. .IX Subsection "The <private> DRBG instance"
  217. This instance is used per default by \fBRAND_priv_bytes\fR\|(3)
  218. .SH "LOCKING"
  219. .IX Header "LOCKING"
  220. The <primary> \s-1DRBG\s0 is intended to be accessed concurrently for reseeding
  221. by its child \s-1DRBG\s0 instances. The necessary locking is done internally.
  222. It is \fInot\fR thread-safe to access the <primary> \s-1DRBG\s0 directly via the
  223. \&\s-1EVP_RAND\s0 interface.
  224. The <public> and <private> \s-1DRBG\s0 are thread-local, i.e. there is an
  225. instance of each per thread. So they can safely be accessed without
  226. locking via the \s-1EVP_RAND\s0 interface.
  227. .PP
  228. Pointers to these \s-1DRBG\s0 instances can be obtained using
  229. \&\fBRAND_get0_primary()\fR, \fBRAND_get0_public()\fR and \fBRAND_get0_private()\fR, respectively.
  230. Note that it is not allowed to store a pointer to one of the thread-local
  231. \&\s-1DRBG\s0 instances in a variable or other memory location where it will be
  232. accessed and used by multiple threads.
  233. .PP
  234. All other \s-1DRBG\s0 instances created by an application don't support locking,
  235. because they are intended to be used by a single thread.
  236. Instead of accessing a single \s-1DRBG\s0 instance concurrently from different
  237. threads, it is recommended to instantiate a separate \s-1DRBG\s0 instance per
  238. thread. Using the <primary> \s-1DRBG\s0 as entropy source for multiple \s-1DRBG\s0
  239. instances on different threads is thread-safe, because the \s-1DRBG\s0 instance
  240. will lock the <primary> \s-1DRBG\s0 automatically for obtaining random input.
  241. .SH "THE OVERALL PICTURE"
  242. .IX Header "THE OVERALL PICTURE"
  243. The following picture gives an overview over how the \s-1DRBG\s0 instances work
  244. together and are being used.
  245. .PP
  246. .Vb 10
  247. \& +\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-+
  248. \& | os entropy sources |
  249. \& +\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-+
  250. \& |
  251. \& v +\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-+
  252. \& RAND_add() ==> <primary> <\-| shared DRBG (with locking) |
  253. \& / \e +\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-+
  254. \& / \e +\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-+
  255. \& <public> <private> <\- | per\-thread DRBG instances |
  256. \& | | +\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-+
  257. \& v v
  258. \& RAND_bytes() RAND_priv_bytes()
  259. \& | ^
  260. \& | |
  261. \& +\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-+ +\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-+
  262. \& | general purpose | | used for secrets like session keys |
  263. \& | random generator | | and private keys for certificates |
  264. \& +\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-+ +\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-+
  265. .Ve
  266. .PP
  267. The usual way to obtain random bytes is to call RAND_bytes(...) or
  268. RAND_priv_bytes(...). These calls are roughly equivalent to calling
  269. EVP_RAND_generate(<public>, ...) and
  270. EVP_RAND_generate(<private>, ...),
  271. respectively.
  272. .SH "RESEEDING"
  273. .IX Header "RESEEDING"
  274. A \s-1DRBG\s0 instance seeds itself automatically, pulling random input from
  275. its entropy source. The entropy source can be either a trusted operating
  276. system entropy source, or another \s-1DRBG\s0 with access to such a source.
  277. .PP
  278. Automatic reseeding occurs after a predefined number of generate requests.
  279. The selection of the trusted entropy sources is configured at build
  280. time using the \-\-with\-rand\-seed option. The following sections explain
  281. the reseeding process in more detail.
  282. .SS "Automatic Reseeding"
  283. .IX Subsection "Automatic Reseeding"
  284. Before satisfying a generate request (\fBEVP_RAND_generate\fR\|(3)), the \s-1DRBG\s0
  285. reseeds itself automatically, if one of the following conditions holds:
  286. .PP
  287. \&\- the \s-1DRBG\s0 was not instantiated (=seeded) yet or has been uninstantiated.
  288. .PP
  289. \&\- the number of generate requests since the last reseeding exceeds a
  290. certain threshold, the so called \fIreseed_interval\fR.
  291. This behaviour can be disabled by setting the \fIreseed_interval\fR to 0.
  292. .PP
  293. \&\- the time elapsed since the last reseeding exceeds a certain time
  294. interval, the so called \fIreseed_time_interval\fR.
  295. This can be disabled by setting the \fIreseed_time_interval\fR to 0.
  296. .PP
  297. \&\- the \s-1DRBG\s0 is in an error state.
  298. .PP
  299. \&\fBNote\fR: An error state is entered if the entropy source fails while
  300. the \s-1DRBG\s0 is seeding or reseeding.
  301. The last case ensures that the \s-1DRBG\s0 automatically recovers
  302. from the error as soon as the entropy source is available again.
  303. .SS "Manual Reseeding"
  304. .IX Subsection "Manual Reseeding"
  305. In addition to automatic reseeding, the caller can request an immediate
  306. reseeding of the \s-1DRBG\s0 with fresh entropy by setting the
  307. \&\fIprediction resistance\fR parameter to 1 when calling
  308. \&\fBEVP_RAND_generate\fR\|(3).
  309. .PP
  310. The document [\s-1NIST SP 800\-90C\s0] describes prediction resistance requests
  311. in detail and imposes strict conditions on the entropy sources that are
  312. approved for providing prediction resistance.
  313. A request for prediction resistance can only be satisfied by pulling fresh
  314. entropy from a live entropy source (section 5.5.2 of [\s-1NIST SP 800\-90C\s0]).
  315. It is up to the user to ensure that a live entropy source is configured
  316. and is being used.
  317. .PP
  318. For the three shared DRBGs (and only for these) there is another way to
  319. reseed them manually:
  320. If \fBRAND_add\fR\|(3) is called with a positive \fIrandomness\fR argument
  321. (or \fBRAND_seed\fR\|(3)), then this will immediately reseed the <primary> \s-1DRBG.\s0
  322. The <public> and <private> \s-1DRBG\s0 will detect this on their next generate
  323. call and reseed, pulling randomness from <primary>.
  324. .PP
  325. The last feature has been added to support the common practice used with
  326. previous OpenSSL versions to call \fBRAND_add()\fR before calling \fBRAND_bytes()\fR.
  327. .SS "Entropy Input and Additional Data"
  328. .IX Subsection "Entropy Input and Additional Data"
  329. The \s-1DRBG\s0 distinguishes two different types of random input: \fIentropy\fR,
  330. which comes from a trusted source, and \fIadditional input\fR',
  331. which can optionally be added by the user and is considered untrusted.
  332. It is possible to add \fIadditional input\fR not only during reseeding,
  333. but also for every generate request.
  334. .SS "Configuring the Random Seed Source"
  335. .IX Subsection "Configuring the Random Seed Source"
  336. In most cases OpenSSL will automatically choose a suitable seed source
  337. for automatically seeding and reseeding its <primary> \s-1DRBG.\s0 In some cases
  338. however, it will be necessary to explicitly specify a seed source during
  339. configuration, using the \-\-with\-rand\-seed option. For more information,
  340. see the \s-1INSTALL\s0 instructions. There are also operating systems where no
  341. seed source is available and automatic reseeding is disabled by default.
  342. .PP
  343. The following two sections describe the reseeding process of the primary
  344. \&\s-1DRBG,\s0 depending on whether automatic reseeding is available or not.
  345. .SS "Reseeding the primary \s-1DRBG\s0 with automatic seeding enabled"
  346. .IX Subsection "Reseeding the primary DRBG with automatic seeding enabled"
  347. Calling \fBRAND_poll()\fR or \fBRAND_add()\fR is not necessary, because the \s-1DRBG\s0
  348. pulls the necessary entropy from its source automatically.
  349. However, both calls are permitted, and do reseed the \s-1RNG.\s0
  350. .PP
  351. \&\fBRAND_add()\fR can be used to add both kinds of random input, depending on the
  352. value of the \fIrandomness\fR argument:
  353. .IP "randomness == 0:" 4
  354. .IX Item "randomness == 0:"
  355. The random bytes are mixed as additional input into the current state of
  356. the \s-1DRBG.\s0
  357. Mixing in additional input is not considered a full reseeding, hence the
  358. reseed counter is not reset.
  359. .IP "randomness > 0:" 4
  360. .IX Item "randomness > 0:"
  361. The random bytes are used as entropy input for a full reseeding
  362. (resp. reinstantiation) if the \s-1DRBG\s0 is instantiated
  363. (resp. uninstantiated or in an error state).
  364. The number of random bits required for reseeding is determined by the
  365. security strength of the \s-1DRBG.\s0 Currently it defaults to 256 bits (32 bytes).
  366. It is possible to provide less randomness than required.
  367. In this case the missing randomness will be obtained by pulling random input
  368. from the trusted entropy sources.
  369. .PP
  370. \&\s-1NOTE:\s0 Manual reseeding is *not allowed* in \s-1FIPS\s0 mode, because
  371. [\s-1NIST\s0 SP\-800\-90Ar1] mandates that entropy *shall not* be provided by
  372. the consuming application for instantiation (Section 9.1) or
  373. reseeding (Section 9.2). For that reason, the \fIrandomness\fR
  374. argument is ignored and the random bytes provided by the \fBRAND_add\fR\|(3) and
  375. \&\fBRAND_seed\fR\|(3) calls are treated as additional data.
  376. .SS "Reseeding the primary \s-1DRBG\s0 with automatic seeding disabled"
  377. .IX Subsection "Reseeding the primary DRBG with automatic seeding disabled"
  378. Calling \fBRAND_poll()\fR will always fail.
  379. .PP
  380. \&\fBRAND_add()\fR needs to be called for initial seeding and periodic reseeding.
  381. At least 48 bytes (384 bits) of randomness have to be provided, otherwise
  382. the (re\-)seeding of the \s-1DRBG\s0 will fail. This corresponds to one and a half
  383. times the security strength of the \s-1DRBG.\s0 The extra half is used for the
  384. nonce during instantiation.
  385. .PP
  386. More precisely, the number of bytes needed for seeding depend on the
  387. \&\fIsecurity strength\fR of the \s-1DRBG,\s0 which is set to 256 by default.
  388. .SH "SEE ALSO"
  389. .IX Header "SEE ALSO"
  390. \&\s-1\fBRAND\s0\fR\|(7), \s-1\fBEVP_RAND\s0\fR\|(3)
  391. .SH "HISTORY"
  392. .IX Header "HISTORY"
  393. This functionality was added in OpenSSL 3.0.
  394. .SH "COPYRIGHT"
  395. .IX Header "COPYRIGHT"
  396. Copyright 2017\-2020 The OpenSSL Project Authors. All Rights Reserved.
  397. .PP
  398. Licensed under the Apache License 2.0 (the \*(L"License\*(R"). You may not use
  399. this file except in compliance with the License. You can obtain a copy
  400. in the file \s-1LICENSE\s0 in the source distribution or at
  401. <https://www.openssl.org/source/license.html>.