config.5 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604
  1. .\" Automatically generated by Pod::Man 4.11 (Pod::Simple 3.35)
  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 "CONFIG 5"
  136. .TH CONFIG 5 "2022-03-15" "1.1.1n" "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. config \- OpenSSL CONF library configuration files
  143. .SH "DESCRIPTION"
  144. .IX Header "DESCRIPTION"
  145. The OpenSSL \s-1CONF\s0 library can be used to read configuration files.
  146. It is used for the OpenSSL master configuration file \fBopenssl.cnf\fR
  147. and in a few other places like \fB\s-1SPKAC\s0\fR files and certificate extension
  148. files for the \fBx509\fR utility. OpenSSL applications can also use the
  149. \&\s-1CONF\s0 library for their own purposes.
  150. .PP
  151. A configuration file is divided into a number of sections. Each section
  152. starts with a line \fB[ section_name ]\fR and ends when a new section is
  153. started or end of file is reached. A section name can consist of
  154. alphanumeric characters and underscores.
  155. .PP
  156. The first section of a configuration file is special and is referred
  157. to as the \fBdefault\fR section. This section is usually unnamed and spans from the
  158. start of file until the first named section. When a name is being looked up
  159. it is first looked up in a named section (if any) and then the
  160. default section.
  161. .PP
  162. The environment is mapped onto a section called \fB\s-1ENV\s0\fR.
  163. .PP
  164. Comments can be included by preceding them with the \fB#\fR character
  165. .PP
  166. Other files can be included using the \fB.include\fR directive followed
  167. by a path. If the path points to a directory all files with
  168. names ending with \fB.cnf\fR or \fB.conf\fR are included from the directory.
  169. Recursive inclusion of directories from files in such directory is not
  170. supported. That means the files in the included directory can also contain
  171. \&\fB.include\fR directives but only inclusion of regular files is supported
  172. there. The inclusion of directories is not supported on systems without
  173. \&\s-1POSIX IO\s0 support.
  174. .PP
  175. It is strongly recommended to use absolute paths with the \fB.include\fR
  176. directive. Relative paths are evaluated based on the application current
  177. working directory so unless the configuration file containing the
  178. \&\fB.include\fR directive is application specific the inclusion will not
  179. work as expected.
  180. .PP
  181. There can be optional \fB=\fR character and whitespace characters between
  182. \&\fB.include\fR directive and the path which can be useful in cases the
  183. configuration file needs to be loaded by old OpenSSL versions which do
  184. not support the \fB.include\fR syntax. They would bail out with error
  185. if the \fB=\fR character is not present but with it they just ignore
  186. the include.
  187. .PP
  188. Each section in a configuration file consists of a number of name and
  189. value pairs of the form \fBname=value\fR
  190. .PP
  191. The \fBname\fR string can contain any alphanumeric characters as well as
  192. a few punctuation symbols such as \fB.\fR \fB,\fR \fB;\fR and \fB_\fR.
  193. .PP
  194. The \fBvalue\fR string consists of the string following the \fB=\fR character
  195. until end of line with any leading and trailing white space removed.
  196. .PP
  197. The value string undergoes variable expansion. This can be done by
  198. including the form \fB\f(CB$var\fB\fR or \fB${var}\fR: this will substitute the value
  199. of the named variable in the current section. It is also possible to
  200. substitute a value from another section using the syntax \fB\f(CB$section::name\fB\fR
  201. or \fB${section::name}\fR. By using the form \fB\f(CB$ENV::name\fB\fR environment
  202. variables can be substituted. It is also possible to assign values to
  203. environment variables by using the name \fBENV::name\fR, this will work
  204. if the program looks up environment variables using the \fB\s-1CONF\s0\fR library
  205. instead of calling \fBgetenv()\fR directly. The value string must not exceed 64k in
  206. length after variable expansion. Otherwise an error will occur.
  207. .PP
  208. It is possible to escape certain characters by using any kind of quote
  209. or the \fB\e\fR character. By making the last character of a line a \fB\e\fR
  210. a \fBvalue\fR string can be spread across multiple lines. In addition
  211. the sequences \fB\en\fR, \fB\er\fR, \fB\eb\fR and \fB\et\fR are recognized.
  212. .PP
  213. All expansion and escape rules as described above that apply to \fBvalue\fR
  214. also apply to the path of the \fB.include\fR directive.
  215. .SH "OPENSSL LIBRARY CONFIGURATION"
  216. .IX Header "OPENSSL LIBRARY CONFIGURATION"
  217. Applications can automatically configure certain
  218. aspects of OpenSSL using the master OpenSSL configuration file, or optionally
  219. an alternative configuration file. The \fBopenssl\fR utility includes this
  220. functionality: any sub command uses the master OpenSSL configuration file
  221. unless an option is used in the sub command to use an alternative configuration
  222. file.
  223. .PP
  224. To enable library configuration the default section needs to contain an
  225. appropriate line which points to the main configuration section. The default
  226. name is \fBopenssl_conf\fR which is used by the \fBopenssl\fR utility. Other
  227. applications may use an alternative name such as \fBmyapplication_conf\fR.
  228. All library configuration lines appear in the default section at the start
  229. of the configuration file.
  230. .PP
  231. The configuration section should consist of a set of name value pairs which
  232. contain specific module configuration information. The \fBname\fR represents
  233. the name of the \fIconfiguration module\fR. The meaning of the \fBvalue\fR is
  234. module specific: it may, for example, represent a further configuration
  235. section containing configuration module specific information. E.g.:
  236. .PP
  237. .Vb 2
  238. \& # This must be in the default section
  239. \& openssl_conf = openssl_init
  240. \&
  241. \& [openssl_init]
  242. \&
  243. \& oid_section = new_oids
  244. \& engines = engine_section
  245. \&
  246. \& [new_oids]
  247. \&
  248. \& ... new oids here ...
  249. \&
  250. \& [engine_section]
  251. \&
  252. \& ... engine stuff here ...
  253. .Ve
  254. .PP
  255. The features of each configuration module are described below.
  256. .SS "\s-1ASN1\s0 Object Configuration Module"
  257. .IX Subsection "ASN1 Object Configuration Module"
  258. This module has the name \fBoid_section\fR. The value of this variable points
  259. to a section containing name value pairs of OIDs: the name is the \s-1OID\s0 short
  260. and long name, the value is the numerical form of the \s-1OID.\s0 Although some of
  261. the \fBopenssl\fR utility sub commands already have their own \s-1ASN1 OBJECT\s0 section
  262. functionality not all do. By using the \s-1ASN1 OBJECT\s0 configuration module
  263. \&\fBall\fR the \fBopenssl\fR utility sub commands can see the new objects as well
  264. as any compliant applications. For example:
  265. .PP
  266. .Vb 1
  267. \& [new_oids]
  268. \&
  269. \& some_new_oid = 1.2.3.4
  270. \& some_other_oid = 1.2.3.5
  271. .Ve
  272. .PP
  273. It is also possible to set the value to the long name followed
  274. by a comma and the numerical \s-1OID\s0 form. For example:
  275. .PP
  276. .Vb 1
  277. \& shortName = some object long name, 1.2.3.4
  278. .Ve
  279. .SS "Engine Configuration Module"
  280. .IX Subsection "Engine Configuration Module"
  281. This \s-1ENGINE\s0 configuration module has the name \fBengines\fR. The value of this
  282. variable points to a section containing further \s-1ENGINE\s0 configuration
  283. information.
  284. .PP
  285. The section pointed to by \fBengines\fR is a table of engine names (though see
  286. \&\fBengine_id\fR below) and further sections containing configuration information
  287. specific to each \s-1ENGINE.\s0
  288. .PP
  289. Each \s-1ENGINE\s0 specific section is used to set default algorithms, load
  290. dynamic, perform initialization and send ctrls. The actual operation performed
  291. depends on the \fIcommand\fR name which is the name of the name value pair. The
  292. currently supported commands are listed below.
  293. .PP
  294. For example:
  295. .PP
  296. .Vb 1
  297. \& [engine_section]
  298. \&
  299. \& # Configure ENGINE named "foo"
  300. \& foo = foo_section
  301. \& # Configure ENGINE named "bar"
  302. \& bar = bar_section
  303. \&
  304. \& [foo_section]
  305. \& ... foo ENGINE specific commands ...
  306. \&
  307. \& [bar_section]
  308. \& ... "bar" ENGINE specific commands ...
  309. .Ve
  310. .PP
  311. The command \fBengine_id\fR is used to give the \s-1ENGINE\s0 name. If used this
  312. command must be first. For example:
  313. .PP
  314. .Vb 3
  315. \& [engine_section]
  316. \& # This would normally handle an ENGINE named "foo"
  317. \& foo = foo_section
  318. \&
  319. \& [foo_section]
  320. \& # Override default name and use "myfoo" instead.
  321. \& engine_id = myfoo
  322. .Ve
  323. .PP
  324. The command \fBdynamic_path\fR loads and adds an \s-1ENGINE\s0 from the given path. It
  325. is equivalent to sending the ctrls \fB\s-1SO_PATH\s0\fR with the path argument followed
  326. by \fB\s-1LIST_ADD\s0\fR with value 2 and \fB\s-1LOAD\s0\fR to the dynamic \s-1ENGINE.\s0 If this is
  327. not the required behaviour then alternative ctrls can be sent directly
  328. to the dynamic \s-1ENGINE\s0 using ctrl commands.
  329. .PP
  330. The command \fBinit\fR determines whether to initialize the \s-1ENGINE.\s0 If the value
  331. is \fB0\fR the \s-1ENGINE\s0 will not be initialized, if \fB1\fR and attempt it made to
  332. initialized the \s-1ENGINE\s0 immediately. If the \fBinit\fR command is not present
  333. then an attempt will be made to initialize the \s-1ENGINE\s0 after all commands in
  334. its section have been processed.
  335. .PP
  336. The command \fBdefault_algorithms\fR sets the default algorithms an \s-1ENGINE\s0 will
  337. supply using the functions \fBENGINE_set_default_string()\fR.
  338. .PP
  339. If the name matches none of the above command names it is assumed to be a
  340. ctrl command which is sent to the \s-1ENGINE.\s0 The value of the command is the
  341. argument to the ctrl command. If the value is the string \fB\s-1EMPTY\s0\fR then no
  342. value is sent to the command.
  343. .PP
  344. For example:
  345. .PP
  346. .Vb 1
  347. \& [engine_section]
  348. \&
  349. \& # Configure ENGINE named "foo"
  350. \& foo = foo_section
  351. \&
  352. \& [foo_section]
  353. \& # Load engine from DSO
  354. \& dynamic_path = /some/path/fooengine.so
  355. \& # A foo specific ctrl.
  356. \& some_ctrl = some_value
  357. \& # Another ctrl that doesn\*(Aqt take a value.
  358. \& other_ctrl = EMPTY
  359. \& # Supply all default algorithms
  360. \& default_algorithms = ALL
  361. .Ve
  362. .SS "\s-1EVP\s0 Configuration Module"
  363. .IX Subsection "EVP Configuration Module"
  364. This modules has the name \fBalg_section\fR which points to a section containing
  365. algorithm commands.
  366. .PP
  367. Currently the only algorithm command supported is \fBfips_mode\fR whose
  368. value can only be the boolean string \fBoff\fR. If \fBfips_mode\fR is set to \fBon\fR,
  369. an error occurs as this library version is not \s-1FIPS\s0 capable.
  370. .SS "\s-1SSL\s0 Configuration Module"
  371. .IX Subsection "SSL Configuration Module"
  372. This module has the name \fBssl_conf\fR which points to a section containing
  373. \&\s-1SSL\s0 configurations.
  374. .PP
  375. Each line in the \s-1SSL\s0 configuration section contains the name of the
  376. configuration and the section containing it.
  377. .PP
  378. Each configuration section consists of command value pairs for \fB\s-1SSL_CONF\s0\fR.
  379. Each pair will be passed to a \fB\s-1SSL_CTX\s0\fR or \fB\s-1SSL\s0\fR structure if it calls
  380. \&\fBSSL_CTX_config()\fR or \fBSSL_config()\fR with the appropriate configuration name.
  381. .PP
  382. Note: any characters before an initial dot in the configuration section are
  383. ignored so the same command can be used multiple times.
  384. .PP
  385. For example:
  386. .PP
  387. .Vb 1
  388. \& ssl_conf = ssl_sect
  389. \&
  390. \& [ssl_sect]
  391. \&
  392. \& server = server_section
  393. \&
  394. \& [server_section]
  395. \&
  396. \& RSA.Certificate = server\-rsa.pem
  397. \& ECDSA.Certificate = server\-ecdsa.pem
  398. \& Ciphers = ALL:!RC4
  399. .Ve
  400. .PP
  401. The system default configuration with name \fBsystem_default\fR if present will
  402. be applied during any creation of the \fB\s-1SSL_CTX\s0\fR structure.
  403. .PP
  404. Example of a configuration with the system default:
  405. .PP
  406. .Vb 1
  407. \& ssl_conf = ssl_sect
  408. \&
  409. \& [ssl_sect]
  410. \& system_default = system_default_sect
  411. \&
  412. \& [system_default_sect]
  413. \& MinProtocol = TLSv1.2
  414. \& MinProtocol = DTLSv1.2
  415. .Ve
  416. .SH "NOTES"
  417. .IX Header "NOTES"
  418. If a configuration file attempts to expand a variable that doesn't exist
  419. then an error is flagged and the file will not load. This can happen
  420. if an attempt is made to expand an environment variable that doesn't
  421. exist. For example in a previous version of OpenSSL the default OpenSSL
  422. master configuration file used the value of \fB\s-1HOME\s0\fR which may not be
  423. defined on non Unix systems and would cause an error.
  424. .PP
  425. This can be worked around by including a \fBdefault\fR section to provide
  426. a default value: then if the environment lookup fails the default value
  427. will be used instead. For this to work properly the default value must
  428. be defined earlier in the configuration file than the expansion. See
  429. the \fB\s-1EXAMPLES\s0\fR section for an example of how to do this.
  430. .PP
  431. If the same variable exists in the same section then all but the last
  432. value will be silently ignored. In certain circumstances such as with
  433. DNs the same field may occur multiple times. This is usually worked
  434. around by ignoring any characters before an initial \fB.\fR e.g.
  435. .PP
  436. .Vb 2
  437. \& 1.OU="My first OU"
  438. \& 2.OU="My Second OU"
  439. .Ve
  440. .SH "EXAMPLES"
  441. .IX Header "EXAMPLES"
  442. Here is a sample configuration file using some of the features
  443. mentioned above.
  444. .PP
  445. .Vb 1
  446. \& # This is the default section.
  447. \&
  448. \& HOME=/temp
  449. \& RANDFILE= ${ENV::HOME}/.rnd
  450. \& configdir=$ENV::HOME/config
  451. \&
  452. \& [ section_one ]
  453. \&
  454. \& # We are now in section one.
  455. \&
  456. \& # Quotes permit leading and trailing whitespace
  457. \& any = " any variable name "
  458. \&
  459. \& other = A string that can \e
  460. \& cover several lines \e
  461. \& by including \e\e characters
  462. \&
  463. \& message = Hello World\en
  464. \&
  465. \& [ section_two ]
  466. \&
  467. \& greeting = $section_one::message
  468. .Ve
  469. .PP
  470. This next example shows how to expand environment variables safely.
  471. .PP
  472. Suppose you want a variable called \fBtmpfile\fR to refer to a
  473. temporary filename. The directory it is placed in can determined by
  474. the \fB\s-1TEMP\s0\fR or \fB\s-1TMP\s0\fR environment variables but they may not be
  475. set to any value at all. If you just include the environment variable
  476. names and the variable doesn't exist then this will cause an error when
  477. an attempt is made to load the configuration file. By making use of the
  478. default section both values can be looked up with \fB\s-1TEMP\s0\fR taking
  479. priority and \fB/tmp\fR used if neither is defined:
  480. .PP
  481. .Vb 5
  482. \& TMP=/tmp
  483. \& # The above value is used if TMP isn\*(Aqt in the environment
  484. \& TEMP=$ENV::TMP
  485. \& # The above value is used if TEMP isn\*(Aqt in the environment
  486. \& tmpfile=${ENV::TEMP}/tmp.filename
  487. .Ve
  488. .PP
  489. Simple OpenSSL library configuration example to enter \s-1FIPS\s0 mode:
  490. .PP
  491. .Vb 3
  492. \& # Default appname: should match "appname" parameter (if any)
  493. \& # supplied to CONF_modules_load_file et al.
  494. \& openssl_conf = openssl_conf_section
  495. \&
  496. \& [openssl_conf_section]
  497. \& # Configuration module list
  498. \& alg_section = evp_sect
  499. \&
  500. \& [evp_sect]
  501. \& # Set to "yes" to enter FIPS mode if supported
  502. \& fips_mode = yes
  503. .Ve
  504. .PP
  505. Note: in the above example you will get an error in non \s-1FIPS\s0 capable versions
  506. of OpenSSL.
  507. .PP
  508. Simple OpenSSL library configuration to make \s-1TLS 1.2\s0 and \s-1DTLS 1.2\s0 the
  509. system-default minimum \s-1TLS\s0 and \s-1DTLS\s0 versions, respectively:
  510. .PP
  511. .Vb 2
  512. \& # Toplevel section for openssl (including libssl)
  513. \& openssl_conf = default_conf_section
  514. \&
  515. \& [default_conf_section]
  516. \& # We only specify configuration for the "ssl module"
  517. \& ssl_conf = ssl_section
  518. \&
  519. \& [ssl_section]
  520. \& system_default = system_default_section
  521. \&
  522. \& [system_default_section]
  523. \& MinProtocol = TLSv1.2
  524. \& MinProtocol = DTLSv1.2
  525. .Ve
  526. .PP
  527. The minimum \s-1TLS\s0 protocol is applied to \fB\s-1SSL_CTX\s0\fR objects that are TLS-based,
  528. and the minimum \s-1DTLS\s0 protocol to those are DTLS-based.
  529. The same applies also to maximum versions set with \fBMaxProtocol\fR.
  530. .PP
  531. More complex OpenSSL library configuration. Add \s-1OID\s0 and don't enter \s-1FIPS\s0 mode:
  532. .PP
  533. .Vb 3
  534. \& # Default appname: should match "appname" parameter (if any)
  535. \& # supplied to CONF_modules_load_file et al.
  536. \& openssl_conf = openssl_conf_section
  537. \&
  538. \& [openssl_conf_section]
  539. \& # Configuration module list
  540. \& alg_section = evp_sect
  541. \& oid_section = new_oids
  542. \&
  543. \& [evp_sect]
  544. \& # This will have no effect as FIPS mode is off by default.
  545. \& # Set to "yes" to enter FIPS mode, if supported
  546. \& fips_mode = no
  547. \&
  548. \& [new_oids]
  549. \& # New OID, just short name
  550. \& newoid1 = 1.2.3.4.1
  551. \& # New OID shortname and long name
  552. \& newoid2 = New OID 2 long name, 1.2.3.4.2
  553. .Ve
  554. .PP
  555. The above examples can be used with any application supporting library
  556. configuration if \*(L"openssl_conf\*(R" is modified to match the appropriate \*(L"appname\*(R".
  557. .PP
  558. For example if the second sample file above is saved to \*(L"example.cnf\*(R" then
  559. the command line:
  560. .PP
  561. .Vb 1
  562. \& OPENSSL_CONF=example.cnf openssl asn1parse \-genstr OID:1.2.3.4.1
  563. .Ve
  564. .PP
  565. will output:
  566. .PP
  567. .Vb 1
  568. \& 0:d=0 hl=2 l= 4 prim: OBJECT :newoid1
  569. .Ve
  570. .PP
  571. showing that the \s-1OID\s0 \*(L"newoid1\*(R" has been added as \*(L"1.2.3.4.1\*(R".
  572. .SH "ENVIRONMENT"
  573. .IX Header "ENVIRONMENT"
  574. .IP "\fB\s-1OPENSSL_CONF\s0\fR" 4
  575. .IX Item "OPENSSL_CONF"
  576. The path to the config file.
  577. Ignored in set-user-ID and set-group-ID programs.
  578. .IP "\fB\s-1OPENSSL_ENGINES\s0\fR" 4
  579. .IX Item "OPENSSL_ENGINES"
  580. The path to the engines directory.
  581. Ignored in set-user-ID and set-group-ID programs.
  582. .SH "BUGS"
  583. .IX Header "BUGS"
  584. Currently there is no way to include characters using the octal \fB\ennn\fR
  585. form. Strings are all null terminated so nulls cannot form part of
  586. the value.
  587. .PP
  588. The escaping isn't quite right: if you want to use sequences like \fB\en\fR
  589. you can't use any quote escaping on the same line.
  590. .PP
  591. Files are loaded in a single pass. This means that a variable expansion
  592. will only work if the variables referenced are defined earlier in the
  593. file.
  594. .SH "SEE ALSO"
  595. .IX Header "SEE ALSO"
  596. \&\fBx509\fR\|(1), \fBreq\fR\|(1), \fBca\fR\|(1)
  597. .SH "COPYRIGHT"
  598. .IX Header "COPYRIGHT"
  599. Copyright 2000\-2020 The OpenSSL Project Authors. All Rights Reserved.
  600. .PP
  601. Licensed under the OpenSSL license (the \*(L"License\*(R"). You may not use
  602. this file except in compliance with the License. You can obtain a copy
  603. in the file \s-1LICENSE\s0 in the source distribution or at
  604. <https://www.openssl.org/source/license.html>.