| 1 | /* |
| 2 | * Summary: interface for the libxslt security framework |
| 3 | * Description: the libxslt security framework allow to restrict |
| 4 | * the access to new resources (file or URL) from |
| 5 | * the stylesheet at runtime. |
| 6 | * |
| 7 | * Copy: See Copyright for the status of this software. |
| 8 | * |
| 9 | * Author: Daniel Veillard |
| 10 | */ |
| 11 | |
| 12 | #ifndef __XML_XSLT_SECURITY_H__ |
| 13 | #define __XML_XSLT_SECURITY_H__ |
| 14 | |
| 15 | #include <libxml/tree.h> |
| 16 | #include "xsltexports.h" |
| 17 | #include "xsltInternals.h" |
| 18 | |
| 19 | #ifdef __cplusplus |
| 20 | extern "C" { |
| 21 | #endif |
| 22 | |
| 23 | /** |
| 24 | * xsltSecurityPref: |
| 25 | * |
| 26 | * structure to indicate the preferences for security in the XSLT |
| 27 | * transformation. |
| 28 | */ |
| 29 | typedef struct _xsltSecurityPrefs xsltSecurityPrefs; |
| 30 | typedef xsltSecurityPrefs *xsltSecurityPrefsPtr; |
| 31 | |
| 32 | /** |
| 33 | * xsltSecurityOption: |
| 34 | * |
| 35 | * the set of option that can be configured |
| 36 | */ |
| 37 | typedef enum { |
| 38 | XSLT_SECPREF_READ_FILE = 1, |
| 39 | XSLT_SECPREF_WRITE_FILE, |
| 40 | XSLT_SECPREF_CREATE_DIRECTORY, |
| 41 | XSLT_SECPREF_READ_NETWORK, |
| 42 | XSLT_SECPREF_WRITE_NETWORK |
| 43 | } xsltSecurityOption; |
| 44 | |
| 45 | /** |
| 46 | * xsltSecurityCheck: |
| 47 | * |
| 48 | * User provided function to check the value of a string like a file |
| 49 | * path or an URL ... |
| 50 | */ |
| 51 | typedef int (*xsltSecurityCheck) (xsltSecurityPrefsPtr sec, |
| 52 | xsltTransformContextPtr ctxt, |
| 53 | const char *value); |
| 54 | |
| 55 | /* |
| 56 | * Module interfaces |
| 57 | */ |
| 58 | XSLTPUBFUN xsltSecurityPrefsPtr XSLTCALL |
| 59 | xsltNewSecurityPrefs (void); |
| 60 | XSLTPUBFUN void XSLTCALL |
| 61 | xsltFreeSecurityPrefs (xsltSecurityPrefsPtr sec); |
| 62 | XSLTPUBFUN int XSLTCALL |
| 63 | xsltSetSecurityPrefs (xsltSecurityPrefsPtr sec, |
| 64 | xsltSecurityOption option, |
| 65 | xsltSecurityCheck func); |
| 66 | XSLTPUBFUN xsltSecurityCheck XSLTCALL |
| 67 | xsltGetSecurityPrefs (xsltSecurityPrefsPtr sec, |
| 68 | xsltSecurityOption option); |
| 69 | |
| 70 | XSLTPUBFUN void XSLTCALL |
| 71 | xsltSetDefaultSecurityPrefs (xsltSecurityPrefsPtr sec); |
| 72 | XSLTPUBFUN xsltSecurityPrefsPtr XSLTCALL |
| 73 | xsltGetDefaultSecurityPrefs (void); |
| 74 | |
| 75 | XSLTPUBFUN int XSLTCALL |
| 76 | xsltSetCtxtSecurityPrefs (xsltSecurityPrefsPtr sec, |
| 77 | xsltTransformContextPtr ctxt); |
| 78 | |
| 79 | XSLTPUBFUN int XSLTCALL |
| 80 | xsltSecurityAllow (xsltSecurityPrefsPtr sec, |
| 81 | xsltTransformContextPtr ctxt, |
| 82 | const char *value); |
| 83 | XSLTPUBFUN int XSLTCALL |
| 84 | xsltSecurityForbid (xsltSecurityPrefsPtr sec, |
| 85 | xsltTransformContextPtr ctxt, |
| 86 | const char *value); |
| 87 | /* |
| 88 | * internal interfaces |
| 89 | */ |
| 90 | XSLTPUBFUN int XSLTCALL |
| 91 | xsltCheckWrite (xsltSecurityPrefsPtr sec, |
| 92 | xsltTransformContextPtr ctxt, |
| 93 | const xmlChar *URL); |
| 94 | XSLTPUBFUN int XSLTCALL |
| 95 | xsltCheckRead (xsltSecurityPrefsPtr sec, |
| 96 | xsltTransformContextPtr ctxt, |
| 97 | const xmlChar *URL); |
| 98 | |
| 99 | #ifdef __cplusplus |
| 100 | } |
| 101 | #endif |
| 102 | |
| 103 | #endif /* __XML_XSLT_SECURITY_H__ */ |
| 104 | |
| 105 | |