aclproto.h 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. /** BEGIN COPYRIGHT BLOCK
  2. * Copyright (C) 2001 Sun Microsystems, Inc. Used by permission.
  3. * Copyright (C) 2005 Red Hat, Inc.
  4. * All rights reserved.
  5. * END COPYRIGHT BLOCK **/
  6. #ifndef ACL_PROTO_HEADER
  7. #define ACL_PROTO_HEADER
  8. #ifndef NOINTNSACL
  9. #define INTNSACL
  10. #endif /* !NOINTNSACL */
  11. #ifndef PUBLIC_NSACL_ACLDEF_H
  12. #include "public/nsacl/acldef.h"
  13. #endif /* !PUBLIC_NSACL_ACLDEF_H */
  14. #ifdef INTNSACL
  15. NSPR_BEGIN_EXTERN_C
  16. /*********************************************************************
  17. * ACL language and file interfaces
  18. *********************************************************************/
  19. NSAPI_PUBLIC ACLListHandle_t * ACL_ParseFile(NSErr_t *errp, char *filename);
  20. NSAPI_PUBLIC ACLListHandle_t * ACL_ParseString(NSErr_t *errp, char *buffer);
  21. NSAPI_PUBLIC int ACL_Decompose(NSErr_t *errp, char **acl, ACLListHandle_t *acl_list);
  22. NSAPI_PUBLIC int ACL_WriteString(NSErr_t *errp, char **acl, ACLListHandle_t *acllist);
  23. NSAPI_PUBLIC int ACL_WriteFile(NSErr_t *errp, char *filename, ACLListHandle_t *acllist);
  24. NSAPI_PUBLIC int ACL_FileRenameAcl(NSErr_t *errp, char *filename, char *acl_name, char *new_acl_name, int flags);
  25. NSAPI_PUBLIC int ACL_FileDeleteAcl(NSErr_t *errp, char *filename, char *acl_name, int flags);
  26. NSAPI_PUBLIC int ACL_FileGetAcl(NSErr_t *errp, char *filename, char *acl_name, char **acl_text, int flags);
  27. NSAPI_PUBLIC int ACL_FileSetAcl(NSErr_t *errp, char *filename, char *acl_text, int flags);
  28. NSAPI_PUBLIC int ACL_FileMergeAcl(NSErr_t *errp, char *filename, char **acl_name_list, char *new_acl_name, int flags);
  29. NSAPI_PUBLIC int ACL_FileMergeFile(NSErr_t *errp, char *filename, char **file_list, int flags);
  30. /*********************************************************************
  31. * ACL Expression construction interfaces
  32. *********************************************************************/
  33. NSAPI_PUBLIC ACLExprHandle_t *ACL_ExprNew(const ACLExprType_t expr_type);
  34. NSAPI_PUBLIC void ACL_ExprDestroy(ACLExprHandle_t *expr);
  35. NSAPI_PUBLIC int ACL_ExprSetPFlags(NSErr_t *errp, ACLExprHandle_t *expr, PFlags_t flags);
  36. NSAPI_PUBLIC int ACL_ExprClearPFlags(NSErr_t *errp, ACLExprHandle_t *expr);
  37. NSAPI_PUBLIC int ACL_ExprTerm(NSErr_t *errp, ACLExprHandle_t *acl_expr, char *attr_name, CmpOp_t cmp, char *attr_pattern);
  38. NSAPI_PUBLIC int ACL_ExprNot(NSErr_t *errp, ACLExprHandle_t *acl_expr);
  39. NSAPI_PUBLIC int ACL_ExprAnd(NSErr_t *errp, ACLExprHandle_t *acl_expr);
  40. NSAPI_PUBLIC int ACL_ExprOr(NSErr_t *errp, ACLExprHandle_t *acl_expr);
  41. NSAPI_PUBLIC int ACL_ExprAddAuthInfo(ACLExprHandle_t *expr, PList_t auth_info);
  42. NSAPI_PUBLIC int ACL_ExprAddArg(NSErr_t *errp, ACLExprHandle_t *expr, char *arg);
  43. NSAPI_PUBLIC int ACL_ExprSetDenyWith(NSErr_t *errp, ACLExprHandle_t *expr, char *deny_type, char *deny_response);
  44. NSAPI_PUBLIC int ACL_ExprGetDenyWith(NSErr_t *errp, ACLExprHandle_t *expr, char **deny_type, char **deny_response);
  45. /*********************************************************************
  46. * ACL manipulation
  47. *********************************************************************/
  48. NSAPI_PUBLIC ACLHandle_t * ACL_AclNew(NSErr_t *errp, char *tag);
  49. NSAPI_PUBLIC void ACL_AclDestroy(NSErr_t *errp, ACLHandle_t *acl);
  50. NSAPI_PUBLIC int ACL_ExprAppend(NSErr_t *errp, ACLHandle_t *acl, ACLExprHandle_t *expr);
  51. NSAPI_PUBLIC const char *ACL_AclGetTag(ACLHandle_t *acl);
  52. /*********************************************************************
  53. * ACL list manipulation
  54. *********************************************************************/
  55. NSAPI_PUBLIC ACLListHandle_t * ACL_ListNew(NSErr_t *errp);
  56. NSAPI_PUBLIC int ACL_ListConcat(NSErr_t *errp, ACLListHandle_t *acl_list1, ACLListHandle_t *acl_list2, int flags);
  57. NSAPI_PUBLIC int ACL_ListAppend(NSErr_t *errp, ACLListHandle_t *acllist, ACLHandle_t *acl, int flags);
  58. NSAPI_PUBLIC void ACL_ListDestroy(NSErr_t *errp, ACLListHandle_t *acllist);
  59. NSAPI_PUBLIC ACLHandle_t * ACL_ListFind(NSErr_t *errp, ACLListHandle_t *acllist, char *aclname, int flags);
  60. NSAPI_PUBLIC int ACL_ListAclDelete(NSErr_t *errp, ACLListHandle_t *acl_list, char *acl_name, int flags);
  61. NSAPI_PUBLIC int ACL_ListGetNameList(NSErr_t *errp, ACLListHandle_t *acl_list, char ***name_list);
  62. NSAPI_PUBLIC int ACL_FileGetNameList(NSErr_t *errp, char * filename, char ***name_list);
  63. NSAPI_PUBLIC int ACL_NameListDestroy(NSErr_t *errp, char **name_list);
  64. NSAPI_PUBLIC ACLHandle_t *ACL_ListGetFirst(ACLListHandle_t *acl_list,
  65. ACLListEnum_t *acl_enum);
  66. NSAPI_PUBLIC ACLHandle_t *ACL_ListGetNext(ACLListHandle_t *acl_list,
  67. ACLListEnum_t *acl_enum);
  68. /* Only used for asserts. Probably shouldn't be publicly advertized */
  69. extern int ACL_AssertAcllist( ACLListHandle_t *acllist );
  70. /* Need to be ACL_LIB_INTERNAL */
  71. NSAPI_PUBLIC int ACL_ListPostParseForAuth(NSErr_t *errp, ACLListHandle_t *acl_list);
  72. /*********************************************************************
  73. * ACL evaluation
  74. *********************************************************************/
  75. NSAPI_PUBLIC int ACL_EvalTestRights(NSErr_t *errp, ACLEvalHandle_t *acleval, char **rights, char **map_generic, char **deny_type, char **deny_response, char **acl_tag, int *expr_num);
  76. NSAPI_PUBLIC int ACL_CachableAclList(ACLListHandle_t *acllist);
  77. NSAPI_PUBLIC ACLEvalHandle_t * ACL_EvalNew(NSErr_t *errp, pool_handle_t *pool);
  78. NSAPI_PUBLIC void ACL_EvalDestroy(NSErr_t *errp, pool_handle_t *pool, ACLEvalHandle_t *acleval);
  79. NSAPI_PUBLIC void ACL_EvalDestroyNoDecrement(NSErr_t *errp, pool_handle_t *pool, ACLEvalHandle_t *acleval);
  80. NSAPI_PUBLIC int ACL_ListDecrement(NSErr_t *errp, ACLListHandle_t *acllist);
  81. NSAPI_PUBLIC int ACL_EvalSetACL(NSErr_t *errp, ACLEvalHandle_t *acleval, ACLListHandle_t *acllist);
  82. NSAPI_PUBLIC PList_t ACL_EvalGetSubject(NSErr_t *errp, ACLEvalHandle_t *acleval);
  83. NSAPI_PUBLIC int ACL_EvalSetSubject(NSErr_t *errp, ACLEvalHandle_t *acleval, PList_t subject);
  84. NSAPI_PUBLIC PList_t ACL_EvalGetResource(NSErr_t *errp, ACLEvalHandle_t *acleval);
  85. NSAPI_PUBLIC int ACL_EvalSetResource(NSErr_t *errp, ACLEvalHandle_t *acleval, PList_t resource);
  86. /*
  87. * The following entities are only meant to be called by whole server
  88. * products that include libaccess. E.g. the HTTP server, the Directory
  89. * server etc. They should not be called by ACL callers, LASs etc.
  90. */
  91. /*********************************************************************
  92. * ACL misc routines
  93. *********************************************************************/
  94. NSAPI_PUBLIC int ACL_Init(void);
  95. NSAPI_PUBLIC int ACL_InitPostMagnus(void);
  96. NSAPI_PUBLIC int ACL_LateInitPostMagnus(void);
  97. NSAPI_PUBLIC void ACL_ListHashUpdate(ACLListHandle_t **acllistp);
  98. NSAPI_PUBLIC void ACL_GetPathAcls(char *path, ACLListHandle_t **acllist_p, char *prefix, ACLListHandle_t *masterlist);
  99. NSAPI_PUBLIC int ACL_ReadDbMapFile(NSErr_t *errp, const char *map_file, int default_only);
  100. NSAPI_PUBLIC int ACL_MethodNamesGet(NSErr_t *errp, char ***names, int *count);
  101. NSAPI_PUBLIC int ACL_MethodNamesFree(NSErr_t *errp, char **names, int count);
  102. NSAPI_PUBLIC int ACL_DatabaseNamesGet(NSErr_t *errp, char ***names, int *count);
  103. NSAPI_PUBLIC int ACL_DatabaseNamesFree(NSErr_t *errp, char **names, int count);
  104. NSAPI_PUBLIC int ACL_InitAttr2Index(void);
  105. NSAPI_PUBLIC int ACL_Attr2Index(const char *attrname);
  106. /*********************************************************************
  107. * ACL cache and flush utility
  108. *********************************************************************/
  109. NSAPI_PUBLIC int ACL_CacheCheck(char *uri, ACLListHandle_t **acllist_p);
  110. NSAPI_PUBLIC int ACL_CacheCheckGet(char *uri, ACLListHandle_t **acllist_p);
  111. NSAPI_PUBLIC void ACL_CacheEnter(char *uri, ACLListHandle_t **acllist_p);
  112. NSAPI_PUBLIC void ACL_CacheEnterGet(char *uri, ACLListHandle_t **acllist_p);
  113. NSAPI_PUBLIC int ACL_ListHashCheck(ACLListHandle_t **acllist_p);
  114. NSAPI_PUBLIC void ACL_ListHashEnter(ACLListHandle_t **acllist_p);
  115. NSAPI_PUBLIC int ACL_CacheFlush(void);
  116. NSAPI_PUBLIC void ACL_Restart(void *clntData);
  117. NSAPI_PUBLIC void ACL_CritEnter(void);
  118. NSAPI_PUBLIC void ACL_CritExit(void);
  119. /*********************************************************************
  120. * ACL CGI routines
  121. *********************************************************************/
  122. NSAPI_PUBLIC void ACL_OutputSelector(char *name, char **item);
  123. NSPR_END_EXTERN_C
  124. #endif /* INTNSACL */
  125. #endif