/usr/include/openscap/oval_definitions.h is in libopenscap-dev 1.2.8-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750 751 752 753 754 755 756 757 758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 783 784 785 786 787 788 789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827 828 829 830 831 832 833 834 835 836 837 838 839 840 841 842 843 844 845 846 847 848 849 850 851 852 853 854 855 856 857 858 859 860 861 862 863 864 865 866 867 868 869 870 871 872 873 874 875 876 877 878 879 880 881 882 883 884 885 886 887 888 889 890 891 892 893 894 895 896 897 898 899 900 901 902 903 904 905 906 907 908 909 910 911 912 913 914 915 916 917 918 919 920 921 922 923 924 925 926 927 928 929 930 931 932 933 934 935 936 937 938 939 940 941 942 943 944 945 946 947 948 949 950 951 952 953 954 955 956 957 958 959 960 961 962 963 964 965 966 967 968 969 970 971 972 973 974 975 976 977 978 979 980 981 982 983 984 985 986 987 988 989 990 991 992 993 994 995 996 997 998 999 1000 1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1011 1012 1013 1014 1015 1016 1017 1018 1019 1020 1021 1022 1023 1024 1025 1026 1027 1028 1029 1030 1031 1032 1033 1034 1035 1036 1037 1038 1039 1040 1041 1042 1043 1044 1045 1046 1047 1048 1049 1050 1051 1052 1053 1054 1055 1056 1057 1058 1059 1060 1061 1062 1063 1064 1065 1066 1067 1068 1069 1070 1071 1072 1073 1074 1075 1076 1077 1078 1079 1080 1081 1082 1083 1084 1085 1086 1087 1088 1089 1090 1091 1092 1093 1094 1095 1096 1097 1098 1099 1100 1101 1102 1103 1104 1105 1106 1107 1108 1109 1110 1111 1112 1113 1114 1115 1116 1117 1118 1119 1120 1121 1122 1123 1124 1125 1126 1127 1128 1129 1130 1131 1132 1133 1134 1135 1136 1137 1138 1139 1140 1141 1142 1143 1144 1145 1146 1147 1148 1149 1150 1151 1152 1153 1154 1155 1156 1157 1158 1159 1160 1161 1162 1163 1164 1165 1166 1167 1168 1169 1170 1171 1172 1173 1174 1175 1176 1177 1178 1179 1180 1181 1182 1183 1184 1185 1186 1187 1188 1189 1190 1191 1192 1193 1194 1195 1196 1197 1198 1199 1200 1201 1202 1203 1204 1205 1206 1207 1208 1209 1210 1211 1212 1213 1214 1215 1216 1217 1218 1219 1220 1221 1222 1223 1224 1225 1226 1227 1228 1229 1230 1231 1232 1233 1234 1235 1236 1237 1238 1239 1240 1241 1242 1243 1244 1245 1246 1247 1248 1249 1250 1251 1252 1253 1254 1255 1256 1257 1258 1259 1260 1261 1262 1263 1264 1265 1266 1267 1268 1269 1270 1271 1272 1273 1274 1275 1276 1277 1278 1279 1280 1281 1282 1283 1284 1285 1286 1287 1288 1289 1290 1291 1292 1293 1294 1295 1296 1297 1298 1299 1300 1301 1302 1303 1304 1305 1306 1307 1308 1309 1310 1311 1312 1313 1314 1315 1316 1317 1318 1319 1320 1321 1322 1323 1324 1325 1326 1327 1328 1329 1330 1331 1332 1333 1334 1335 1336 1337 1338 1339 1340 1341 1342 1343 1344 1345 1346 1347 1348 1349 1350 1351 1352 1353 1354 1355 1356 1357 1358 1359 1360 1361 1362 1363 1364 1365 1366 1367 1368 1369 1370 1371 1372 1373 1374 1375 1376 1377 1378 1379 1380 1381 1382 1383 1384 1385 1386 1387 1388 1389 1390 1391 1392 1393 1394 1395 1396 1397 1398 1399 1400 1401 1402 1403 1404 1405 1406 1407 1408 1409 1410 1411 1412 1413 1414 1415 1416 1417 1418 1419 1420 1421 1422 1423 1424 1425 1426 1427 1428 1429 1430 1431 1432 1433 1434 1435 1436 1437 1438 1439 1440 1441 1442 1443 1444 1445 1446 1447 1448 1449 1450 1451 1452 1453 1454 1455 1456 1457 1458 1459 1460 1461 1462 1463 1464 1465 1466 1467 1468 1469 1470 1471 1472 1473 1474 1475 1476 1477 1478 1479 1480 1481 1482 1483 1484 1485 1486 1487 1488 1489 1490 1491 1492 1493 1494 1495 1496 1497 1498 1499 1500 1501 1502 1503 1504 1505 1506 1507 1508 1509 1510 1511 1512 1513 1514 1515 1516 1517 1518 1519 1520 1521 1522 1523 1524 1525 1526 1527 1528 1529 1530 1531 1532 1533 1534 1535 1536 1537 1538 1539 1540 1541 1542 1543 1544 1545 1546 1547 1548 1549 1550 1551 1552 1553 1554 1555 1556 1557 1558 1559 1560 1561 1562 1563 1564 1565 1566 1567 1568 1569 1570 1571 1572 1573 1574 1575 1576 1577 1578 1579 1580 1581 1582 1583 1584 1585 1586 1587 1588 1589 1590 1591 1592 1593 1594 1595 1596 1597 1598 1599 1600 1601 1602 1603 1604 1605 1606 1607 1608 1609 1610 1611 1612 1613 1614 1615 1616 1617 1618 1619 1620 1621 1622 1623 1624 1625 1626 1627 1628 1629 1630 1631 1632 1633 1634 1635 1636 1637 1638 1639 1640 1641 1642 1643 1644 1645 1646 1647 1648 1649 1650 1651 1652 1653 1654 1655 1656 1657 1658 1659 1660 1661 1662 1663 1664 1665 1666 1667 1668 1669 1670 1671 1672 1673 1674 1675 1676 1677 1678 1679 1680 1681 1682 1683 1684 1685 1686 1687 1688 1689 1690 1691 1692 1693 1694 1695 1696 1697 1698 1699 1700 1701 1702 1703 1704 1705 1706 1707 1708 1709 1710 1711 1712 1713 1714 1715 1716 1717 1718 1719 1720 1721 1722 1723 1724 1725 1726 1727 1728 1729 1730 1731 1732 1733 1734 1735 1736 1737 1738 1739 1740 1741 1742 1743 1744 1745 1746 1747 1748 1749 1750 1751 1752 1753 1754 1755 1756 1757 1758 1759 1760 1761 1762 1763 1764 1765 1766 1767 1768 1769 1770 1771 1772 1773 1774 1775 1776 1777 1778 1779 1780 1781 1782 1783 1784 1785 1786 1787 1788 1789 1790 1791 1792 1793 1794 1795 1796 1797 1798 1799 1800 1801 1802 1803 1804 1805 1806 1807 1808 1809 1810 1811 1812 1813 1814 1815 1816 1817 1818 1819 1820 1821 1822 1823 1824 1825 1826 1827 1828 1829 1830 1831 1832 1833 1834 1835 1836 1837 1838 1839 1840 1841 1842 1843 1844 1845 1846 1847 1848 1849 1850 1851 1852 1853 1854 1855 1856 1857 1858 1859 1860 1861 1862 1863 1864 1865 1866 1867 1868 1869 1870 1871 1872 1873 1874 1875 1876 1877 1878 1879 1880 1881 1882 1883 1884 1885 1886 1887 1888 1889 1890 1891 1892 1893 1894 1895 1896 1897 1898 1899 1900 1901 1902 1903 1904 1905 1906 1907 1908 1909 1910 1911 1912 1913 1914 1915 1916 1917 1918 1919 1920 1921 1922 1923 1924 1925 1926 1927 1928 1929 1930 1931 1932 1933 1934 1935 1936 1937 1938 1939 1940 1941 1942 1943 1944 1945 1946 1947 1948 1949 1950 1951 1952 1953 1954 1955 1956 1957 1958 1959 1960 1961 1962 1963 1964 1965 1966 1967 1968 1969 1970 1971 1972 1973 1974 1975 1976 1977 1978 1979 1980 1981 1982 1983 1984 1985 1986 1987 1988 1989 1990 1991 1992 1993 1994 1995 1996 1997 1998 1999 2000 2001 2002 2003 2004 2005 2006 2007 2008 2009 2010 2011 2012 2013 2014 2015 2016 2017 2018 2019 2020 2021 2022 2023 2024 2025 2026 2027 2028 2029 2030 2031 2032 2033 2034 2035 2036 2037 2038 2039 2040 2041 2042 2043 2044 2045 2046 2047 2048 2049 2050 2051 2052 2053 2054 2055 2056 2057 2058 2059 2060 2061 2062 2063 2064 2065 2066 2067 2068 2069 2070 2071 2072 2073 2074 2075 2076 2077 2078 2079 2080 2081 2082 2083 2084 2085 2086 2087 2088 2089 2090 2091 2092 2093 2094 2095 2096 2097 2098 2099 2100 2101 2102 2103 2104 2105 2106 2107 2108 2109 2110 2111 2112 2113 2114 2115 2116 2117 2118 2119 2120 2121 2122 2123 2124 2125 2126 2127 2128 2129 2130 2131 2132 2133 2134 2135 2136 2137 2138 2139 2140 2141 2142 2143 2144 2145 2146 2147 2148 2149 2150 2151 2152 2153 2154 2155 2156 2157 2158 2159 2160 2161 2162 2163 2164 2165 2166 2167 2168 2169 2170 2171 2172 2173 2174 2175 2176 2177 2178 2179 2180 2181 2182 2183 2184 2185 2186 2187 2188 2189 2190 2191 2192 2193 2194 2195 2196 2197 2198 2199 2200 2201 2202 2203 2204 2205 2206 2207 2208 2209 2210 2211 2212 2213 2214 2215 2216 2217 2218 2219 2220 2221 2222 2223 2224 2225 2226 2227 2228 2229 2230 2231 2232 2233 2234 2235 2236 2237 2238 2239 2240 2241 2242 2243 2244 2245 2246 2247 2248 2249 2250 2251 2252 2253 2254 2255 2256 2257 2258 2259 2260 2261 2262 2263 2264 2265 2266 2267 2268 2269 2270 2271 2272 2273 2274 2275 2276 2277 2278 2279 2280 2281 2282 2283 2284 2285 2286 2287 2288 2289 2290 2291 2292 2293 2294 2295 2296 2297 2298 2299 2300 2301 2302 2303 2304 2305 2306 2307 2308 2309 2310 2311 2312 2313 2314 2315 2316 2317 2318 2319 2320 2321 2322 2323 2324 2325 2326 2327 2328 2329 2330 2331 2332 2333 2334 2335 2336 2337 2338 2339 2340 2341 2342 2343 2344 2345 2346 2347 2348 2349 2350 2351 2352 2353 2354 2355 2356 2357 2358 2359 2360 2361 2362 2363 2364 2365 2366 2367 2368 2369 2370 2371 2372 2373 2374 2375 2376 2377 2378 2379 2380 2381 2382 2383 2384 2385 2386 2387 2388 2389 2390 2391 2392 2393 2394 2395 2396 2397 2398 2399 2400 2401 2402 2403 2404 2405 2406 2407 2408 2409 2410 2411 2412 2413 2414 2415 2416 2417 2418 2419 2420 2421 2422 2423 2424 2425 2426 2427 2428 2429 2430 2431 2432 2433 2434 2435 2436 2437 2438 2439 2440 2441 2442 2443 2444 2445 2446 2447 2448 2449 2450 2451 2452 2453 2454 2455 2456 2457 2458 2459 2460 2461 2462 2463 2464 2465 2466 2467 2468 2469 2470 2471 2472 2473 2474 2475 2476 2477 2478 2479 2480 2481 2482 2483 2484 2485 2486 2487 2488 2489 2490 2491 2492 2493 2494 2495 2496 2497 2498 2499 2500 2501 2502 2503 2504 2505 2506 2507 2508 2509 2510 2511 2512 2513 2514 2515 2516 2517 2518 2519 2520 2521 2522 2523 2524 2525 2526 2527 2528 2529 2530 2531 2532 2533 2534 2535 2536 2537 2538 2539 2540 2541 2542 2543 2544 2545 2546 2547 2548 2549 2550 2551 2552 2553 2554 2555 2556 2557 2558 2559 2560 2561 2562 2563 2564 2565 2566 2567 2568 2569 2570 2571 2572 2573 2574 2575 2576 2577 2578 2579 2580 2581 2582 2583 2584 2585 2586 2587 2588 2589 2590 2591 2592 2593 2594 2595 2596 2597 2598 2599 2600 2601 2602 2603 2604 2605 2606 2607 2608 2609 2610 2611 2612 2613 2614 2615 2616 2617 2618 2619 2620 2621 2622 2623 2624 2625 2626 2627 2628 2629 2630 2631 2632 2633 2634 2635 2636 2637 2638 2639 2640 2641 2642 2643 2644 2645 2646 2647 2648 2649 2650 2651 2652 2653 2654 2655 2656 2657 2658 2659 2660 2661 2662 2663 2664 2665 2666 2667 2668 2669 2670 2671 2672 2673 2674 2675 2676 2677 2678 2679 2680 2681 2682 2683 2684 2685 2686 2687 2688 2689 2690 2691 2692 2693 2694 2695 2696 2697 2698 2699 2700 2701 2702 2703 2704 2705 2706 2707 2708 2709 2710 2711 2712 2713 2714 2715 2716 2717 2718 2719 2720 2721 2722 2723 2724 2725 2726 2727 2728 2729 2730 2731 2732 2733 2734 2735 2736 2737 2738 2739 2740 2741 2742 2743 2744 2745 2746 2747 2748 2749 2750 2751 2752 2753 2754 2755 2756 2757 2758 2759 2760 2761 2762 2763 2764 2765 2766 2767 2768 2769 2770 2771 2772 2773 2774 2775 2776 2777 2778 2779 2780 2781 2782 2783 2784 2785 2786 2787 2788 2789 2790 2791 2792 2793 2794 2795 2796 2797 2798 2799 2800 2801 2802 2803 2804 2805 2806 2807 2808 2809 2810 2811 2812 2813 2814 2815 2816 2817 2818 2819 2820 2821 2822 2823 2824 2825 2826 2827 2828 2829 2830 2831 2832 2833 2834 2835 2836 2837 2838 2839 2840 2841 2842 2843 2844 2845 2846 2847 2848 2849 2850 2851 2852 2853 2854 2855 2856 2857 2858 2859 2860 2861 2862 2863 2864 2865 2866 2867 2868 2869 2870 2871 2872 2873 2874 2875 2876 2877 2878 2879 2880 2881 2882 2883 2884 2885 2886 2887 2888 2889 2890 2891 2892 2893 2894 2895 2896 2897 2898 2899 2900 2901 2902 2903 2904 2905 2906 2907 2908 2909 2910 2911 2912 2913 2914 2915 2916 2917 2918 2919 2920 2921 2922 2923 2924 2925 2926 2927 2928 2929 2930 2931 2932 2933 2934 2935 2936 2937 2938 2939 2940 2941 2942 2943 2944 2945 2946 2947 2948 2949 2950 2951 2952 2953 2954 2955 2956 2957 2958 2959 2960 2961 2962 2963 2964 2965 2966 2967 2968 2969 2970 2971 2972 2973 2974 2975 2976 2977 2978 2979 2980 2981 2982 2983 2984 2985 2986 2987 2988 2989 2990 2991 2992 2993 2994 2995 2996 2997 2998 2999 3000 3001 3002 3003 3004 3005 3006 3007 3008 3009 3010 3011 3012 3013 3014 3015 3016 3017 3018 3019 3020 3021 3022 3023 3024 3025 3026 3027 3028 3029 3030 3031 3032 3033 3034 3035 3036 3037 3038 3039 3040 3041 3042 3043 3044 3045 3046 3047 3048 3049 3050 3051 3052 3053 3054 3055 3056 3057 3058 3059 3060 3061 3062 3063 3064 3065 3066 3067 3068 3069 3070 3071 3072 3073 3074 3075 3076 3077 3078 3079 3080 3081 3082 3083 3084 3085 3086 3087 3088 3089 3090 3091 3092 3093 3094 3095 3096 3097 3098 3099 3100 3101 3102 3103 3104 3105 3106 3107 3108 3109 3110 3111 3112 3113 3114 3115 3116 3117 3118 3119 3120 3121 3122 3123 3124 3125 3126 3127 3128 3129 3130 3131 3132 3133 3134 3135 3136 3137 3138 3139 3140 3141 3142 3143 3144 3145 3146 3147 3148 3149 3150 3151 3152 3153 3154 3155 3156 3157 3158 3159 3160 3161 3162 3163 3164 3165 3166 3167 3168 3169 3170 3171 3172 3173 3174 3175 3176 3177 3178 3179 3180 3181 3182 3183 3184 3185 3186 3187 3188 3189 3190 3191 3192 3193 3194 3195 3196 3197 3198 3199 3200 3201 3202 3203 3204 3205 3206 3207 3208 3209 3210 3211 3212 3213 3214 3215 3216 3217 3218 3219 3220 3221 3222 3223 3224 3225 3226 3227 3228 3229 3230 3231 3232 3233 3234 3235 3236 3237 3238 3239 3240 3241 3242 3243 3244 3245 3246 3247 3248 3249 3250 3251 3252 3253 3254 3255 3256 3257 3258 3259 3260 3261 3262 3263 3264 3265 3266 3267 3268 3269 3270 3271 3272 3273 3274 3275 3276 3277 3278 3279 3280 3281 3282 3283 3284 3285 3286 3287 3288 3289 3290 3291 3292 3293 3294 3295 3296 3297 3298 3299 3300 3301 3302 3303 3304 3305 3306 3307 3308 3309 3310 3311 3312 3313 3314 3315 3316 3317 3318 3319 3320 3321 3322 3323 3324 3325 3326 | /**
* @addtogroup OVAL
* @{
* @addtogroup OVALDEF
* Interface for Definition model.
* @{
*
* Class diagram
* \image html definition_model.png
*
* @file
*
* @author "David Niemoller" <David.Niemoller@g2-inc.com>
*/
/*
* Copyright 2009-2014 Red Hat Inc., Durham, North Carolina.
* All Rights Reserved.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
* Authors:
* "David Niemoller" <David.Niemoller@g2-inc.com>
*/
#ifndef OVAL_DEFINITIONS
#define OVAL_DEFINITIONS
#include "oscap.h"
#include "oscap_source.h"
#include "oval_adt.h"
#include "oval_types.h"
#include "oval_version.h"
#include "oval_schema_version.h"
#include <stdbool.h>
/**
* Affected family enumeration.
* Since new family values can only be added with new version of the schema,
* the value OVAL_AFCFML_UNDEFINED is to be used when the desired family is not available
*/
typedef enum {
OVAL_AFCFML_UNKNOWN = 0,
OVAL_AFCFML_CATOS = 1,
OVAL_AFCFML_IOS = 2,
OVAL_AFCFML_MACOS = 3,
OVAL_AFCFML_PIXOS = 4,
OVAL_AFCFML_UNDEFINED = 5,
OVAL_AFCFML_UNIX = 6,
OVAL_AFCFML_WINDOWS = 7
} oval_affected_family_t;
/// Criteria node type
typedef enum {
OVAL_NODETYPE_UNKNOWN = 0,
OVAL_NODETYPE_CRITERIA = 1,
OVAL_NODETYPE_CRITERION = 2,
OVAL_NODETYPE_EXTENDDEF = 3
} oval_criteria_node_type_t;
/// Boolean operators
typedef enum {
OVAL_OPERATOR_UNKNOWN = 0,
OVAL_OPERATOR_AND = 1,
OVAL_OPERATOR_ONE = 2,
OVAL_OPERATOR_OR = 3,
OVAL_OPERATOR_XOR = 4
} oval_operator_t;
/// Operations
typedef enum {
OVAL_OPERATION_UNKNOWN = 0,
OVAL_OPERATION_BITWISE_AND,
OVAL_OPERATION_BITWISE_OR,
OVAL_OPERATION_CASE_INSENSITIVE_EQUALS,
OVAL_OPERATION_CASE_INSENSITIVE_NOT_EQUAL,
OVAL_OPERATION_EQUALS,
OVAL_OPERATION_GREATER_THAN,
OVAL_OPERATION_GREATER_THAN_OR_EQUAL,
OVAL_OPERATION_LESS_THAN,
OVAL_OPERATION_LESS_THAN_OR_EQUAL,
OVAL_OPERATION_NOT_EQUAL,
OVAL_OPERATION_PATTERN_MATCH,
OVAL_OPERATION_SUBSET_OF,
OVAL_OPERATION_SUPERSET_OF,
} oval_operation_t;
/// Existence check enumeration
typedef enum {
OVAL_EXISTENCE_UNKNOWN = 0,
OVAL_ALL_EXIST = 1,
OVAL_ANY_EXIST = 2,
OVAL_AT_LEAST_ONE_EXISTS = 3,
OVAL_ONLY_ONE_EXISTS = 4,
OVAL_NONE_EXIST = 5
} oval_existence_t;
/// Check enumeration
typedef enum {
OVAL_CHECK_UNKNOWN = 0,
OVAL_CHECK_ALL = 1,
OVAL_CHECK_AT_LEAST_ONE = 2,
OVAL_CHECK_NONE_EXIST = 3,
OVAL_CHECK_NONE_SATISFY = 4,
OVAL_CHECK_ONLY_ONE = 5
} oval_check_t;
/// Type of object content
typedef enum {
OVAL_OBJECTCONTENT_UNKNOWN = 0,
OVAL_OBJECTCONTENT_ENTITY = 1,
OVAL_OBJECTCONTENT_SET = 2,
OVAL_OBJECTCONTENT_FILTER = 3
} oval_object_content_type_t;
/// Type of OVAL entity
typedef enum {
OVAL_ENTITY_TYPE_UNKNOWN,
OVAL_ENTITY_TYPE_ANY,
OVAL_ENTITY_TYPE_BINARY,
OVAL_ENTITY_TYPE_BOOLEAN,
OVAL_ENTITY_TYPE_FLOAT,
OVAL_ENTITY_TYPE_INTEGER,
OVAL_ENTITY_TYPE_STRING,
} oval_entity_type_t;
/// Type of filter action
typedef enum {
OVAL_FILTER_ACTION_UNKNOWN = 0,
OVAL_FILTER_ACTION_EXCLUDE,
OVAL_FILTER_ACTION_INCLUDE
} oval_filter_action_t;
/// Datatypes
typedef enum {
OVAL_DATATYPE_UNKNOWN = 0,
OVAL_DATATYPE_BINARY,
OVAL_DATATYPE_BOOLEAN,
OVAL_DATATYPE_EVR_STRING,
OVAL_DATATYPE_FILESET_REVISION,
OVAL_DATATYPE_FLOAT,
OVAL_DATATYPE_INTEGER,
OVAL_DATATYPE_IOS_VERSION,
OVAL_DATATYPE_IPV4ADDR,
OVAL_DATATYPE_IPV6ADDR,
OVAL_DATATYPE_RECORD,
OVAL_DATATYPE_SEXP,
OVAL_DATATYPE_STRING,
OVAL_DATATYPE_STRING_M,
OVAL_DATATYPE_VERSION,
OVAL_DATATYPE_DEBIAN_EVR_STRING
} oval_datatype_t;
/// Varref types
typedef enum {
OVAL_ENTITY_VARREF_UNKNOWN,
OVAL_ENTITY_VARREF_NONE,
OVAL_ENTITY_VARREF_ATTRIBUTE,
OVAL_ENTITY_VARREF_ELEMENT
} oval_entity_varref_type_t;
/// OVAL set object types
typedef enum {
OVAL_SET_UNKNOWN,
OVAL_SET_AGGREGATE,
OVAL_SET_COLLECTIVE
} oval_setobject_type_t;
/// Set operations
typedef enum {
OVAL_SET_OPERATION_UNKNOWN,
OVAL_SET_OPERATION_COMPLEMENT = 1,
OVAL_SET_OPERATION_INTERSECTION = 2,
OVAL_SET_OPERATION_UNION = 3
} oval_setobject_operation_t;
/// OVAL variable types
typedef enum {
OVAL_VARIABLE_UNKNOWN,
OVAL_VARIABLE_EXTERNAL,
OVAL_VARIABLE_CONSTANT,
OVAL_VARIABLE_LOCAL
} oval_variable_type_t;
#define OVAL_FUNCTION 4
/// Component types
typedef enum {
OVAL_COMPONENT_UNKNOWN = 0,
OVAL_COMPONENT_LITERAL = 1,
OVAL_COMPONENT_OBJECTREF = 2,
OVAL_COMPONENT_VARREF = 3,
OVAL_COMPONENT_FUNCTION = 4,
OVAL_FUNCTION_BEGIN = OVAL_FUNCTION + 1,
OVAL_FUNCTION_CONCAT = OVAL_FUNCTION + 2,
OVAL_FUNCTION_END = OVAL_FUNCTION + 3,
OVAL_FUNCTION_SPLIT = OVAL_FUNCTION + 4,
OVAL_FUNCTION_SUBSTRING = OVAL_FUNCTION + 5,
OVAL_FUNCTION_TIMEDIF = OVAL_FUNCTION + 6,
OVAL_FUNCTION_ESCAPE_REGEX = OVAL_FUNCTION + 7,
OVAL_FUNCTION_REGEX_CAPTURE = OVAL_FUNCTION + 8,
OVAL_FUNCTION_ARITHMETIC = OVAL_FUNCTION + 9,
OVAL_FUNCTION_COUNT = OVAL_FUNCTION + 10,
OVAL_FUNCTION_UNIQUE = OVAL_FUNCTION + 11,
OVAL_FUNCTION_GLOB_TO_REGEX = OVAL_FUNCTION + 12,
OVAL_FUNCTION_LAST = OVAL_FUNCTION + 13
} oval_component_type_t;
/// Arithmetic format enumeration
typedef enum {
OVAL_ARITHMETIC_UNKNOWN = 0,
OVAL_ARITHMETIC_ADD = 1,
OVAL_ARITHMETIC_MULTIPLY = 2,
OVAL_ARITHMETIC_SUBTRACT = 3, //NOT YET SUPPORTED BY OVAL
OVAL_ARITHMETIC_DIVIDE = 4 //NOT YET SUPPORTED BY OVAL
} oval_arithmetic_operation_t;
/// Datetime format enumeration.
typedef enum {
OVAL_DATETIME_UNKNOWN = 0,
OVAL_DATETIME_YEAR_MONTH_DAY = 1,
OVAL_DATETIME_MONTH_DAY_YEAR = 2,
OVAL_DATETIME_DAY_MONTH_YEAR = 3,
OVAL_DATETIME_WIN_FILETIME = 4,
OVAL_DATETIME_SECONDS_SINCE_EPOCH = 5,
OVAL_DATETIME_CIM_DATETIME = 6
} oval_datetime_format_t;
typedef enum {
OVAL_RECORD_FIELD_UNKNOWN = 0,
OVAL_RECORD_FIELD_STATE = 1,
OVAL_RECORD_FIELD_ITEM = 2,
} oval_record_field_type_t;
/**
* Get the family associated with a given subtype.
*/
oval_family_t oval_subtype_get_family(oval_subtype_t);
const char *oval_operator_get_text(oval_operator_t);
const char *oval_subtype_get_text(oval_subtype_t);
const char *oval_family_get_text(oval_family_t);
const char *oval_check_get_text(oval_check_t);
const char *oval_existence_get_text(oval_existence_t);
const char *oval_affected_family_get_text(oval_affected_family_t);
const char *oval_datatype_get_text(oval_datatype_t);
oval_datatype_t oval_datatype_from_text(const char *);
const char *oval_operation_get_text(oval_operation_t);
const char *oval_set_operation_get_text(oval_setobject_operation_t);
const char *oval_datetime_format_get_text(oval_datetime_format_t);
const char *oval_arithmetic_operation_get_text(oval_arithmetic_operation_t);
const char *oval_filter_action_get_text(oval_filter_action_t);
/**
* @struct oval_definition_model
* Oval definition model
*/
struct oval_definition_model;
/**
* @struct oval_definition
* Oval definition specification.
* A definition is the key structure in OVAL. It is analogous to the logical sentence or proposition:
* if a computer's state matches the configuration parameters laid out in the criteria, then that computer exhibits the state described.
*/
struct oval_definition;
/**
* @struct oval_definition_iterator
* @see oval_definition_model_get_definitions
*/
struct oval_definition_iterator;
/**
* @struct oval_test
* An Oval_test specifies a technical control by identifying an @ref oval_object that is evaluated on an instrumented host platform and,
* optionally, an @ref Oval_state instance that matches the object query.
*/
struct oval_test;
/**
* @struct oval_test_iterator
* @see oval_definition_model_get_tests
*/
struct oval_test_iterator;
/**
* @struct oval_object
* An Oval_object instance describes a set of items to look for on an instrumented host platform.
* A simple object will usually result in a single file, process, etc being identified.
* But through the use pattern matches, sets, and variables, multiple matching objects can be identified.
* Therefore an OVAL Object can identify a set of many individual items on a system.
* This set of items defined by the OVAL Object can then be used by an OVAL Test and compared against an OVAL State.
*/
struct oval_object;
/**
* @struct oval_object_iterator
* @see oval_definition_model_get_objects
*/
struct oval_object_iterator;
/**
* @struct oval_state
* An Oval_state instance is a collection of one or more characteristics pertaining to a specific object type.
* The Oval_state is used by an during the evaluation of an Oval_test to determine if a set of items queried
* by an Oval_object on a instrumented host meet certain characteristics.
*/
struct oval_state;
/**
* @struct oval_state_iterator
* @see oval_definition_model_get_states
*/
struct oval_state_iterator;
/**
* @struct oval_variable
* An oval variable resolves an @ref oval_value stream which specifies constraints for @ref oval_object\b s and @ref oval_state\b s.
* - if @ref oval_variable_type == @ref OVAL_VARIABLE_EXTERNAL
* - The value stream is determined by @ref oval_definition_model_bind_variable_model
* - if @ref oval_variable_type == @ref OVAL_VARIABLE_CONSTANT
* - The value stream is determined by a set of specified constants (see @ref oval_variable_add_value)
* - if @ref oval_variable_type == @ref OVAL_VARIABLE_LOCAL
* - The value stream is specified by either a single component or a complex function, meaning that a value can be as simple as a literal string or as
* complex as multiple registry keys concatenated together.
* Note that if an individual component is used and it returns multiple values, then there will be multiple values associated with the Oval_local.
* For example, if an object is specified as the local source and it references a file object that identifies a set of 5 files,
* then the local variable would represent these 5 values.
*/
struct oval_variable;
/**
* @struct oval_variable_possible_value
*/
struct oval_variable_possible_value;
/**
* @struct oval_variable_possible_restriction
*/
struct oval_variable_possible_restriction;
/**
* @struct oval_variable_restriction
*/
struct oval_variable_restriction;
/**
* @struct oval_variable_iterator
* @see oval_definition_model_get_variables
*/
struct oval_variable_iterator;
/**
* @struct oval_affected
* Each OVAL Definition specifies certain type of affected system(s). The family, platform(s),
* and product(s) of this target are described by the Oval_affected component whose main purpose is to provide hints
* for tools using OVAL Definitions. For instance, to help a reporting tool only use Windows definitions,
* or to preselect only Red Hat definitions to be evaluated. Note, the inclusion of a particular platform
* or product does not mean the definition is physically checking for the existence of the platform or product.
* For the actual test to be performed, the correct test must still be included in the definition's criteria section.
*
* The AffectedType complex type details the specific system, application, subsystem, library, etc. for which a
* definition has been written. If a definition is not tied to a specific product, then this element should not
* be included. The absence of the platform or product element can be thought of as definition applying to
* all platforms or products. The inclusion of a particular platform or product does not mean the definition
* is physically checking for the existence of the platform or product. For the actual test to be performed,
* the correct test must still be included in the definition's criteria section. To increase the utility of this element,
* care should be taken when assigning and using strings for product names. The schema places no restrictions on the values
* that can be assigned, potentially leading to many different representations of the same value. For example
* 'Internet Explorer' and 'IE'. The current convention is to fully spell out all terms, and avoid the use of
* abbreviations at all costs.
*/
struct oval_affected;
/**
* @struct oval_affected_iterator
* @see oval_definition_get_affected
*/
struct oval_affected_iterator;
/**
* @struct oval_reference
* An Oval_reference links an @ref Oval_definition to a definitive external reference.
* For example, CVE Identifiers for vulnerabilities.
* The intended purpose for this reference is to link the definition to a variety of other sources that address the same
* issue being specified by the Oval_definition.
*/
struct oval_reference;
/**
* @struct oval_reference_iterator
* @see oval_definition_get_references
*/
struct oval_reference_iterator;
/**
* @struct oval_criteria_node
* Specify @ref oval_definition dependencies.
* An Oval_criteria_node specifies @ref oval_definition dependencies as follows:
* - if @ref oval_criteria_node_get_type == @ref OVAL_NODETYPE_CRITERIA - a hierarchic dependency on other Oval_criteria_nodes
* - if @ref oval_criteria_node_get_type == @ref OVAL_NODETYPE_CRITERION - an @ref oval_test dependency
* - if @ref oval_criteria_node_get_type == @ref OVAL_NODETYPE_EXTENDDEF - an @ref oval_definition dependency
*/
struct oval_criteria_node;
/**
* @struct oval_criteria_node_iterator
* @see oval_criteria_node_get_subnodes
*/
struct oval_criteria_node_iterator;
/**
* @struct oval_object_content
* An Oval_object_content instance specifies an @ref oval_object field.
*/
struct oval_object_content;
/**
* @struct oval_object_content_iterator
* @see oval_object_get_object_contents
*/
struct oval_object_content_iterator;
/**
* @struct oval_behavior
* OVAL behavior
*/
struct oval_behavior;
/**
* @struct oval_behavior_iterator
* @see oval_object_get_behaviors
*/
struct oval_behavior_iterator;
/**
* @struct oval_state_content
* An Oval_state_content instance specifies an @ref oval_state field.
*/
struct oval_state_content;
/**
* @struct oval_state_content_iterator
* @see oval_state_get_contents
*/
struct oval_state_content_iterator;
/**
* @struct oval_value
* OVAL object or item entity value
*/
struct oval_value;
/**
* @struct oval_value_iterator
* @see oval_variable_get_values
*/
struct oval_value_iterator;
/**
* @struct oval_entity
* OVAL entity
*/
struct oval_entity;
/**
* @struct oval_entity_iterator
*/
struct oval_entity_iterator;
/**
* @struct oval_record_field
*/
struct oval_record_field;
/**
* @struct oval_record_field_iterator
*/
struct oval_record_field_iterator;
/**
* @struct oval_setobject
* OVAL set object
*/
struct oval_setobject;
/**
* @struct oval_setobject_iteraor
* @see oval_setobject_get_subsets
*/
struct oval_setobject_iterator;
/**
* @struct oval_filter
* OVAL filter
*/
struct oval_filter;
/**
* @struct oval_filter_iterator
*/
struct oval_filter_iterator;
/**
* @struct oval_component
* OVAL variable component
* Oval_component instances specify evaluation constraints on local variables (see @ref oval_variable_get_type).
*
* - If @ref oval_component_get_type == @ref OVAL_FUNCTION_CONCAT - Concatenation function
* - Oval_function_CONCAT takes two or more components and sub-concatenates them together to form a single string.
* The first component makes up the begining of the resulting string and any following components are added to the end it.
* If one of the components returns multiple values then the concat function would be performed multiple times and the end result would be an array of values for the local variable.
* For example assume a local variable has two sub-components: a basic component element returns the values "abc" and "def", and a literal component element that has a value of "xyz".
* The local_variable element would be evaluated to have two values, "abcxyz" and "defxyz". If one of the components does not exist,
* then the result of the concat operation should be does not exist.
* - If @ref oval_component_get_type == @ref OVAL_FUNCTION_COUNT - Counting function.
* - The count function counts the values represented by one or more components as an integer. This function determines the total number of values referenced
* by all of thespecified sub-components.
* - If @ref oval_component_get_type == @ref OVAL_FUNCTION_ARITHMETIC - Arithmetic function.
* - The arithmetic function takes two or more integer or float components and performs a basic mathmetical function on them.
* The result of this function in a single integer or float unless one of the components returns multiple values.
* In this case the specified arithmetic function would be performed multiple times and the end result would be an array of values for the local variable.
* For example assume a local_variable specifies the arithmetic function with an arithmetic_operation of "add" and has two sub-components under this function:
* the first component returns multiple values "1" and "2", and the second component returns multiple values "3" and "4" and "5".
* The local_variable element would be evaluated to have six values: 1+3, 1+4, 1+5, 2+3, 2+4, and 2+5.
* - If @ref oval_component_get_type == @ref OVAL_FUNCTION_REGEX_CAPTURE - Regex_capture function.
* - The regex_capture function captures a single substring from a string component.
* The 'pattern' attribute provides a regular expression that must contain a single subexpression (using parentheses).
* The first match of the subexpression is considered the captured substring.
* For example, the pattern ^abc(.*)xyz$ would capture a substring from each of the string component's values if the value starts with abc and ends with xyz.
* In this case the subexpression would be all the characters that exist in between the abc and the xyz.
* If more than one subexpression is supplied only the first match is considered.
* If more than one match is identified by a single subexpression only the first match is considered.
* If no matches are found or a subexpression is not supplied the function will evaluate to an empty string.
* Note that subexpressions match the longest possible substrings.
* - If @ref oval_component_get_type == @ref OVAL_FUNCTION_BEGIN - Begin function
* - The begin function takes a single string component and defines a character (or string) that the component string should start with.
* The character attribute defines the specific character (or string).
* The character (or string) is only added to the component string if the component string doesn't already start with the specified character (or string).
* - If @ref oval_component_get_type == @ref OVAL_FUNCTION_END - End function
* - The end function takes a single string component and defines a character (or string) that the component string should end with.
* The character attribute defines the specific character (or string).
* The character (or string) is only added to the component string if the component string doesn't already end with the specified character (or string).
* If the desired end character is a string, then the entire end string must exist at the end if the component string.
* If the entire end string is not present then the entire end string is appended to the component string.
* - If @ref oval_component_get_type == @ref OVAL_FUNCTION_SPLIT - Split function
* - The split function takes a single string component and turns it into multiple values based on a delimiter string.
* For example, assume that a basic component element returns the value "a-b-c-d" to the split function with the delimiter set to "-".
* The local_variable element would be evaluated to have four values "a", "b", "c", and "d".
* If the basic component returns a value that begins, or ends, with a delimiter, the local_variable element would contain empty string
* values at the beginning, or end, of the set of values returned for that string component.
* For example, if the delimiter is "-", and the basic component element returns the value "-a-a-",
* the local_variable element would be evaluated to have four values "", "a", "a", and "".
* Likewise, if the basic component element returns a value that contains adjacent delimiters such as "---",
* the local_variable element would be evaluated to have four values "", "", "", and "".
* Lastly, if the basic component element used by the split function returns multiple values,
* then the split function is performed multiple times, and all of the results, from each of the split functions, are returned.
* - If @ref oval_component_get_type == @ref OVAL_FUNCTION_SUBSTRING - Substring function
* - The substring function takes a single string component and produces a single value that contains a portion
* of the original string. The substring_start attribute defines the starting position in the original string.
* Note, to include the first character of the string, the start position would be 1.
* Also note that a value less than one also means starting at the first character of the string.
* The substring_length attribute defines how many character after and including the starting character to include.
* Note that a substring_length value greater than the actual length of the string or a negative value means to
* include all the characters after the starting character.
* For example assume a basic component element that returns the value "abcdefg" with a substring_start value of
* 3 and a substring_length value of 2. The local_variable element would be evaluate to have a single value of
* "cd". If the string component used by the substring function returns multiple values, then the substring
* operation is performed multiple times and results in multiple values for the component.
* - If @ref oval_component_get_type == @ref OVAL_FUNCTION_TIMEDIF - Time difference function
* - Oval_function_TIMEDIF calculates the difference in seconds between date-time values.
* If one component is specified, the values of that component are subtracted from the current time (UTC).
* If two components are specified, the value of the second component is subtracted from the value of the first component.
* If the component(s) contain multiple values,
* the operation is performed multiple times on the Cartesian product of the component(s) and the result is an array of time difference values.
* For example, assume a local_variable specifies the time_difference function and has two sub-components under this function: the first
* component returns multiple values "04/02/2009" and "04/03/2009", and the second component returns multiple values "02/02/2005"
* and "02/03/2005" and "02/04/2005".
* The local_variable element would be evaluated to have six values: (ToSeconds("04/02/2009") - ToSeconds("02/02/2005")),
* (ToSeconds("04/02/2009") - ToSeconds("02/03/2005")), (ToSeconds("04/02/2009") - ToSeconds("02/04/2005")),
* (ToSeconds("04/03/2009") - ToSeconds("02/02/2005")), (ToSeconds("04/03/2009") - ToSeconds("02/03/2005")),
* and (ToSeconds("04/03/2009") - ToSeconds("02/04/2005"))..
* - If @ref oval_component_get_type == @ref OVAL_FUNCTION_ESCAPE_REGEX - Escape Regular Expression function
* - Oval_function_ESCAPE_REGEX takes a single string component and escapes all the regular expression characters.
* The purpose for this is that many times, a component used in pattern match needs to be treated as a literal string and not a regular expression.
* For example, assume a basic component element that identifies a file path that is held in the Windows registry.
* This path is a string that might contain regular expression characters.
* These characters are likely not intended to be treated as regular expression characters and need to be escaped.
* This function allows a definition writer to mark convert the values of components to regular expression format.
* Note that when using regular expressions, OVAL supports a common subset of the regular expression character
* classes, operations, expressions and other lexical tokens defined within Perl 5's regular expression specification.
* For more information on the supported regular expression syntax in OVAL see: http://oval.mitre.org/language/about/re_support_5.6.html.
* - If @ref oval_component_get_type == @ref OVAL_COMPONENT_LITERAL - Literal component
* - Oval_literal evaluates to a literal value.
* - If @ref oval_component_get_type == @ref OVAL_COMPONENT_OBJECTREF - Object component
* - Oval_component_object binds an Oval_object.
* During evaluation of the component, the object is queried and the resultant item stream is transformed to provide the Oval_value stream that
* constitutes the evaluation result of this component. The item stream transformation consists of using the component object_field attribute to identify the name of a specific item field
* whose value is appended to the component value stream.
* - If @ref oval_component_get_type == @ref OVAL_COMPONENT_VARREF - Variable component
* - Oval_variable_component binds an Oval_variable. The component evaluation is the result of the evaluation of the bound
* Oval_variable.
*/
struct oval_component;
/**
* @struct oval_component_iterator
* @see oval_component_get_function_components
*/
struct oval_component_iterator;
/**
* @struct oval_generator
*/
struct oval_generator;
struct oval_generator *oval_generator_new(void);
void oval_generator_free(struct oval_generator *generator);
struct oval_generator *oval_generator_clone(struct oval_generator *old_generator);
char *oval_generator_get_product_name(struct oval_generator *generator);
char *oval_generator_get_product_version(struct oval_generator *generator);
OSCAP_DEPRECATED(char *oval_generator_get_schema_version(struct oval_generator *generator));
const char *oval_generator_get_core_schema_version(struct oval_generator *generator);
char *oval_generator_get_timestamp(struct oval_generator *generator);
const char *oval_generator_get_platform_schema_version (struct oval_generator *generator, const char *platform);
void oval_generator_set_product_name(struct oval_generator *generator, const char *product_name);
void oval_generator_set_product_version(struct oval_generator *generator, const char *product_version);
OSCAP_DEPRECATED(void oval_generator_set_schema_version(struct oval_generator *generator, const char *schema_version));
void oval_generator_set_core_schema_version(struct oval_generator *generator, const char *schema_version);
void oval_generator_add_platform_schema_version(struct oval_generator *generator, const char *platform, const char *schema_version);
void oval_generator_set_timestamp(struct oval_generator *generator, const char *timestamp);
void oval_generator_update_timestamp(struct oval_generator *generator);
/**
* Create an empty oval_definition_model.
* @memberof oval_definition_model
*/
struct oval_definition_model *oval_definition_model_new(void);
/**
* Import the content of the oscap_source into the oval_definition_model
* @memberof oval_definition_model
* @param source The oscap_source to import from
* @returns newly build oval_definition_model, or NULL if something went wrong
*/
struct oval_definition_model *oval_definition_model_import_source(struct oscap_source *source);
/**
* Import the content from the file into an oval_definition_model.
* @param file filename
* @return new oval_definition_model, or NULL if an error occurred
* @memberof oval_definition_model
* @deprecated This function has been deprecated and it may be dropped from later
* OpenSCAP releases. Please use oval_definition_model_import_source instead.
*/
OSCAP_DEPRECATED(struct oval_definition_model *oval_definition_model_import(const char *file));
/**
* Merge the content from the file with specified oval_definition_model.
* If imported content specifies a model entity that is already registered within the model its content is overwritten.
* @param model the merge target model
* @param file filename
* @return -1 if an error occurred
* @memberof oval_definition_model
* @deprecated This function has been deprecated and it may be dropped from later
* OpenSCAP releases.
*/
OSCAP_DEPRECATED(int oval_definition_model_merge(struct oval_definition_model *model, const char *file));
/**
* Copy an oval_definition_model.
* @return A copy of the specified @ref oval_definition_model.
* @memberof oval_definition_model
*/
struct oval_definition_model *oval_definition_model_clone(struct oval_definition_model *);
/**
* Export an oval_definition_model into file.
* @memberof oval_definition_model
*
*/
int oval_definition_model_export(struct oval_definition_model *, const char *file);
/**
* Free OVAL object model and all binded variable models.
* @memberof oval_definition_model
*/
void oval_definition_model_free(struct oval_definition_model *model);
/**
* @name Setters
* @{
*/
void oval_definition_model_set_generator(struct oval_definition_model *model, struct oval_generator *generator);
/**
* Bind an oval_variable_model to the specified oval_definition_model.
* @return zero on success or non zero value if an error occurred
* @memberof oval_definition_model
*/
int oval_definition_model_bind_variable_model(struct oval_definition_model *, struct oval_variable_model *);
void oval_definition_model_clear_external_variables(struct oval_definition_model *);
/** @} */
/**
* @name Getters
* @{
*/
struct oval_generator *oval_definition_model_get_generator(struct oval_definition_model *model);
/**
* Returns the appended @ref oval_definition having the specified id.
* IF the specified id does not resolve to an appended Oval_definition the method shall return NULL.
* @see oval_definition_add_definition
* @param id the definition id.
* @memberof oval_definition_model
*/
struct oval_definition *oval_definition_model_get_definition(struct oval_definition_model *, const char *id);
/**
* Get oval test by ID.
* Return a designated oval_test from the specified oval_definition_model.
* If the specified id does not resolve to an oval_test the function returns NULL.
* @param model the queried model.
* @param id the test id.
* @memberof oval_definition_model
*/
struct oval_test *oval_definition_model_get_test(struct oval_definition_model *model, const char *id);
/**
* Get OVAL object by ID.
* Return a designated oval_object from the specified oval_definition_model.
* If the specified id does not resolve to an oval_object the function returns NULL.
* @param model the queried model.
* @param id the object id.
* @memberof oval_definition_model
*/
struct oval_object *oval_definition_model_get_object(struct oval_definition_model *model, const char *id);
/**
* Get OVAL state by ID.
* Return a designated oval_state from the specified oval_definition_model.
* If the specified id does not resolve to an oval_state the function returns NULL.
* @param model the queried model.
* @param id the state id.
* @memberof oval_definition_model
*/
struct oval_state *oval_definition_model_get_state(struct oval_definition_model *model, const char *id);
/**
* Get OVAL variable by ID.
* Return a designated oval_variable from the specified oval_definition_model.
* If the specified id does not resolve to an oval_variable the function returns NULL.
* @param model the queried model.
* @param id the variable id.
* @memberof oval_definition_model
*/
struct oval_variable *oval_definition_model_get_variable(struct oval_definition_model *model, const char *id);
/**
* Returns all appended @ref oval_definition instances.
* @memberof oval_definition_model
*/
struct oval_definition_iterator *oval_definition_model_get_definitions(struct oval_definition_model *model);
/**
* Get OVAL tests.
* Return all oval_tests from the specified oval_definition_model.
* @param model the queried model.
* @memberof oval_definition_model
*/
struct oval_test_iterator *oval_definition_model_get_tests(struct oval_definition_model *model);
/**
* Get OVAL objects.
* Return all oval_objects from the specified oval_definition_model.
* @param model the queried model.
* @memberof oval_definition_model
*/
struct oval_object_iterator *oval_definition_model_get_objects(struct oval_definition_model *model);
/**
* Get OVAL states.
* Return all oval_states from the specified oval_definition_model.
* @param model the queried model.
* @memberof oval_definition_model
*/
struct oval_state_iterator *oval_definition_model_get_states(struct oval_definition_model *model);
/**
* Get OVAL variables.
* Return all oval_variables from the specified oval_definition_model.
* @param model the queried model.
* @memberof oval_definition_model
*/
struct oval_variable_iterator *oval_definition_model_get_variables(struct oval_definition_model *model);
/**
* Get supported version of OVAL XML
* @return version of XML file format
* @memberof oval_definition_model
*/
const char * oval_definition_model_supported(void);
/**
* Return the list of variable models bound to the specified oval_definition_model.
* @return iterator over oval_variable_model collection
* @memberof oval_definition_model
*/
struct oval_variable_model_iterator *oval_definition_model_get_variable_models(struct oval_definition_model *);
/** @} */
/**
* @name Evaluators
* @{
*/
/** @} */
/**
* Construct an instance of @ref oval_definition.
* Initialized attribute values are
* - id bound to value specified by id parameter.
* - version bound to 0.
* - class bound to @ref OVAL_CLASS_UNKNOWN
* - deprecated bound to <b>false</b>
* - title bound to NULL
* - description bound to NULL
* - criteria bound to NULL
* - affected bound to empty iterator
* - references bound to empty iterator
* - notes bound to empty iterator
* @param id - (non-NULL) A copy of this string is bound to the id attribute of the created instance.
* @memberof oval_definition
*/
struct oval_definition *oval_definition_new(struct oval_definition_model *, const char *id);
/**
* Clone instance of @ref oval_definition and add it to the specified @ref oval_definition_model.
* @return A copy of the specified @ref oval_definition.
* @memberof oval_definition
*/
struct oval_definition *oval_definition_clone(struct oval_definition_model *new_model, struct oval_definition *old_definition);
/**
* Release an instance of @ref oval_definition.
* All attributes of the Oval_definition are also released.
*
* @note Applications should not call this method to free an Oval_definition that is bound
* to an instance of @ref OVALDEF. These bound definitions are released when the @ref OVALDEF are
* released.
* @memberof oval_definition
*/
void oval_definition_free(struct oval_definition *);
/**
* @name Setters
* @{
*/
/**
* Set attribute @ref oval_definition->version.
* This method shall overwrite a zero version attribute value with the value of the version parameter.
* Valid values of the version attribute shall not be overwritten by this method.
* @param version - the required version
* @memberof oval_definition
*/
void oval_definition_set_version(struct oval_definition *, int version);
/**
* Set attribute @ref oval_definition->class.
* This method shall overwrite a @ref OVAL_CLASS_UNKNOWN class attribute value with the value of the class parameter.
* Valid values of the class attribute shall not be overwritten by this method.
* @param class - the required class
* @memberof oval_definition
*/
void oval_definition_set_class(struct oval_definition *, oval_definition_class_t);
/**
* Set attribute @ref oval_definition->deprecated.
* @param deprecated - the required deprecation toggle.
* @memberof oval_definition
*/
void oval_definition_set_deprecated(struct oval_definition *, bool deprecated);
/**
* Set attribute @ref oval_definition->title.
* This method shall overwrite a NULL title attribute value with a copy of the title parameter.
* Valid values of the title attribute shall not be overwritten by this method.
* @param title - the required title
* @memberof oval_definition
*/
void oval_definition_set_title(struct oval_definition *, char *title);
/**
* Set attribute @ref oval_definition->description.
* This method shall overwrite a NULL description attribute value with a copy of the description parameter.
* Valid values of the description attribute shall not be overwritten by this method.
* @param description - the required description
* @memberof oval_definition
*/
void oval_definition_set_description(struct oval_definition *, char *description);
/**
* Append instance of @ref oval_affected to attribute @ref oval_definition->affected.
* @note Instances of Oval_affected bound to Oval_definition by this method should not be subsequently freed by
* the application using @ref oval_affected_free. These instances shall be freed by the API when
* the Oval_definition is freed.
* @note A given instance of Oval_affected should not be appended by an application to more than one instance of Oval_definition, nor should
* the given instance of Oval_affected be appended more than once to a single instance of Oval_definition.
* @param affected - appended instance of Oval_affected.
* @memberof oval_definition
*/
void oval_definition_add_affected(struct oval_definition *, struct oval_affected *affected);
/**
* Append instance of @ref oval_reference to attribute @ref oval_definition->references.
* @note Instances of Oval_reference bound to Oval_definition by this method should not be subsequently freed by
* the application using @ref oval_reference_free. These instances shall be freed by the API when
* the Oval_definition is freed.
* @note A given instance of Oval_reference should not be appended by an application to more than one instance of Oval_definition, nor should
* the given instance of Oval_reference be appended more than once to a single instance of Oval_definition.
* @param reference - appended instance of Oval_reference.
* @memberof oval_definition
*/
void oval_definition_add_reference(struct oval_definition *, struct oval_reference *reference);
/**
* Append a copy of the note parameter to attribute @ref Oval_definition->notes.
* @param note - the note text.
* @memberof oval_definition
*/
void oval_definition_add_note(struct oval_definition *, char *note);
/**
* Set attribute @ref oval_definition->criteria.
* This method shall overwrite a NULL criteria attribute value with the criteria parameter only if the criteria parameter is an instance of @ref Oval_criteria
* (i.e. criteria->type == @ref OVAL_NODETYPE_CRITERIA).
* Other values of the criteria attribute shall not be overwritten by this method.
* @note Instances of Oval_criteria bound to Oval_definition by this method should not be subsequently freed by the application using oval_criteria_node_free.
* These instances shall be freed by the API when the Oval_definition is freed.
*
* @note An application should not bind a given instance of Oval_criteria to more than one instance of Oval_definition,
* nor should a given instance of Oval_criteria be bound to both an Oval_definition and an Oval_criteria (using @ref oval_criteria_node_add_subnode).
* @param criteria - the required instance of Oval_criteria
* @memberof oval_definition
*/
void oval_definition_set_criteria(struct oval_definition *, struct oval_criteria_node *criteria);
/** @} */
/**
* @name Getters
* @{
*/
/**
* Returns attribute @ref oval_definition->id (identifier).
* @memberof oval_definition
*/
char *oval_definition_get_id(struct oval_definition *);
/**
* Returns attribute @ref oval_definition->version.
* @return A pointer to the id attribute of the specified @ref oval_definition.
* @memberof oval_definition
*/
int oval_definition_get_version(struct oval_definition *);
/**
* Returns attribute @ref oval_definition->class.
* @memberof oval_definition
*/
oval_definition_class_t oval_definition_get_class(struct oval_definition *);
/**
* Returns attribute @ref oval_definition->deprecated.
* @memberof oval_definition
*/
bool oval_definition_get_deprecated(struct oval_definition *);
/**
* Returns attribute @ref oval_definition->title.
* @return A pointer to the title attribute of the specified @ref oval_definition.
* @memberof oval_definition
*/
char *oval_definition_get_title(struct oval_definition *);
/**
* Returns attribute @ref oval_definition->description.
* @return A pointer to the description attribute of the specified @ref oval_definition.
* @memberof oval_definition
*/
char *oval_definition_get_description(struct oval_definition *);
/**
* Returns attribute @ref oval_definition->affected.
* @return A new iterator for the affected attribute of the specified @ref oval_definition.
* It should be freed after use by the calling application.
* @memberof oval_definition
*/
struct oval_affected_iterator *oval_definition_get_affected(struct oval_definition *);
/**
* Returns attribute @ref oval_definition->references.
* @return A new iterator for the reference attribute of the specified @ref oval_definition.
* It should be freed after use by the calling application.
* @memberof oval_definition
*/
struct oval_reference_iterator *oval_definition_get_references(struct oval_definition *);
/**
* Returns attribute @ref oval_definition->notes.
* @return A new iterator for the notes attribute of the specified @ref oval_definition.
* It should be freed after use by the calling application.
* @memberof oval_definition
*/
struct oval_string_iterator *oval_definition_get_notes(struct oval_definition *);
/**
* Returns attribute @ref oval_definition->criteria.
* @return A pointer to the criteria attribute of the specified @ref oval_definition.
* @memberof oval_definition
*/
struct oval_criteria_node *oval_definition_get_criteria(struct oval_definition *);
/** @} */
/**
* @name Evaluators
* @{
*/
/** @} */
/**
* @name Iterators
* @{
*/
/**
* Returns <b>true</b> if the iterator contains more instances of @ref oval_definition.
* @memberof oval_definition_iterator
*/
bool oval_definition_iterator_has_more(struct oval_definition_iterator *);
/**
* Returns the next iterated instance of @ref oval_definition.
* NULL is returned if the iterator is exhausted (@ref oval_definition_iterator_has_more == <b>false</b>)
* @memberof oval_definition_iterator
*/
struct oval_definition *oval_definition_iterator_next(struct oval_definition_iterator *);
/**
* Free the iterator.
* @memberof oval_definition_iterator
*/
void oval_definition_iterator_free(struct oval_definition_iterator *);
/** @} */
/**
* Construct new instance of @ref oval_test.
* Attribute values shall be initialized:
* - family -- initialized to @ref OVAL_FAMILY_UNKNOWN
* - subtype -- initialized to @ref OVAL_SUBTYPE_UNKNOWN
* - notes -- initialized to empty iterator.
* - comment -- initialized to NULL
* - id -- initialized to a copy of the id parameter
* - deprecated -- initialized to <b>false</b>
* - version -- initialized to zero
* - existence -- initialized to @ref OVAL_CHECK_UNKNOWN
* - check -- initialized to @ref OVAL_CHECK_UNKNOWN
* - object -- initialized to NULL
* - state -- initialized to NULL
*
* @note This method shall not construct a new instance of Oval_test and shall return NULL if the text of the id parameter is not matched
* by the regular expression <b>^oval:[\.A-Za-z0-9_\-]+:tst:[1-9][0-9]*$</b>.
* @param id - (Not NULL) the text of the required test id.
* @memberof oval_test
*/
struct oval_test *oval_test_new(struct oval_definition_model *, const char *id);
/**
* Clone instance of @ref oval_test and add it to the specified @ref oval_definition_model.
* @return A copy of the specified @ref oval_test.
* @memberof oval_test
*/
struct oval_test *oval_test_clone(struct oval_definition_model *new_model, struct oval_test *old_test);
/**
* Destruct instance of @ref oval_test.
* @memberof oval_test
*/
void oval_test_free(struct oval_test *);
/**
* @name Setters
* @{
*/
/**
* Sets attributes @ref oval_test->subtype and @ref Oval_test->family.
* If Oval_test->subtype == @ref OVAL_SUBTYPE_UNKNOWN and parameter subtype <> @ref OVAL_SUBTYPE_UNKNOWN,
* this method shall overwrite Oval_test->subtype with the value of the subtype parameter and Oval_test->family
* with the value of @ref oval_family_t corresponding to the specified subtype.
* Otherwise, the state of the Oval_test instance shall not be changed by this method.
* @param subtype - the required subtype value.
* @memberof oval_test
*/
void oval_test_set_subtype(struct oval_test *, oval_subtype_t subtype);
/**
* Appends a copy of the note parameter to attribute @ref oval_test->notes.
* @param note - (Not NULL) the text of the appended note.
* @memberof oval_test
*/
void oval_test_add_note(struct oval_test *, char *note);
/**
* Sets a copy of the comment parameter to attribute @ref oval_test->comment.
* @param comment - (Not NULL) the text of the comment.
* @memberof oval_test
*/
void oval_test_set_comment(struct oval_test *, char *comment);
/**
* Sets attribute @ref oval_test->deprecated.
* @memberof oval_test
*/
void oval_test_set_deprecated(struct oval_test *, bool deprecated);
/**
* Sets attribute @ref oval_test->version.
* If Oval_test->version == 0 and parameter version >0,
* this method shall overwrite Oval_test->version with the parameter value.
* Otherwise, the method shall leave the Oval_test state unchanged.
* @param version - (>0) the required version
* @memberof oval_test
*/
void oval_test_set_version(struct oval_test *, int version);
/**
* Sets attribute @ref oval_test->state_operator.
* @memberof oval_test
*/
void oval_test_set_state_operator(struct oval_test *, oval_operator_t);
/**
* Sets attribute @ref oval_test->existence.
* If Oval_test->existence == @ref OVAL_CHECK_UNKNOWN and parameter existence <> @ref OVAL_CHECK_UNKNOWN,
* this method shall overwrite Oval_test->existence with the parameter value.
* Otherwise, the method shall leave the Oval_test state unchanged.
* @param existence - (<> @ref OVAL_CHECK_UNKNOWN) the required existence
* @memberof oval_test
*/
void oval_test_set_existence(struct oval_test *, oval_existence_t);
/**
* Sets attribute @ref oval_test->check.
* If Oval_test->check == @ref OVAL_CHECK_UNKNOWN and parameter check <> @ref OVAL_CHECK_UNKNOWN,
* this method shall overwrite Oval_test->check with the parameter check.
* Otherwise, the method shall leave the Oval_test state unchanged.
* @note If Oval_test->state == NULL, the value of Oval_test->check is ignored.
* @param check - (<> @ref OVAL_CHECK_UNKNOWN) the required check
* @memberof oval_test
*/
void oval_test_set_check(struct oval_test *, oval_check_t);
/**
* Sets attribute @ref oval_test->object.
* If Oval_test->object == NULL and parameter object <> NULL,
* this method shall overwrite Oval_test->object with the parameter object.
* Otherwise, the method shall leave the Oval_test state unchanged.
* @param object - (<> NULL) the required object
* @memberof oval_test
*/
void oval_test_set_object(struct oval_test *, struct oval_object *);
/**
* Add the specified state to the state list of the specified test.
* @param state - (<> NULL) the required state
* @memberof oval_test
*/
void oval_test_add_state(struct oval_test *, struct oval_state *);
/** @} */
/**
* @name Getters
* @{
*/
/**
* Returns attribute @ref Oval_test->family
* @memberof oval_test
*/
oval_family_t oval_test_get_family(struct oval_test *);
/**
* Returns attribute @ref Oval_test->subtype
* @memberof oval_test
*/
oval_subtype_t oval_test_get_subtype(struct oval_test *);
/**
* Returns attribute @ref oval_test->notes.
* @return A new iterator for the notes attribute of the specified @ref oval_test.
* It should be freed after use by the calling application.
* @memberof oval_test
*/
struct oval_string_iterator *oval_test_get_notes(struct oval_test *);
/**
* Returns attribute @ref Oval_test->comment.
* @return A pointer to the comment attribute of the specified @ref oval_test.
* @memberof oval_test
*/
char *oval_test_get_comment(struct oval_test *);
/**
* Returns attribute @ref oval_test->id.
* @return A pointer to the id attribute of the specified @ref oval_test.
* @memberof oval_test
*/
char *oval_test_get_id(struct oval_test *);
/**
* Returns attribute @ref oval_test->deprecated.
* @memberof oval_test
*/
bool oval_test_get_deprecated(struct oval_test *);
/**
* Returns attribute @ref oval_test->version.
* @memberof oval_test
*/
int oval_test_get_version(struct oval_test *);
/**
* Returns attribute @ref oval_test->state_operator.
* @memberof oval_test
*/
oval_operator_t oval_test_get_state_operator(struct oval_test *);
/**
* Returns attribute @ref oval_test->existence.
* @memberof oval_test
*/
oval_existence_t oval_test_get_existence(struct oval_test *);
/**
* Returns attribute @ref oval_test->check.
* @memberof oval_test
*/
oval_check_t oval_test_get_check(struct oval_test *);
/**
* Returns attribute @ref oval_test->object.
* @return A pointer to the object attribute of the specified @ref oval_test.
* @memberof oval_test
*/
struct oval_object *oval_test_get_object(struct oval_test *);
/**
* Returns attribute @ref oval_test->states.
* @return A new iterator for the states attribute of the specified @ref oval_test.
* It should be freed after use by the calling application.
* @memberof oval_test
*/
struct oval_state_iterator *oval_test_get_states(struct oval_test *);
/** @} */
/**
* @name Evaluators
* @{
*/
/** @} */
/**
* @name Iterators
* @{
*/
/**
* Returns <b>true</b> if the iterator is not exhausted.
* @memberof oval_test_iterator
*/
bool oval_test_iterator_has_more(struct oval_test_iterator *);
/**
* Returns the next instance of @ref oval_test.
* @memberof oval_test_iterator
*/
struct oval_test *oval_test_iterator_next(struct oval_test_iterator *);
/**
* Frees the iterator.
* @memberof oval_test_iterator
*/
void oval_test_iterator_free(struct oval_test_iterator *);
/** @} */
/**
* Construct new intance of @ref oval_object.
* Attribute values shall be initialized:
* - family -- initialized to @ref OVAL_FAMILY_UNKNOWN
* - subtype -- initialized to @ref OVAL_SUBTYPE_UNKNOWN
* - notes -- initialized to empty iterator
* - comment -- initialized to NULL
* - id -- initialized to a copy of the id parameter
* - deprecated -- initialized to <b>false</b>
* - version -- initialized to zero
* - contents -- initialized to empty iterator
* - behaviors -- initialized to empty iterator
*
* @note This method shall not construct a new instance of Oval_object and shall return NULL if the text of the id parameter is not matched
* by the regular expression <b>^oval:[\.A-Za-z0-9_\-]+:obj:[1-9][0-9]*$</b>.
* @param id - (Not NULL) the text of the required object id.
* @memberof oval_object
*/
struct oval_object *oval_object_new(struct oval_definition_model *, const char *id);
/**
* Clone instance of @ref oval_object and add it to the specified @ref oval_definition_model.
* @return A copy of the specified @ref oval_object.
* @memberof oval_object
*/
struct oval_object *oval_object_clone(struct oval_definition_model *new_model, struct oval_object *old_object);
/**
* Free instance of @ref oval_object
* @memberof oval_object
*/
void oval_object_free(struct oval_object *);
/**
* @name Setters
* @{
*/
/**
* Sets attributes @ref oval_object->subtype and @ref oval_object->family.
* If Oval_object->subtype == @ref OVAL_SUBTYPE_UNKNOWN and parameter subtype <> @ref OVAL_SUBTYPE_UNKNOWN,
* this method shall overwrite Oval_object->subtype with the value of the subtype parameter and Oval_object->family
* with the value of @ref oval_family_t corresponding to the specified subtype.
* Otherwise, the state of the Oval_object instance shall not be changed by this method.
* @param subtype - the required subtype value.
* @memberof oval_object
*/
void oval_object_set_subtype(struct oval_object *, oval_subtype_t subtype);
/**
* Appends a copy of the note parameter to attribute @ref oval_object->notes.
* @param note - (Not NULL) the text of the appended note.
* @memberof oval_object
*/
void oval_object_add_note(struct oval_object *, char *note);
/**
* Sets a copy of the comment parameter to attribute @ref oval_object->comment.
* @param comment - (Not NULL) the text of the comment.
* @memberof oval_object
*/
void oval_object_set_comment(struct oval_object *, char *comment);
/**
* Sets attribute @ref oval_object->deprecated.
* @memberof oval_object
*/
void oval_object_set_deprecated(struct oval_object *, bool deprecated);
/**
* Sets attribute @ref oval_object->version.
* If Oval_object->version == 0 and parameter version >0,
* this method shall overwrite Oval_object->version with the parameter value.
* Otherwise, the method shall leave the Oval_object state unchanged.
* @param version - (>0) the required version
* @memberof oval_object
*/
void oval_object_set_version(struct oval_object *, int version);
/**
* Append instance of @ref oval_object_content to attribute @ref oval_object->object_contents.
*
* Oval_object_contents appended to a given Oval_object shall be freed by the API when the Oval_object is freed.
*
* @note A specific instance of Oval_object_content should not be appended to more than one Oval_object,
* and an instance of Oval_object_content should not be appended more than once to a single Oval_object.
* @note An instance of Oval_object_content that is appended to an Oval_object should not be freed
* independently by the application using @ref oval_object_content_free.
* @param content - (Not NULL) the Oval_object_content to be appended.
* @memberof oval_object
*/
void oval_object_add_object_content(struct oval_object *, struct oval_object_content *content);
/**
* Append instance of @ref oval_behavior to attribute @ref oval_object->behaviors.
*
* Oval_behaviors appended to a given Oval_object shall be freed by the API when the Oval_object is freed.
*
* @note A specific instance of Oval_behavior should not be appended to more than one Oval_object,
* and an instance of Oval_behavior should not be appended more than once to a single Oval_object.
* @note An instance of Oval_behavior that is appended to an Oval_object should not be freed
* independently by the application using @ref oval_behavior_free.
* @param behavior - (Not NULL) the Oval_behavior to be appended.
* @memberof oval_object
*/
void oval_object_add_behavior(struct oval_object *, struct oval_behavior *behavior);
/** @} */
/**
* @name Getters
* @{
*/
/**
* Returns attribute @ref oval_object->family
* @memberof oval_object
*/
oval_family_t oval_object_get_family(struct oval_object *);
/**
* Returns the name of an @ref oval_object.
* This is a convenience method that is equivalent to @ref oval_subtype_get_text (@ref oval_object_get_subtype)+"_object".
* @memberof oval_object
*/
const char *oval_object_get_name(struct oval_object *);
/**
* Returns attribute @ref oval_object->subtype
* @memberof oval_object
*/
oval_subtype_t oval_object_get_subtype(struct oval_object *);
/**
* Returns attribute @ref oval_object->notes.
* @return A new iterator for the notes attribute of the specified @ref oval_object.
* It should be freed after use by the calling application.
* @memberof oval_object
*/
struct oval_string_iterator *oval_object_get_notes(struct oval_object *);
/**
* Returns attribute @ref oval_object->comment.
* @return A pointer to the comment attribute of the specified @ref oval_object.
* @memberof oval_object
*/
char *oval_object_get_comment(struct oval_object *);
/**
* Returns attribute @ref oval_object->id.
* @return A pointer to the id attribute of the specified @ref oval_object.
* @memberof oval_object
*/
char *oval_object_get_id(struct oval_object *);
/**
* Returns attribute @ref oval_object->deprecated.
* @memberof oval_object
*/
bool oval_object_get_deprecated(struct oval_object *);
/**
* Returns attribute @ref oval_object->version.
* @memberof oval_object
*/
int oval_object_get_version(struct oval_object *);
/**
* Returns schema version of the associated definition model
*/
OSCAP_DEPRECATED(oval_version_t oval_object_get_schema_version(struct oval_object *object));
/**
* Returns schema version of the associated platform extension definition model
* @memberof oval_object
*/
oval_schema_version_t oval_object_get_platform_schema_version(struct oval_object *object);
/**
* Returns attribute @ref oval_object->contents.
* @return A new iterator for the object_content attribute of the specified @ref oval_object.
* It should be freed after use by the calling application.
* @memberof oval_object
*/
struct oval_object_content_iterator *oval_object_get_object_contents(struct oval_object *);
/**
* Returns attribute @ref oval_object->behaviors.
* @return A new iterator for the behaviors attribute of the specified @ref oval_object.
* It should be freed after use by the calling application.
* @memberof oval_object
*/
struct oval_behavior_iterator *oval_object_get_behaviors(struct oval_object *);
/** @} */
/**
* @name Evaluators
* @{
*/
/** @} */
/**
* @name Iterators
* @{
*/
/**
* Returns <b>true</b> if the iterator is not exhausted.
* @memberof oval_object_iterator
*/
bool oval_object_iterator_has_more(struct oval_object_iterator *);
/**
* Returns the next instance of @ref oval_object.
* @memberof oval_object_iterator
*/
struct oval_object *oval_object_iterator_next(struct oval_object_iterator *);
/**
* Frees the iterator.
* @memberof oval_object_iterator
*/
void oval_object_iterator_free(struct oval_object_iterator *);
/** @} */
/**
* Construct new intance of @ref oval_state.
* Attribute values shall be initialized:
* - family -- initialized to @ref OVAL_FAMILY_UNKNOWN
* - subtype -- initialized to @ref OVAL_SUBTYPE_UNKNOWN
* - notes -- initialized to empty iterator
* - comment -- initialized to NULL
* - id -- initialized to a copy of the id parameter
* - deprecated -- initialized to <b>false</b>
* - version -- initialized to zero
* - operator -- initialized to @ref OVAL_OPERATOR_AND
* - contents -- initialized to empty iterator
*
* @note This method shall not construct a new instance of Oval_state and shall return NULL if the text of the id parameter is not matched
* by the regular expression <b>^oval:[\.A-Za-z0-9_\-]+:stt:[1-9][0-9]*$</b>.
* @param id - (Not NULL) the text of the required state id.
* @memberof oval_state
*/
struct oval_state *oval_state_new(struct oval_definition_model *, const char *id);
/**
* Clone instance of @ref oval_state and add it to the specified @ref oval_definition_model.
* @return A copy of the specified @ref oval_state.
* @memberof oval_state
*/
struct oval_state *oval_state_clone(struct oval_definition_model *new_model, struct oval_state *old_state);
/**
* Free instance of @ref oval_state
* @memberof oval_state
*/
void oval_state_free(struct oval_state *);
/**
* @name Setters
* @{
*/
/**
* Sets attributes @ref oval_state->subtype and @ref oval_state->family.
* If oval_state->subtype == @ref OVAL_SUBTYPE_UNKNOWN and parameter subtype <> @ref OVAL_SUBTYPE_UNKNOWN,
* this method shall overwrite oval_state->subtype with the value of the subtype parameter and oval_state->family
* with the value of @ref oval_family_t corresponding to the specified subtype.
* Otherwise, the state of the oval_state instance shall not be changed by this method.
* @param subtype - the required subtype value.
* @memberof oval_state
*/
void oval_state_set_subtype(struct oval_state *, oval_subtype_t subtype);
/**
* Appends a copy of the note parameter to attribute @ref oval_state->notes.
* @param note - (Not NULL) the text of the appended note.
* @memberof oval_state
*/
void oval_state_add_note(struct oval_state *, char *note);
/**
* Sets a copy of the comment parameter to attribute @ref oval_state->comment.
* @param comment - (Not NULL) the text of the comment.
* @memberof oval_state
*/
void oval_state_set_comment(struct oval_state *, char *comment);
/**
* Sets attribute @ref oval_state->deprecated.
* @memberof oval_state
*/
void oval_state_set_deprecated(struct oval_state *, bool deprecated);
/**
* Sets attribute @ref oval_state->version.
* If oval_state->version == 0 and parameter version >0,
* this method shall overwrite oval_state->version with the parameter value.
* Otherwise, the method shall leave the oval_state state unchanged.
* @param version - (>0) the required version
* @memberof oval_state
*/
void oval_state_set_version(struct oval_state *, int version);
/**
* Sets attribute @ref oval_state->operator.
* @memberof oval_state
*/
void oval_state_set_operator(struct oval_state *, oval_operator_t);
/**
* Append instance of @ref oval_state_content to attribute @ref oval_state->state_contents.
*
* oval_state_contents appended to a given oval_state shall be freed by the API when the oval_state is freed.
*
* @note A specific instance of oval_state_content should not be appended to more than one oval_state,
* and an instance of oval_state_content should not be appended more than once to a single oval_state.
* @note An instance of oval_state_content that is appended to an oval_state should not be freed
* independently by the application using @ref oval_state_content_free.
* @param content - (Not NULL) the oval_state_content to be appended.
* @memberof oval_state
*/
void oval_state_add_content(struct oval_state *, struct oval_state_content *content);
/** @} */
/**
* @name Getters
* @{
*/
/**
* Returns attribute @ref oval_state->family
* @memberof oval_state
*/
oval_family_t oval_state_get_family(struct oval_state *);
/**
* Returns the name of an @ref oval_state.
* This is a convenience method that is equivalent to @ref oval_subtype_get_text (@ref oval_state_get_subtype)+"_state".
* @memberof oval_state
*/
const char *oval_state_get_name(struct oval_state *);
/**
* Returns attribute @ref oval_state->subtype
* @memberof oval_state
*/
oval_subtype_t oval_state_get_subtype(struct oval_state *);
/**
* Returns attribute @ref oval_state->notes.
* @return A new iterator for the notes attribute of the specified @ref oval_state.
* It should be freed after use by the calling application.
* @memberof oval_state
*/
struct oval_string_iterator *oval_state_get_notes(struct oval_state *);
/**
* Returns attribute @ref oval_state->comment.
* @return A pointer to the comment attribute of the specified @ref oval_state.
* @memberof oval_state
*/
char *oval_state_get_comment(struct oval_state *);
/**
* Returns attribute @ref oval_state->id.
* @return A pointer to the id attribute of the specified @ref oval_state.
* @memberof oval_state
*/
char *oval_state_get_id(struct oval_state *);
/**
* Returns attribute @ref oval_state->deprecated.
* @memberof oval_state
*/
bool oval_state_get_deprecated(struct oval_state *);
/**
* Returns attribute @ref oval_state->version.
* @memberof oval_state
*/
int oval_state_get_version(struct oval_state *);
/**
* Returns attribute @ref oval_state->operator.
* @memberof oval_state
*/
int oval_state_get_operator(struct oval_state *);
/**
* Returns attribute @ref oval_state->contents.
* @return A new iterator for the contents attribute of the specified @ref oval_state.
* It should be freed after use by the calling application.
* @memberof oval_state
*/
struct oval_state_content_iterator *oval_state_get_contents(struct oval_state *);
/** @} */
/**
* @name Iterators
* @{
*/
/**
* Returns <b>true</b> if the iterator is not exhausted.
* @memberof oval_state_iterator
*/
bool oval_state_iterator_has_more(struct oval_state_iterator *);
/**
* Returns the next instance of @ref oval_state.
* @memberof oval_state_iterator
*/
struct oval_state *oval_state_iterator_next(struct oval_state_iterator *);
/**
* Frees the iterator.
* @memberof oval_state_iterator
*/
void oval_state_iterator_free(struct oval_state_iterator *);
/** @} */
/**
* @name Evaluators
* @{
*/
/** @} */
/**
* Construct new instance of @ref oval_variable.
* Attribute values shall be initialized:
* - id -- initialized to a copy of the id parameter
* - type -- initialized to the type parameter
* - version -- initialized to zero
* - deprecated -- initialized to <b>false</b>
* - comment -- initialized to NULL
* - datatype -- initialzed to @ref OVAL_DATATYPE_UNKNOWN
* - If type == @ref OVAL_VARIABLE_CONSTANT
* - values -- initialized to empty iterator
* - If type == @ref OVAL_VARIABLE_EXTERNAL
* - values -- initialized to NULL
* - If type == @ref OVAL_VARIABLE_LOCAL
* - component -- initialized to NULL
*
* This method shall not construct a new instance of oval_variable and shall return NULL
* - if the text of the id parameter is not matched by the regular expression <b>^oval:[\.A-Za-z0-9_\-]+:var:[1-9][0-9]*$</b>.
* - if the value of the type parameter is @ref OVAL_VARIABLE_UNKNOWN.
*
* @param id - (Not NULL) the text of the required variable id.
* @param type - (Not @ref OVAL_VARIABLE_UNKNOWN) the required type.
* @memberof oval_variable
*/
struct oval_variable *oval_variable_new(struct oval_definition_model *model, const char *id, oval_variable_type_t type);
/**
* Clone instance of @ref oval_variable and add it to the specified @ref oval_definition_model.
* @return A copy of the specified @ref oval_variable.
* @memberof oval_variable
*/
struct oval_variable *oval_variable_clone(struct oval_definition_model *new_model, struct oval_variable *old_variable);
/**
* Free instance of @ref oval_variable.
* @memberof oval_variable
*/
void oval_variable_free(struct oval_variable *);
/**
* Construct new instance of possible_value element.
* @param hint A short description of what the value means or represents.
* @param value An expected value of an external variable
* @memberof oval_variable_possible_value
*/
struct oval_variable_possible_value *oval_variable_possible_value_new(const char *hint, const char *value);
/**
* Free instance of possible_value
* @memberof oval_variable_possible_value
*/
void oval_variable_possible_value_free(struct oval_variable_possible_value *pv);
/**
* Construct new instance of possible_restriction element.
* @param operator Operator to evaluation
* @param hint A short description of what the value means or represents.
* @memberof oval_variable_possible_restriction
*/
struct oval_variable_possible_restriction *oval_variable_possible_restriction_new(oval_operator_t operator, const char *hint);
/**
* Free instance of possible_restriction
* @memberof oval_variable_possible_restriction
*/
void oval_variable_possible_restriction_free(struct oval_variable_possible_restriction *pr);
/**
* Construct new instance of restriction element.
* @param operation Operation of restriction.
* @param value Restriction placed on expected values for an external variable.
* @memberof oval_variable_restriction
*/
struct oval_variable_restriction *oval_variable_restriction_new(oval_operation_t operation, const char *value);
/**
* Free instance of restriction element.
* @memberof oval_variable_restriction
*/
void oval_variable_restriction_free(struct oval_variable_restriction *r);
/**
* @name Setters
* @{
*/
/**
* set attribute @ref oval_variable->comment.
* If attribute oval_variable->comment == NULL this method shall overwrite the attribute with a copy of the comment parameter.
* Otherwise the variable state shall be unchanged.
* @param comm - (Not NULL) a copy of the comment parameter is set as the comment attribute.
* @memberof oval_variable
*/
void oval_variable_set_comment(struct oval_variable *, char *comment);
/**
* set attribute @ref oval_variable->version.
* If attribute oval_variable->version == 0 this method shall overwrite the attribute with the version parameter.
* Otherwise the variable state shall be unchanged.
* @param version - (>0) the required version.
* @memberof oval_variable
*/
void oval_variable_set_version(struct oval_variable *, int version);
/**
* set attribute @ref oval_variable->deprecated.
* @param deprecated - the required deprecation toggle.
* @memberof oval_variable
*/
void oval_variable_set_deprecated(struct oval_variable *, bool deprecated);
/**
* set attribute @ref oval_variable->datatype.
* If attribute oval_variable->datatype == @ref OVAL_DATATYPE_UNKNOWN this method shall overwrite the attribute with the datatype parameter.
* Otherwise the variable state shall be unchanged.
* @param datatype - (Not @ref OVAL_DATATYPE_UNKNOWN) a the required datatype.
* @memberof oval_variable
*/
void oval_variable_set_datatype(struct oval_variable *, oval_datatype_t);
/**
* Append an instance of @ref Oval_value to the attribute @ref Oval_constant->values.
* If attribute type <> @ref OVAL_VARIABLE_CONSTANT or the value parameter is NULL the state of the oval_variable shall not be changed by this
* method.
* Otherwise, The value parameter shall be appended and shall be freed by the API when the Oval_constant is freed
*
* @note When a value is appended to an Oval_constant by an application, that value should not be subsequently
* freed by the application using @ref oval_value_free.
* @note An application should not append an Oval_value to more than one Oval_constant, and that
* an Oval_value should not be bound more than once to a single Oval_constant.
* @param value - the required value.
* @memberof oval_variable
*/
void oval_variable_add_value(struct oval_variable *, struct oval_value *); //type==OVAL_VARIABLE_CONSTANT
void oval_variable_clear_values(struct oval_variable *);
/**
* Add a new possible value to an external variable.
* @param variable Variable to add.
* @param pv The new possible_value.
* @memberof oval_variable
*/
void oval_variable_add_possible_value(struct oval_variable *variable, struct oval_variable_possible_value *pv);
/**
* Add a new possible restriction to an external variable.
* @param variable Variable to add.
* @param pr The new possible_restriction.
* @memberof oval_variable
*/
void oval_variable_add_possible_restriction(struct oval_variable *variable, struct oval_variable_possible_restriction *pr);
/**
* Add a restriction to the list of possible restrictions.
* @param pr A possible_restriction type
* @param r Restriction which will be added
* @memberof oval_variable_possible_restriction
*/
void oval_variable_possible_restriction_add_restriction(struct oval_variable_possible_restriction *pr, struct oval_variable_restriction *r);
/**
* Bind an instance of @ref Oval_component to the attribute @ref Oval_local->component.
* If attribute type <> @ref OVAL_VARIABLE_LOCAL, the component attribute <> NULL or the component parameter is NULL the state of the oval_variable shall not be changed by this
* method.
* Otherwise, The component parameter shall be bound to the component attribute and shall be freed by the API when the Oval_local is freed
*
* @note When an Oval_component is bound to an Oval_local by an application, the Oval_component should not be subsequently
* freed by the application using @ref oval_component_free.
* @note An application should not bind a single Oval_component to more than one Oval_local or to an Oval_local and an @ref Oval_function.
* @param component - the required component.
* @memberof oval_variable
*/
void oval_variable_set_component(struct oval_variable *, struct oval_component *component); //type==OVAL_VARIABLE_LOCAL
/** @} */
/**
* @name Getters
* @{
*/
/**
* Returns attribute @ref oval_variable->id.
* @return A pointer to the id attribute of the specified @ref oval_variable.
* @memberof oval_variable
*/
char *oval_variable_get_id(struct oval_variable *);
/**
* Returns attribute @ref oval_variable->comment.
* @return A pointer to the comment attribute of the specified @ref oval_variable.
* @memberof oval_variable
*/
char *oval_variable_get_comment(struct oval_variable *);
/**
* Returns attribute @ref oval_variable->version.
* @memberof oval_variable
*/
int oval_variable_get_version(struct oval_variable *);
/**
* Returns attribute @ref oval_variable->deprecated.
* @memberof oval_variable
*/
bool oval_variable_get_deprecated(struct oval_variable *);
/**
* Returns attribute @ref oval_variable->type.
* @memberof oval_variable
*/
oval_variable_type_t oval_variable_get_type(struct oval_variable *);
/**
* Returns attribute @ref oval_variable->datatype.
* @memberof oval_variable
*/
oval_datatype_t oval_variable_get_datatype(struct oval_variable *);
/**
* Returns attribute @ref Oval_external/@ref Oval_constant->values.
* If attribute type == @ref OVAL_VARIABLE_LOCAL or @ref OVAL_VARIABLE_UNKNOWN, this method shall return NULL
* @return A new iterator for the values attribute of the specified @ref oval_variable.
* It should be freed after use by the calling application.
* @memberof oval_variable
*/
struct oval_value_iterator *oval_variable_get_values(struct oval_variable *); //type==OVAL_VARIABLE_CONSTANT
/**
* Returns attribute @ref Oval_local->component.
* If attribute type <> @ref OVAL_VARIABLE_LOCAL this method shall return NULL.
* @return A pointer to the component attribute of the specified @ref oval_variable.
* @memberof oval_variable
*/
struct oval_component *oval_variable_get_component(struct oval_variable *); //type==OVAL_VARIABLE_LOCAL
/**
* Get list of allowed values for an external variable.
* @return A new iterator for the possible_value attribute of the specified @ref oval_variable.
* It should be freed after use by the calling application.
* @memberof oval_variable
*/
struct oval_iterator *oval_variable_get_possible_values(struct oval_variable *variable);
/**
* Get list of constraints for an external variable.
* @return A new iterator for the possible_restriction attribute of the specified @ref oval_variable.
* It should be freed after use by the calling application.
* @memberof oval_variable
*/
struct oval_iterator *oval_variable_get_possible_restrictions(struct oval_variable *variable);
/**
* Get restrictions from one possible_restriction element.
* @return A new iterator for the restriction attribute of possible_restriction.
* It should be freed after use by the calling application.
* @memberof oval_variable_possible_restriction
*/
struct oval_iterator *oval_variable_possible_restriction_get_restrictions(struct oval_variable_possible_restriction *possible_restriction);
/**
* Get operator of possible_restriction element
* @return operator
* @memberof oval_variable_possible_restriction
*/
oval_operator_t oval_variable_possible_restriction_get_operator(struct oval_variable_possible_restriction *possible_restriction);
/**
* Returns attribute @ref Oval_component_type->text.
* @memberof oval_variable
*/
const char *oval_component_type_get_text(oval_component_type_t type);
/** @} */
/**
* @name Iterators
* @{
*/
/**
* Returns <b>true</b> if iterator not exhausted.
* @memberof oval_variable_iterator
*/
bool oval_variable_iterator_has_more(struct oval_variable_iterator *);
/**
* Returns next instance of @ref oval_variable.
* @memberof oval_variable_iterator
*/
struct oval_variable *oval_variable_iterator_next(struct oval_variable_iterator *);
/**
* Free iterator.
* @memberof oval_variable_iterator
*/
void oval_variable_iterator_free(struct oval_variable_iterator *);
/** @} */
/**
* @name Evaluators
* @{
*/
/** @} */
/**
* Construct instance of @ref oval_affected.
* @memberof oval_affected
*/
struct oval_affected *oval_affected_new(struct oval_definition_model *);
/**
* Clone instance of @ref oval_affected.
* @return A copy of the specified @ref oval_affected.
* @memberof oval_affected
*/
struct oval_affected *oval_affected_clone(struct oval_definition_model *new_model, struct oval_affected *old_affected);
/**
* Release instance of @ref oval_affected.
* @memberof oval_affected
*/
void oval_affected_free(struct oval_affected *);
/**
* @name Setters
* @{
*/
/**
* Set @ref oval_affected family.
* @memberof oval_affected
*/
void oval_affected_set_family(struct oval_affected *, oval_affected_family_t family);
/**
* Append name to @ref oval_affected platform names.
* @memberof oval_affected
*/
void oval_affected_add_platform(struct oval_affected *, char *platform_name);
/**
* Append name to @ref oval_affected product names.
* @memberof oval_affected
*/
void oval_affected_add_product(struct oval_affected *, char *product_name);
/** @} */
/**
* @name Getters
* @{
*/
/**
* Get member value @ref oval_affected family.
* @note A family value of @ref OVAL_AFCFML_UNDEFINED signifies some family
* other than one of the defined values is targeted.
* @memberof oval_affected
*/
oval_affected_family_t oval_affected_get_family(struct oval_affected *);
/**
* Get member values @ref oval_affected platform_names.
* If the returned iterator is empty, then the associated Oval_definition is not constrained to a specific platform choice.
* @return A new iterator for the platforms attribute of the specified @ref oval_affected.
* It should be freed after use by the calling application.
* @memberof oval_affected
*/
struct oval_string_iterator *oval_affected_get_platforms(struct oval_affected *);
/**
* Get member values @ref oval_affected product_names.
* If the returned iterator is empty, then the associated Oval_definition is not constrained to a specific product choice.
* @return A new iterator for the products attribute of the specified @ref oval_affected.
* It should be freed after use by the calling application.
* @memberof oval_affected
*/
struct oval_string_iterator *oval_affected_get_products(struct oval_affected *);
/** @} */
/**
* @name Evaluators
* @{
*/
/** @} */
/**
* @name Iterators
* @{
*/
/**
* Return <b>true</b> if iterator has more @ref oval_affected.
* @memberof oval_affected_iterator
*/
bool oval_affected_iterator_has_more(struct oval_affected_iterator *);
/**
* Return next instance of @ref oval_affected from iterator.
* @memberof oval_affected_iterator
*/
struct oval_affected *oval_affected_iterator_next(struct oval_affected_iterator *);
/**
* Release instance of @ref oval_affected_ iterator.
* @memberof oval_affected_iterator
*/
void oval_affected_iterator_free(struct oval_affected_iterator *);
/** @} */
/**
* @memberof oval_reference
*/
struct oval_reference *oval_reference_new(struct oval_definition_model *);
/**
* @return A copy of the specified @ref oval_reference.
* @memberof oval_reference
*/
struct oval_reference *oval_reference_clone
(struct oval_definition_model *new_model, struct oval_reference *old_reference);
/**
* @memberof oval_reference
*/
void oval_reference_free(struct oval_reference *);
/**
* @name Setters
* @{
*/
/**
* Set OVAL reference source
* @memberof oval_reference
*/
void oval_reference_set_source(struct oval_reference *, char *);
/**
* @memberof oval_reference
*/
void oval_reference_set_id(struct oval_reference *, char *);
/**
* @memberof oval_reference
*/
void oval_reference_set_url(struct oval_reference *, char *);
/** @} */
/**
* @name Getters
* @{
*/
/**
* Get OVAL reference source.
* @return A pointer to the source attribute of the specified @ref oval_reference.
* @memberof oval_reference
*/
char *oval_reference_get_source(struct oval_reference *);
/**
* Get OVAL reference ID.
* @return A pointer to the id attribute of the specified @ref oval_reference.
* @memberof oval_reference
*/
char *oval_reference_get_id(struct oval_reference *);
/**
* Get OVAL reference URL.
* @return A pointer to the url attribute of the specified @ref oval_reference.
* @memberof oval_reference
*/
char *oval_reference_get_url(struct oval_reference *);
/** @} */
/**
* @name Iterators
* @{
*/
/**
* @memberof oval_reference_iterator
*/
bool oval_reference_iterator_has_more(struct oval_reference_iterator *);
/**
* @memberof oval_reference_iterator
*/
struct oval_reference *oval_reference_iterator_next(struct oval_reference_iterator *);
/**
* @memberof oval_reference_iterator
*/
void oval_reference_iterator_free(struct oval_reference_iterator *);
/** @} */
/**
* @name Evaluators
* @{
*/
/** @} */
/**
* Construct an instance of @ref oval_criteria_node.
* Initialized attribute values are:
* - type initialized to value of type parameter.
* - negate -- initialized to <b>false</b>
* - comment -- initialized to NULL
* - If type == @ref OVAL_NODETYPE_CRITERIA (@ref Oval_criteria):
* - operator -- initialized to @ref OVAL_OPERATOR_UNKNOWN
* - subnodes -- initialized to empty iterator
* - If type == @ref OVAL_NODETYPE_CRITERION (@ref Oval_criterion):
* - test -- initialized to NULL
* - If type == @ref OVAL_NODETYPE_EXTENDDEF (@ref Oval_extends):
* - definition -- initialized to NULL
* Careful ! Calling this function with inappropriate number of arguments will cause undefined behavior !
*
* If the type parameter is entered as @ref OVAL_NODETYPE_UNKNOWN, no instance shall be constructed
* and the method shall return NULL.
* @param type - the required node type.
* @memberof oval_criteria_node
*/
struct oval_criteria_node *oval_criteria_node_new(struct oval_definition_model *, oval_criteria_node_type_t type);
/**
* Clone an instance of @ref oval_criteria_node.
* @return A copy of the specified @ref oval_criteria_node.
* @memberof oval_criteria_node
*/
struct oval_criteria_node *oval_criteria_node_clone
(struct oval_definition_model *new_model, struct oval_criteria_node *old_node);
/**
* Free an instance of @ref oval_criteria_node.
* @memberof oval_criteria_node
*/
void oval_criteria_node_free(struct oval_criteria_node *);
/**
* @name Setters
* @{
*/
/**
* Set attribute @ref Oval_criteria_node->negate.
* @param negate - the required value of the negate attribute
* @memberof oval_criteria_node
*/
void oval_criteria_node_set_negate(struct oval_criteria_node *, bool negate);
/**
* Set attribute @ref Oval_criteria_node->applicability_check.
* @param applicability_check - the required value of the applicability_check attribute
* @memberof oval_criteria_node
*/
void oval_criteria_node_set_applicability_check(struct oval_criteria_node *, bool applicability_check);
/**
* Set attribute @ref Oval_criteria_node->type.
* @param type - the required value of the type attribute
* @memberof oval_criteria_node
*/
void oval_criteria_set_node_type(struct oval_criteria_node *node, oval_criteria_node_type_t type);
/**
* set attribute @ref Oval_criteria_node->comment.
* @param comm - (Not NULL) a copy of the comment parameter is set as the comment attribute.
* @memberof oval_criteria_node
*/
void oval_criteria_node_set_comment(struct oval_criteria_node *, char *comment);
/**
* Set attribute @ref Oval_criteria->operator.
* If Oval_criteria_node->type == @ref OVAL_NODETYPE_CRITERIA and the value of the operator attribute is @ref OVAL_OPERATOR_UNKNOWN,
* this method shall overwrite the operator attribute value with the operator parameter.
* Otherwise the Oval_criteria_node state shall not be changed by this method.
* @memberof oval_criteria_node
*/
void oval_criteria_node_set_operator(struct oval_criteria_node *, oval_operator_t op);
/**
* Append instance of @ref Oval_criteria_node to attribute @ref Oval_criteria->subnodes.
* If Oval_criteria_node->type <> @ref OVAL_NODETYPE_CRITERIA, this method shall return without changing the Oval_criteria_node state.
* @note Instances of Oval_criteria_node bound to an Oval_criteria by this method should not be subsequently freed by the application using oval_criteria_node_free.
* These instances shall be freed by the API when the Oval_criteria is freed.
* @note An application should not bind a given Oval_criteria_node as a subnode to more than one Oval_criteria,
* nor should a given Oval_criteria_node be bound more than once to a single Oval_criteria.
* @param - (Not NULL) the subnode to be appended.
* @memberof oval_criteria_node
*/
void oval_criteria_node_add_subnode(struct oval_criteria_node *, struct oval_criteria_node *node);
/**
* Sets attribute @ref Oval_criterion->test.
* If Oval_criteria_node->type == @ref OVAL_NODETYPE_CRITERION and the value of the test attribute is NULL,
* this method shall overwrite the test attribute value with the test parameter.
* Otherwise the Oval_criteria_node state shall not be changed by this method.
* @memberof oval_criteria_node
*/
void oval_criteria_node_set_test(struct oval_criteria_node *, struct oval_test *);
/**
* Sets attribute @ref Oval_extends->definition.
* If Oval_criteria_node->type == @ref OVAL_NODETYPE_EXTENDDEF and the value of the definition attribute is NULL,
* this method shall overwrite the definition attribute value with the definition parameter.
* Otherwise the Oval_criteria_node state shall not be changed by this method.
* @memberof oval_criteria_node
*/
void oval_criteria_node_set_definition(struct oval_criteria_node *, struct oval_definition *); //type==NODETYPE_EXTENDDEF
/** @} */
/**
* @name Getters
* @{
*/
/**
* Returns attribute @ref Oval_criteria_node->type.
* @memberof oval_criteria_node
*/
oval_criteria_node_type_t oval_criteria_node_get_type(struct oval_criteria_node *);
/**
* Returns attribute @ref Oval_criteria_node->negate.
* @memberof oval_criteria_node
*/
bool oval_criteria_node_get_negate(struct oval_criteria_node *);
/**
* Returns attribute @ref Oval_criteria_node->applicability_check.
* @memberof oval_criteria_node
*/
bool oval_criteria_node_get_applicability_check(struct oval_criteria_node *);
/**
* Returns attribute @ref Oval_criteria_node->comment.
* @return A pointer to the comment attribute of the specified @ref oval_criteria_node.
* @memberof oval_criteria_node
*/
char *oval_criteria_node_get_comment(struct oval_criteria_node *);
/**
* Returns attribute @ref Oval_criteria->operator HOWDI.
* @note If Oval_criteria_node->type <> @ref OVAL_NODETYPE_CRITERIA, this method shall return @ref OVAL_OPERATOR_UNKNOWN.
* @memberof oval_criteria_node
*/
oval_operator_t oval_criteria_node_get_operator(struct oval_criteria_node *);
/**
* Returns attribute @ref Oval_criteria_node->subnodes.
* If Oval_criteria_node->type <> @ref OVAL_NODETYPE_CRITERIA, this method shall return NULL.
* @return A new iterator for the subnodes attribute of the specified @ref oval_criteria_node.
* It should be freed after use by the calling application.
* @memberof oval_criteria_node
*/
struct oval_criteria_node_iterator *oval_criteria_node_get_subnodes(struct oval_criteria_node *);
/**
* Returns attribute @ref Oval_criterion->test.
* If Oval_criteria_node->type <> @ref OVAL_NODETYPE_CRITERION, this method shall return NULL.
* @return A pointer to the test attribute of the specified @ref oval_criteria_node.
* @memberof oval_criteria_node
*/
struct oval_test *oval_criteria_node_get_test(struct oval_criteria_node *);
/**
* Returns attribute @ref Oval_extends->definition.
* If Oval_criteria_node->type <> @ref OVAL_NODETYPE_EXTENDDEF, this method shall return NULL.
* @return A pointer to the definition attribute of the specified @ref oval_criteria_node.
* @memberof oval_criteria_node
*/
struct oval_definition *oval_criteria_node_get_definition(struct oval_criteria_node *);
/** @} */
/**
* @name Iterators
* @{
*/
/**
* Returns <b>true</b> if the iterator is not exhausted.
* @memberof oval_criteria_node_iterator
*/
bool oval_criteria_node_iterator_has_more(struct oval_criteria_node_iterator *);
/**
* Returns the next instance of @ref Oval_criteria_node from the iterator.
* Returns NULL if the iterator is exhausted.
* @memberof oval_criteria_node_iterator
*/
struct oval_criteria_node *oval_criteria_node_iterator_next(struct oval_criteria_node_iterator *);
/**
* Free the iterator.
* @memberof oval_criteria_node_iterator
*/
void oval_criteria_node_iterator_free(struct oval_criteria_node_iterator *);
/** @} */
/**
* @name Evaluators
* @{
*/
/** @} */
/**
* @memberof oval_object_content
*/
struct oval_object_content *oval_object_content_new(struct oval_definition_model *model, oval_object_content_type_t type);
/**
* @return A copy of the specified @ref oval_object_content.
* @memberof oval_object_content
*/
struct oval_object_content *oval_object_content_clone
(struct oval_definition_model *new_model, struct oval_object_content *old_content);
/**
* @memberof oval_object_content
*/
void oval_object_content_free(struct oval_object_content *);
/**
* @name Setters
* @{
*/
/**
* @memberof oval_object_content
*/
void oval_object_content_set_type(struct oval_object_content *, oval_object_content_type_t);
/**
* @memberof oval_object_content
*/
void oval_object_content_set_field_name(struct oval_object_content *, char *);
/**
* @memberof oval_object_content
*/
void oval_object_content_set_entity(struct oval_object_content *, struct oval_entity *); //type == OVAL_OBJECTCONTENT_ENTITY
/**
* @memberof oval_object_content
*/
void oval_object_content_set_varCheck(struct oval_object_content *, oval_check_t); //type == OVAL_OBJECTCONTENT_ENTITY
/**
* @memberof oval_object_content
*/
void oval_object_content_set_setobject(struct oval_object_content *, struct oval_setobject *); //type == OVAL_OBJECTCONTENT_SET
/** @} */
/**
* @name Getters
* @{
*/
/**
* Get field name of a object content.
* @return A pointer to the fieldName attribute of the specified @ref oval_object_content.
* @memberof oval_object_content
*/
char *oval_object_content_get_field_name(struct oval_object_content *);
/**
* Get type of a object content (entity or set).
* @memberof oval_object_content
*/
oval_object_content_type_t oval_object_content_get_type(struct oval_object_content *);
/**
* Get entity of a simple object content.
* @return A pointer to the entity attribute of the specified @ref oval_object_content.
* @memberof oval_object_content
*/
struct oval_entity *oval_object_content_get_entity(struct oval_object_content *); //type == OVAL_OBJECTCONTENT_ENTITY
/**
* Get varCheck of a simple object content.
* @memberof oval_object_content
*/
oval_check_t oval_object_content_get_varCheck(struct oval_object_content *); //type == OVAL_OBJECTCONTENT_ENTITY
/**
* Get setobject of a set object content.
* @return A pointer to the set attribute of the specified @ref oval_object_content.
* @memberof oval_object_content
*/
struct oval_setobject *oval_object_content_get_setobject(struct oval_object_content *); //type == OVAL_OBJECTCONTENT_SET
/** @} */
/**
* @name Iterators
* @{
*/
/**
* @memberof oval_object_content_iterator
*/
bool oval_object_content_iterator_has_more(struct oval_object_content_iterator *);
/**
* @memberof oval_object_content_iterator
*/
struct oval_object_content *oval_object_content_iterator_next(struct oval_object_content_iterator *);
/**
* @memberof oval_object_content_iterator
*/
void oval_object_content_iterator_free(struct oval_object_content_iterator *);
/** @} */
/**
* @name Evaluators
* @{
*/
/** @} */
/**
* @memberof oval_behavior
*/
struct oval_behavior *oval_behavior_new(struct oval_definition_model *);
/**
* @return A copy of the specified @ref oval_behavior.
* @memberof oval_behavior
*/
struct oval_behavior *oval_behavior_clone(struct oval_definition_model *new_model, struct oval_behavior *old_behavior);
/**
* @memberof oval_behavior
*/
void oval_behavior_free(struct oval_behavior *);
/**
* @name Setters
* @{
*/
/**
* @memberof oval_behavior
*/
void oval_behavior_set_keyval(struct oval_behavior *behavior, const char *key, const char *value);
/** @} */
/**
* @name Getters
* @{
*/
/**
* Get OVAL behavior name.
* @return A pointer to the key attribute of the specified @ref oval_behavior.
* @memberof oval_behavior
*/
char *oval_behavior_get_key(struct oval_behavior *);
/**
* Get OVAL behavior value.
* @return A pointer to the value attribute of the specified @ref oval_behavior.
* @memberof oval_behavior
*/
char *oval_behavior_get_value(struct oval_behavior *);
/** @} */
/**
* @name Iterators
* @{
*/
/**
* @memberof oval_behavior_iterator
*/
bool oval_behavior_iterator_has_more(struct oval_behavior_iterator *);
/**
* @memberof oval_behavior_iterator
*/
struct oval_behavior *oval_behavior_iterator_next(struct oval_behavior_iterator *);
/**
* @memberof oval_behavior_iterator
*/
void oval_behavior_iterator_free(struct oval_behavior_iterator *);
/** @} */
/**
* @name Evaluators
* @{
*/
/** @} */
/**
* @memberof oval_state_content
*/
struct oval_state_content *oval_state_content_new(struct oval_definition_model *);
/**
* @return A copy of the specified @ref oval_state_content.
* @memberof oval_state_content
*/
struct oval_state_content *oval_state_content_clone (struct oval_definition_model *new_model, struct oval_state_content *old_content);
/**
* @memberof oval_state_content
*/
void oval_state_content_free(struct oval_state_content *);
/**
* @name Setters
* @{
*/
/**
* @memberof oval_state_content
*/
void oval_state_content_set_entity(struct oval_state_content *, struct oval_entity *);
/**
* @memberof oval_state_content
*/
void oval_state_content_add_record_field(struct oval_state_content *, struct oval_record_field *);
/**
* @memberof oval_state_content
*/
void oval_state_content_set_varcheck(struct oval_state_content *, oval_check_t);
/**
* @memberof oval_state_content
*/
void oval_state_content_set_entcheck(struct oval_state_content *, oval_check_t);
/**
* Sets the "check_existence" attribute of an OVAL state entity
* @param content An entity within the state element
* @param existence New value of check_existence attribute of that entity
* @memberof oval_state_content
*/
void oval_state_content_set_check_existence(struct oval_state_content *content, oval_existence_t existence);
/** @} */
/**
* @name Getters
* @{
*/
/**
* Get entity of a state content.
* @return A pointer to the entity attribute of the specified @ref oval_state_content.
* @memberof oval_state_content
*/
struct oval_entity *oval_state_content_get_entity(struct oval_state_content *);
/**
* @memberof oval_state_content
*/
struct oval_record_field_iterator *oval_state_content_get_record_fields(struct oval_state_content *);
/**
* Get multipe variable values processing of a state content.
* @memberof oval_state_content
*/
oval_check_t oval_state_content_get_var_check(struct oval_state_content *);
/**
* Get multipe entities processing of a state content.
* @memberof oval_state_content
*/
oval_check_t oval_state_content_get_ent_check(struct oval_state_content *);
/**
* Get "check_existence" attribute of an OVAL state entity
* @param content An entity within the state element
* @return Value of the check_existence attribute
* @memberof oval_state_content
*/
oval_existence_t oval_state_content_get_check_existence(struct oval_state_content *content);
/** @} */
/**
* @name Iterators
* @{
*/
/**
* @ingroup oval_state_content_iterators
* @memberof oval_state_content_iterator
*/
bool oval_state_content_iterator_has_more(struct oval_state_content_iterator *);
/**
* @memberof oval_state_content_iterator
*/
struct oval_state_content *oval_state_content_iterator_next(struct oval_state_content_iterator *);
/**
* @memberof oval_state_content_iterator
*/
void oval_state_content_iterator_free(struct oval_state_content_iterator *);
/** @} */
/**
* @memberof oval_value
*/
struct oval_value *oval_value_new(oval_datatype_t datatype, char *text_value);
/**
* @return A copy of the specified @ref oval_value.
* @memberof oval_value
*/
struct oval_value *oval_value_clone(struct oval_value *old_value);
/**
* @memberof oval_value
*/
void oval_value_free(struct oval_value *);
/**
* @name Setters
* @{
*/
/**
* @memberof oval_value
*/
void oval_value_set_datatype(struct oval_value *, oval_datatype_t);
/**
* @name Getters
* @{
*/
/**
* Get OVAL value datatype.
* @memberof oval_value
*/
oval_datatype_t oval_value_get_datatype(struct oval_value *);
/**
* Get OVAL value as a text.
* @return A pointer to the text attribute of the specified @ref oval_value.
* @memberof oval_value
*/
char *oval_value_get_text(struct oval_value *);
/**
* Get OVAL value as a piece of raw binary data.
* @memberof oval_value
*/
unsigned char *oval_value_get_binary(struct oval_value *); //datatype==OVAL_DATATYPE_BINARY
/**
* Get OVAL value as a boolean.
* @memberof oval_value
*/
bool oval_value_get_boolean(struct oval_value *); //datatype==OVAL_DATATYPE_BOOLEAN
/**
* Get OVAL value as a floating point number.
* @memberof oval_value
*/
float oval_value_get_float(struct oval_value *); //datatype==OVAL_DATATYPE_FLOAT
/**
* Get OVAL value as an integer.
* @memberof oval_value
*/
long long oval_value_get_integer(struct oval_value *); //datatype==OVAL_DATATYPE_INTEGER
/** @} */
/**
* @name Iterators
* @{
*/
/**
* @memberof oval_value_iterator
*/
bool oval_value_iterator_has_more(struct oval_value_iterator *);
/**
* @memberof oval_value_iterator
*/
struct oval_value *oval_value_iterator_next(struct oval_value_iterator *);
/**
* @memberof oval_value_iterator
*/
int oval_value_iterator_remaining(struct oval_value_iterator *iterator);
/**
* @memberof oval_value_iterator
*/
void oval_value_iterator_free(struct oval_value_iterator *);
/** @} */
/**
* @name Evaluators
* @{
*/
/** @} */
/**
* @memberof oval_entity
*/
struct oval_entity *oval_entity_new(struct oval_definition_model *);
/**
* @return A copy of the specified @ref oval_entity.
* @memberof oval_entity
*/
struct oval_entity *oval_entity_clone(struct oval_definition_model *model, struct oval_entity *old_entity);
/**
* @memberof oval_entity
*/
void oval_entity_free(struct oval_entity *);
/**
* @name Setters
* @{
*/
/**
* @memberof oval_entity
*/
void oval_entity_set_type(struct oval_entity *, oval_entity_type_t);
/**
* @memberof oval_entity
*/
void oval_entity_set_datatype(struct oval_entity *, oval_datatype_t);
/**
* @memberof oval_entity
*/
void oval_entity_set_mask(struct oval_entity *, int);
/**
* @memberof oval_entity
*/
void oval_entity_set_varref_type(struct oval_entity *, oval_entity_varref_type_t);
/**
* @memberof oval_entity
*/
void oval_entity_set_variable(struct oval_entity *, struct oval_variable *);
/**
* @memberof oval_entity
*/
void oval_entity_set_value(struct oval_entity *, struct oval_value *);
/**
* @memberof oval_entity
*/
void oval_entity_set_name(struct oval_entity *, char *);
/**
* @memberof oval_entity
*/
void oval_entity_set_operation(struct oval_entity *, oval_operation_t);
/** @} */
/**
* @name Getters
* @{
*/
/**
* Get OVAL entity name.
* @return A pointer to the name attribute of the specified @ref oval_entity.
* @memberof oval_entity
*/
char *oval_entity_get_name(struct oval_entity *);
/**
* Get OVAL entity type.
* @memberof oval_entity
*/
oval_entity_type_t oval_entity_get_type(struct oval_entity *);
/**
* Get OVAL entity datatype.
* @memberof oval_entity
*/
oval_datatype_t oval_entity_get_datatype(struct oval_entity *);
/**
* Get OVAL entity operation type.
* @memberof oval_entity
*/
oval_operation_t oval_entity_get_operation(struct oval_entity *);
/**
* Get OVAL entity varref variable.
* @return A pointer to the variable attribute of the specified @ref oval_entity.
* @memberof oval_entity
*/
struct oval_variable *oval_entity_get_variable(struct oval_entity *);
/**
* Get OVAL entity value.
* @return A pointer to the value attribute of the specified @ref oval_entity.
* @memberof oval_entity
*/
struct oval_value *oval_entity_get_value(struct oval_entity *);
/**
* Get OVAL entity mask.
* @memberof oval_entity
*/
int oval_entity_get_mask(struct oval_entity *);
/**
* Get OVAL entity varref type.
* @memberof oval_entity
*/
oval_entity_varref_type_t oval_entity_get_varref_type(struct oval_entity *);
/** @} */
/**
* @name Iterators
* @{
*/
/**
* @memberof oval_entity_iterator
*/
bool oval_entity_iterator_has_more(struct oval_entity_iterator *);
/**
* @memberof oval_entity_iterator
*/
struct oval_entity *oval_entity_iterator_next(struct oval_entity_iterator *);
/**
* @memberof oval_entity_iterator
*/
void oval_entity_iterator_free(struct oval_entity_iterator *);
/** @} */
/**
* @name Evaluators
* @{
*/
/** @} */
/**
* @memberof oval_record_field
*/
struct oval_record_field *oval_record_field_new(oval_record_field_type_t);
/**
* @memberof oval_record_field
*/
struct oval_record_field *oval_record_field_clone(struct oval_record_field *);
/**
* @memberof oval_record_field
*/
void oval_record_field_free(struct oval_record_field *);
/**
* @name Setters
* @{
*/
/**
* @memberof oval_record_field
*/
void oval_record_field_set_name(struct oval_record_field *, char *);
/**
* @memberof oval_record_field
*/
void oval_record_field_set_value(struct oval_record_field *, char *);
/**
* @memberof oval_record_field
*/
void oval_record_field_set_datatype(struct oval_record_field *, oval_datatype_t);
/**
* @memberof oval_record_field
*/
void oval_record_field_set_mask(struct oval_record_field *, int);
/**
* @memberof oval_record_field
*/
void oval_record_field_set_operation(struct oval_record_field *, oval_operation_t);
/**
* @memberof oval_record_field
*/
void oval_record_field_set_variable(struct oval_record_field *, struct oval_variable *);
/**
* @memberof oval_record_field
*/
void oval_record_field_set_var_check(struct oval_record_field *, oval_check_t);
/**
* @memberof oval_record_field
*/
void oval_record_field_set_ent_check(struct oval_record_field *, oval_check_t);
/** @} */
/**
* @name Getters
* @{
*/
/**
* @memberof oval_record_field
*/
oval_record_field_type_t oval_record_field_get_type(struct oval_record_field *);
/**
* @memberof oval_record_field
*/
char *oval_record_field_get_name(struct oval_record_field *);
/**
* @memberof oval_record_field
*/
char *oval_record_field_get_value(struct oval_record_field *);
/**
* @memberof oval_record_field
*/
oval_datatype_t oval_record_field_get_datatype(struct oval_record_field *);
/**
* @memberof oval_record_field
*/
int oval_record_field_get_mask(struct oval_record_field *);
/**
* @memberof oval_record_field
*/
oval_operation_t oval_record_field_get_operation(struct oval_record_field *);
/**
* @memberof oval_record_field
*/
struct oval_variable *oval_record_field_get_variable(struct oval_record_field *);
/**
* @memberof oval_record_field
*/
oval_check_t oval_record_field_get_var_check(struct oval_record_field *);
/**
* @memberof oval_record_field
*/
oval_check_t oval_record_field_get_ent_check(struct oval_record_field *);
/** @} */
/**
* @name Iterators
* @{
*/
/**
* @memberof oval_record_field
*/
bool oval_record_field_iterator_has_more(struct oval_record_field_iterator *);
/**
* @memberof oval_record_field
*/
struct oval_record_field *oval_record_field_iterator_next(struct oval_record_field_iterator *);
/**
* @memberof oval_record_field
*/
void oval_record_field_iterator_free(struct oval_record_field_iterator *);
/** @} */
/**
* @name Evaluators
* @{
*/
/** @} */
/**
* @memberof oval_filter
*/
struct oval_filter *oval_filter_new(struct oval_definition_model *);
/**
* @memberof oval_filter
*/
void oval_filter_free(struct oval_filter *);
/**
* @memberof oval_filter
*/
struct oval_filter *oval_filter_clone(struct oval_definition_model *, struct oval_filter *);
/**
* @name Setters
* @{
*/
/**
* @memberof oval_filter
*/
void oval_filter_set_state(struct oval_filter *, struct oval_state *);
/**
* @memberof oval_filter
*/
void oval_filter_set_filter_action(struct oval_filter *, oval_filter_action_t );
/** @} */
/**
* @name Getters
* @{
*/
/**
* @memberof oval_filter
*/
struct oval_state *oval_filter_get_state(struct oval_filter *);
/**
* @memberof oval_filter
*/
oval_filter_action_t oval_filter_get_filter_action(struct oval_filter *);
/** @} */
/**
* @name Iterators
* @{
*/
/**
* @memberof oval_filter
*/
bool oval_filter_iterator_has_more(struct oval_filter_iterator *);
/**
* @memberof oval_filter
*/
struct oval_filter *oval_filter_iterator_next(struct oval_filter_iterator *);
/**
* @memberof oval_filter
*/
void oval_filter_iterator_free(struct oval_filter_iterator *);
/** @} */
/**
* @name Evaluators
* @{
*/
/** @} */
/**
* @memberof oval_setobject
*/
struct oval_setobject *oval_setobject_new(struct oval_definition_model *);
/**
* @return A copy of the specified @ref oval_setobject.
* @memberof oval_setobject
*/
struct oval_setobject *oval_setobject_clone(struct oval_definition_model *new_model, struct oval_setobject *old_setobject);
/**
* @memberof oval_setobject
*/
void oval_setobject_free(struct oval_setobject *);
/**
* @name Setters
* @{
*/
/**
*/
void oval_setobject_set_type(struct oval_setobject *, oval_setobject_type_t);
/**
* @memberof oval_setobject
*/
void oval_setobject_set_operation(struct oval_setobject *, oval_setobject_operation_t);
/**
* @memberof oval_setobject
*/
void oval_setobject_add_subset(struct oval_setobject *, struct oval_setobject *); //type==OVAL_SET_AGGREGATE;
/**
* @memberof oval_setobject
*/
void oval_setobject_add_object(struct oval_setobject *, struct oval_object *); //type==OVAL_SET_COLLECTIVE;
/**
* @memberof oval_setobject
*/
void oval_setobject_add_filter(struct oval_setobject *, struct oval_filter *); //type==OVAL_SET_COLLECTIVE;
/** @} */
/**
* @name Getters
* @{
*/
/**
* Get OVAL set object type.
* @memberof oval_setobject
*/
oval_setobject_type_t oval_setobject_get_type(struct oval_setobject *);
/**
* Get OVAL set object operation type.
* @memberof oval_setobject
*/
oval_setobject_operation_t oval_setobject_get_operation(struct oval_setobject *);
/**
* Get OVAL set object subsets.
* This works only with sets of OVAL_SET_AGGREGATE type.
* @return A new iterator for the subsets attribute of the specified @ref oval_setobject.
* It should be freed after use by the calling application.
* @memberof oval_setobject
*/
struct oval_setobject_iterator *oval_setobject_get_subsets(struct oval_setobject *); //type==OVAL_SET_AGGREGATE;
/**
* Get OVAL set object referenced objects.
* This works only with sets of OVAL_SET_COLLECTIVE type.
* @return A new iterator for the objects attribute of the specified @ref oval_setobject.
* It should be freed after use by the calling application.
* @memberof oval_setobject
*/
struct oval_object_iterator *oval_setobject_get_objects(struct oval_setobject *); //type==OVAL_SET_COLLECTIVE;
/**
* Get OVAL set object filters.
* This works only with sets of OVAL_SET_COLLECTIVE type.
* @return A new iterator for the filters attribute of the specified @ref oval_setobject.
* It should be freed after use by the calling application.
* @memberof oval_setobject
*/
struct oval_filter_iterator *oval_setobject_get_filters(struct oval_setobject *); //type==OVAL_SET_COLLECTIVE;
/** @} */
/**
* @name Iterators
* @{
*/
/**
* @memberof oval_setobject_iterator
*/
bool oval_setobject_iterator_has_more(struct oval_setobject_iterator *);
/**
* @memberof oval_setobject_iterator
*/
struct oval_setobject *oval_setobject_iterator_next(struct oval_setobject_iterator *);
/**
* @memberof oval_setobject_iterator
*/
void oval_setobject_iterator_free(struct oval_setobject_iterator *);
/** @} */
/**
* @name Evaluators
* @{
*/
/** @} */
/**
* Construct new intance of @ref Oval_component.
* Attribute values shall be initialized:
* - type -- initialized to the value of the type parameter.
* - If type == @ref OVAL_FUNCTION_CONCAT
* - components -- initialized to empty iterator
* - If type == @ref OVAL_FUNCTION_COUNT
* - components -- initialized to empty iterator
* - If type == @ref OVAL_FUNCTION_ESCAPE_REGEX
* - components -- initialized to empty iterator
* - If type == @ref OVAL_FUNCTION_ARITHMETIC
* - arithmetic_operation -- initialized to @ref OVAL_ARITHMETIC_UNKNOWN
* - components -- initialized to empty iterator
* - If type == @ref OVAL_FUNCTION_BEGIN
* - prefix -- initialized to NULL
* - components -- initialized to empty iterator
* - If type == @ref OVAL_FUNCTION_END
* - suffix -- initialized to NULL
* - components -- initialized to empty iterator
* - If type == @ref OVAL_FUNCTION_SPLIT
* - delimiter -- initialized to NULL
* - components -- initialized to empty iterator
* - If type == @ref OVAL_FUNCTION_SUBSTRING
* - start, length -- initialized to zero
* - components -- initialized to empty iterator
* - If type == @ref OVAL_FUNCTION_TIMEDIF
* - timedif_format_1, timedif_format_2 -- initialized to @ref OVAL_DATETIME_UNKNOWN
* - components -- initialized to empty iterator
* - If type == @ref OVAL_FUNCTION_REGEX_CAPTURE
* - pattern -- initialized to NULL
* - components -- initialized to empty iterator
* - If type == @ref OVAL_COMPONENT_LITERAL
* - literal -- initialized to NULL
* - If type == @ref OVAL_COMPONENT_OBJECTREF
* - object -- initialized to NULL
* - object_field -- initialized to NULL
* - If type == @ref OVAL_COMPONENT_VARREF
* - variable -- initialized to NULL
*
* This method shall not construct a new instance of Oval_object and shall return NULL if the type parameter is entered as @ref OVAL_COMPONENT_UNKNOWN.
* @param type - the required component type.
* @memberof oval_component
*/
struct oval_component *oval_component_new(struct oval_definition_model *, oval_component_type_t type);
/**
* Clone instance of @ref Oval_component.
* @return A copy of the specified @ref oval_component.
* @memberof oval_component
*/
struct oval_component *oval_component_clone(struct oval_definition_model *new_model,
struct oval_component *old_component);
/**
* Free instance of @ref Oval_component
* @memberof oval_component
*/
void oval_component_free(struct oval_component *);
/**
* @name Setters
* @{
*/
/**
* Set type of component @ref Oval_component->type
* @memberof oval_component
*/
void oval_component_set_type(struct oval_component *component, oval_component_type_t type);
/**
* set attribute @ref Oval_component_object->object.
* IF component->type <> @ref OVAL_COMPONENT_OBJECTREF OR component->object <> NULL, this method does nothing .
* @memberof oval_component
*/
void oval_component_set_object(struct oval_component *, struct oval_object *object);
/**
* set attribute @ref Oval_component_object->item_field.
* @memberof oval_component
*/
void oval_component_set_item_field(struct oval_component *, char *);
/**
* set attribute @ref Oval_component_object->record_field.
* @memberof oval_component
*/
void oval_component_set_record_field(struct oval_component *, char *);
/**
* set attribute @ref Oval_component_object->variable.
* IF component->type <> @ref OVAL_COMPONENT_OBJECTREF OR component->variable <> NULL, this method does nothing.
* @memberof oval_component
*/
void oval_component_set_variable(struct oval_component *, struct oval_variable *variable);
/**
* @memberof oval_component
*/
void oval_component_add_function_component(struct oval_component *, struct oval_component *); //type==OVAL_COMPONENT_FUNCTION
/**
* @memberof oval_component
*/
void oval_component_set_arithmetic_operation(struct oval_component *, oval_arithmetic_operation_t); //type==OVAL_COMPONENT_ARITHMETIC
/**
* @memberof oval_component
*/
void oval_component_set_prefix(struct oval_component *, char *); //type==OVAL_COMPONENT_BEGIN
/**
* @memberof oval_component
*/
void oval_component_set_suffix(struct oval_component *, char *); //type==OVAL_COMPONENT_END
/**
* @memberof oval_component
*/
void oval_component_set_split_delimiter(struct oval_component *, char *); //type==OVAL_COMPONENT_SPLIT
/**
* @memberof oval_component
*/
void oval_component_set_glob_to_regex_glob_noescape(struct oval_component *, bool); //type==OVAL_COMPONENT_GLOB
/**
* @memberof oval_component
*/
void oval_component_set_substring_start(struct oval_component *, int); //type==OVAL_COMPONENT_SUBSTRING
/**
* @memberof oval_component
*/
void oval_component_set_substring_length(struct oval_component *, int); //type==OVAL_COMPONENT_SUBSTRING
/**
* @memberof oval_component
*/
void oval_component_set_timedif_format_1(struct oval_component *, oval_datetime_format_t); //type==OVAL_COMPONENT_TIMEDIF
/**
* @memberof oval_component
*/
void oval_component_set_timedif_format_2(struct oval_component *, oval_datetime_format_t); //type==OVAL_COMPONENT_TIMEDIF
/**
* @memberof oval_component
*/
void oval_component_set_regex_pattern(struct oval_component *, char *); //type==OVAL_COMPONENT_REGEX_CAPTURE
/**
* @memberof oval_component
*/
void oval_component_set_literal_value(struct oval_component *, struct oval_value *); //type==OVAL_COMPONENT_LITERAL
/** @} */
/**
* @name Getters
* @{
*/
/**
* Returns attribute @ref Oval_component->type
* @memberof oval_component
*/
oval_component_type_t oval_component_get_type(struct oval_component *);
/**
* Returns attribute @ref Oval_component_object->object.
* IF component->type <> @ref OVAL_COMPONENT_OBJECTREF, this method shall return NULL.
* @return A pointer to the object attribute of the specified @ref oval_component.
* @note applications should not free the @ref Oval_object returned by this method
* @memberof oval_component
*/
struct oval_object *oval_component_get_object(struct oval_component *); //type==OVAL_COMPONENT_OBJECTREF
/**
* Returns attribute @ref Oval_component_object->item_field.
* @return A pointer to the item_field attribute of the specified @ref oval_component.
* @note applications should not free the char* returned by this method
* @memberof oval_component
*/
char *oval_component_get_item_field(struct oval_component *);
/**
* Returns attribute @ref Oval_component_object->record_field.
* @return A pointer to the record_field attribute of the specified @ref oval_component.
* @note applications should not free the char* returned by this method
* @memberof oval_component
*/
char *oval_component_get_record_field(struct oval_component *);
/**
* Returns attribute @ref Oval_component_variable->variable.
* IF component->type <> @ref OVAL_COMPONENT_VARREF, this method shall return NULL.
* @return A pointer to the variable attribute of the specified @ref oval_component.
* @note applications should not free the @ref Oval_variable returned by this method
* @memberof oval_component
*/
struct oval_variable *oval_component_get_variable(struct oval_component *);
/**
* Returns attribute @ref Oval_function->components.
* IF component->type < @ref OVAL_COMPONENT_FUNCTION, this method shall return NULL.
* @return A new iterator for the function_components attribute of the specified @ref oval_component.
* It should be freed after use by the calling application.
* @memberof oval_component
*/
struct oval_component_iterator *oval_component_get_function_components(struct oval_component *); //type==OVAL_COMPONENT_FUNCTION
/**
* Returns attribute @ref Oval_function_ARITHMETIC->arithmetic_operation.
* IF component->type <> @ref OVAL_FUNCTION_ARITHMETIC, this method shall return @ref OVAL_ARITHMETIC_UNKNOWN.
* @memberof oval_component
*/
oval_arithmetic_operation_t oval_component_get_arithmetic_operation(struct oval_component *); //type==OVAL_COMPONENT_ARITHMETIC
/**
* Returns attribute @ref Oval_function_BEGIN->prefix.
* IF component->type <> @ref OVAL_FUNCTION_BEGIN, this method shall return NULL
* @return A pointer to the attribute of the specified @ref oval_component.
* @note applications should not free the char* returned by this method
* @memberof oval_component
*/
char *oval_component_get_prefix(struct oval_component *); //type==OVAL_COMPONENT_BEGIN
/**
* Returns attribute @ref Oval_function_END->suffix.
* IF component->type <> @ref OVAL_FUNCTION_END, this method shall return NULL
* @return A pointer to the attribute of the specified @ref oval_component.
* @note applications should not free the char* returned by this method
* @memberof oval_component
*/
char *oval_component_get_suffix(struct oval_component *); //type==OVAL_COMPONENT_END
/**
* Returns attribute @ref Oval_function_SPLIT->delimiter.
* IF component->type <> @ref OVAL_FUNCTION_SPLIT, this method shall return NULL
* @return A pointer to the attribute of the specified @ref oval_component.
* @note applications should not free the char* returned by this method
* @memberof oval_component
*/
char *oval_component_get_split_delimiter(struct oval_component *); //type==OVAL_COMPONENT_SPLIT
/**
* Returns attribute @ref Oval_function_GLOB_TO_REGEX->glob_noescape.
* IF component->type <> @ref OVAL_FUNCTION_GLOB_TO_REGEX, this method shall return false
* @return An attribute of the specified @ref oval_component.
* @memberof oval_component
*/
bool oval_component_get_glob_to_regex_glob_noescape(struct oval_component *); //type==OVAL_COMPONENT_GLOB
/**
* Returns attribute @ref Oval_function_SUBSTRING->start.
* IF component->type <> @ref OVAL_FUNCTION_SUBSTRING, this method shall return 0
* @memberof oval_component
*/
int oval_component_get_substring_start(struct oval_component *); //type==OVAL_COMPONENT_SUBSTRING
/**
* Returns attribute @ref Oval_function_SUBSTRING->length.
* IF component->type <> @ref OVAL_FUNCTION_SUBSTRING, this method shall return 0
* @memberof oval_component
*/
int oval_component_get_substring_length(struct oval_component *); //type==OVAL_COMPONENT_SUBSTRING
/**
* Returns attribute @ref Oval_function_TIMEDIF->timedif_format_1.
* IF component->type <> @ref OVAL_FUNCTION_TIMEDIF, this method shall return @ref OVAL_TIMEDATE_UNKNOWN
* @memberof oval_component
*/
oval_datetime_format_t oval_component_get_timedif_format_1(struct oval_component *); //type==OVAL_COMPONENT_TIMEDIF
/**
* Returns attribute @ref Oval_function_TIMEDIF->timedif_format_2.
* IF component->type <> @ref OVAL_FUNCTION_TIMEDIF, this method shall return @ref OVAL_TIMEDATE_UNKNOWN
* @memberof oval_component
*/
oval_datetime_format_t oval_component_get_timedif_format_2(struct oval_component *); //type==OVAL_COMPONENT_TIMEDIF
/**
* Returns attribute @ref Oval_function_REGEX_CAPTURE->pattern.
* IF component->type <> @ref OVAL_FUNCTION_REGEX_CAPTURE, this method shall return NULL
* @return A pointer to the attribute of the specified @ref oval_component.
* @note applications should not free the char* returned by this method
* @memberof oval_component
*/
char *oval_component_get_regex_pattern(struct oval_component *); //type==OVAL_COMPONENT_REGEX_CAPTURE
/**
* Returns attribute @ref Oval_literal->literal.
* IF component->type <> @ref OVAL_COMPONENT_LITERAL, this method shall return NULL
* @return A pointer to the value attribute of the specified @ref oval_component.
* @note applications should not free the @ref Oval_value returned by this method
* @memberof oval_component
*/
struct oval_value *oval_component_get_literal_value(struct oval_component *); //type==OVAL_COMPONENT_LITERAL
/** @} */
/**
* @name Iterators
* @{
*/
/**
* Return <b>true</b> if the iterator is not exhausted.
* @memberof oval_component_iterator
*/
bool oval_component_iterator_has_more(struct oval_component_iterator *);
/**
* return the next instance of @ref Oval_component.
* If the iterator is exhausted this method shall return NULL.
* @memberof oval_component_iterator
*/
struct oval_component *oval_component_iterator_next(struct oval_component_iterator *);
/**
* Free the iterator.
* @memberof oval_component_iterator
*/
void oval_component_iterator_free(struct oval_component_iterator *);
/**
* How many remains.
* @memberof oval_component_iterator
*/
int oval_component_iterator_remaining(struct oval_component_iterator *);
/** @} */
/**
* @name Evaluators
* @{
*/
/** @} */
/**
* @} END OVALDEF
*/
/**
* Returns the version of the schema this document should be validated against
*
* Deallocate the result after use with "free(..)".
* @deprecated This function has been deprecated by @ref oscap_source_get_schema_version.
* This function may be dropped from later versions of the library.
*/
OSCAP_DEPRECATED(char *oval_determine_document_schema_version(const char *, oscap_document_type_t));
/**
* @} END OVAL
*/
#endif
|