Merge pull request #5714 from alexischr/update_bockbuild
[mono.git] / mono / metadata / security-manager.h
index 25223e42d900b79eadd512c7d7e980903dfeeac4..d9f49ceb510c86ff0ea33218dead8ce21bff1d14 100644 (file)
@@ -1,10 +1,12 @@
-/*
- * security-manager.h:  Security Manager
+/**
+ * \file
+ * Security Manager
  *
  * Author:
  *     Sebastien Pouliot  <sebastien@ximian.com>
  *
  * Copyright (C) 2004-2005 Novell, Inc (http://www.novell.com)
+ * Licensed under the MIT license. See LICENSE file in the project root for full license information.
  */
 
 #ifndef _MONO_METADATA_SECURITY_MANAGER_H_
@@ -38,43 +40,34 @@ enum {
        MONO_METADATA_INHERITANCEDEMAND_METHOD  = 0x02
 };
 
+typedef enum {
+       MONO_SECURITY_MODE_NONE,
+       MONO_SECURITY_MODE_CORE_CLR,
+} MonoSecurityMode;
 
 /* Structures */
 
 typedef struct {
        MonoClass *securitymanager;             /* System.Security.SecurityManager */
-       MonoMethod *demand;                     /* SecurityManager.InternalDemand */
-       MonoMethod *demandchoice;               /* SecurityManager.InternalDemandChoice */
-       MonoMethod *demandunmanaged;            /* SecurityManager.DemandUnmanaged */
-       MonoMethod *inheritancedemand;          /* SecurityManager.InheritanceDemand */
-       MonoMethod *inheritsecurityexception;   /* SecurityManager.InheritanceDemandSecurityException */
-       MonoMethod *linkdemand;                 /* SecurityManager.LinkDemand */
-       MonoMethod *linkdemandfulltrust;        /* SecurityManager.LinkDemandFullTrust */
-       MonoMethod *linkdemandunmanaged;        /* SecurityManager.LinkDemandUnmanaged */
-       MonoMethod *linkdemandsecurityexception;/* SecurityManager.LinkDemandSecurityException */
-
-       MonoClass *allowpartiallytrustedcallers;        /* System.Security.AllowPartiallyTrustedCallersAttribute */
-       MonoClass *suppressunmanagedcodesecurity;       /* System.Security.SuppressUnmanagedCodeSecurityAttribute */
 } MonoSecurityManager;
 
+gboolean mono_is_ecma_key (const char *publickey, int size);
+MonoMethod* mono_get_context_capture_method (void);
 
-/* Initialization/utility functions */
-void mono_activate_security_manager (void) MONO_INTERNAL;
-gboolean mono_is_security_manager_active (void) MONO_INTERNAL;
-MonoSecurityManager* mono_security_manager_get_methods (void) MONO_INTERNAL;
-gboolean mono_is_ecma_key (const char *publickey, int size) MONO_INTERNAL;
-MonoMethod* mono_get_context_capture_method (void) MONO_INTERNAL;
-
-void mono_secman_inheritancedemand_class (MonoClass *klass, MonoClass *parent) MONO_INTERNAL;
-void mono_secman_inheritancedemand_method (MonoMethod *override, MonoMethod *base) MONO_INTERNAL;
+MonoSecurityManager* mono_security_manager_get_methods (void);
 
+/* Security mode */
+void mono_security_set_mode (MonoSecurityMode mode);
+MonoSecurityMode mono_security_get_mode (void);
 
 /* internal calls */
-MonoBoolean ves_icall_System_Security_SecurityManager_get_SecurityEnabled (void) MONO_INTERNAL;
-void ves_icall_System_Security_SecurityManager_set_SecurityEnabled (MonoBoolean value) MONO_INTERNAL;
-MonoBoolean ves_icall_System_Security_SecurityManager_get_CheckExecutionRights (void) MONO_INTERNAL;
-void ves_icall_System_Security_SecurityManager_set_CheckExecutionRights (MonoBoolean value) MONO_INTERNAL;
-MonoBoolean ves_icall_System_Security_SecurityManager_GetLinkDemandSecurity (MonoReflectionMethod *m, MonoDeclSecurityActions *kactions, MonoDeclSecurityActions *mactions) MONO_INTERNAL;
-
+MonoBoolean ves_icall_System_Security_SecurityManager_get_SecurityEnabled (void);
+void ves_icall_System_Security_SecurityManager_set_SecurityEnabled (MonoBoolean value);
+
+#ifndef DISABLE_SECURITY
+#define mono_security_core_clr_enabled() (mono_security_get_mode () == MONO_SECURITY_MODE_CORE_CLR)
+#else
+#define mono_security_core_clr_enabled() (FALSE)
+#endif
 
 #endif /* _MONO_METADATA_SECURITY_MANAGER_H_ */