40#include "MagickCore/studio.h"
41#include "MagickCore/cache-private.h"
42#include "MagickCore/client.h"
43#include "MagickCore/configure.h"
44#include "MagickCore/configure-private.h"
45#include "MagickCore/exception.h"
46#include "MagickCore/exception-private.h"
47#include "MagickCore/linked-list-private.h"
48#include "MagickCore/magick-private.h"
49#include "MagickCore/memory_.h"
50#include "MagickCore/memory-private.h"
51#include "MagickCore/monitor.h"
52#include "MagickCore/monitor-private.h"
53#include "MagickCore/option.h"
54#include "MagickCore/policy.h"
55#include "MagickCore/policy-private.h"
56#include "MagickCore/resource_.h"
57#include "MagickCore/resource-private.h"
58#include "MagickCore/semaphore.h"
59#include "MagickCore/stream-private.h"
60#include "MagickCore/string_.h"
61#include "MagickCore/string-private.h"
62#include "MagickCore/token.h"
63#include "MagickCore/timer-private.h"
64#include "MagickCore/utility.h"
65#include "MagickCore/utility-private.h"
66#include "MagickCore/xml-tree.h"
67#include "MagickCore/xml-tree-private.h"
68#if defined(MAGICKCORE_XML_DELEGATE)
69# include <libxml/parser.h>
70# include <libxml/tree.h>
76#define PolicyFilename "policy.xml"
126static const PolicyMapInfo
129 { UndefinedPolicyDomain, UndefinedPolicyRights, (
const char *) NULL,
130 (
const char *) NULL, (
const char *) NULL }
134 *policy_cache = (LinkedListInfo *) NULL;
142static MagickBooleanType
143 IsPolicyCacheInstantiated(ExceptionInfo *),
144 LoadPolicyCache(LinkedListInfo *,
const char *,
const char *,
const size_t,
173static LinkedListInfo *AcquirePolicyCache(
const char *filename,
174 ExceptionInfo *exception)
188 cache=NewLinkedList(0);
190#if MAGICKCORE_ZERO_CONFIGURATION_SUPPORT
191 magick_unreferenced(filename);
192 status=LoadPolicyCache(cache,ZeroConfigurationPolicy,
"[zero-configuration]",0,
194 if (status == MagickFalse)
195 CatchException(exception);
204 options=GetConfigureOptions(filename,exception);
205 option=(
const StringInfo *) GetNextValueInLinkedList(options);
206 while (option != (
const StringInfo *) NULL)
208 status=LoadPolicyCache(cache,(
const char *) GetStringInfoDatum(option),
209 GetStringInfoPath(option),0,exception);
210 if (status == MagickFalse)
211 CatchException(exception);
212 option=(
const StringInfo *) GetNextValueInLinkedList(options);
214 options=DestroyConfigureOptions(options);
220 for (i=0; i < (ssize_t) (
sizeof(PolicyMap)/
sizeof(*PolicyMap)); i++)
229 policy_info=(PolicyInfo *) AcquireMagickMemory(
sizeof(*policy_info));
230 if (policy_info == (PolicyInfo *) NULL)
232 (void) ThrowMagickException(exception,GetMagickModule(),
233 ResourceLimitError,
"MemoryAllocationFailed",
"`%s'",
234 p->name == (
char *) NULL ?
"" : p->name);
235 CatchException(exception);
238 (void) memset(policy_info,0,
sizeof(*policy_info));
239 policy_info->path=(
char *)
"[built-in]";
240 policy_info->domain=p->domain;
241 policy_info->rights=p->rights;
242 policy_info->name=(
char *) p->name;
243 policy_info->pattern=(
char *) p->pattern;
244 policy_info->value=(
char *) p->value;
245 policy_info->exempt=MagickTrue;
246 policy_info->signature=MagickCoreSignature;
247 status=AppendValueToLinkedList(cache,policy_info);
248 if (status == MagickFalse)
250 (void) ThrowMagickException(exception,GetMagickModule(),
251 ResourceLimitError,
"MemoryAllocationFailed",
"`%s'",
252 p->name == (
char *) NULL ?
"" : p->name);
253 CatchException(exception);
284static PolicyInfo *GetPolicyInfo(
const char *name,ExceptionInfo *exception)
287 policyname[MagickPathExtent],
299 assert(exception != (ExceptionInfo *) NULL);
300 if (IsPolicyCacheInstantiated(exception) == MagickFalse)
301 return((PolicyInfo *) NULL);
306 if (name != (
const char *) NULL)
307 (void) CopyMagickString(policyname,name,MagickPathExtent);
308 for (q=policyname; *q !=
'\0'; q++)
310 if (isspace((
int) ((
unsigned char) *q)) == 0)
312 (void) CopyMagickString(q,q+1,MagickPathExtent);
318 domain=UndefinedPolicyDomain;
319 for (q=policyname; *q !=
'\0'; q++)
324 domain=(PolicyDomain) ParseCommandOption(MagickPolicyDomainOptions,
325 MagickTrue,policyname);
326 (void) CopyMagickString(policyname,q+1,MagickPathExtent);
332 policy=(PolicyInfo *) NULL;
333 LockSemaphoreInfo(policy_semaphore);
334 ResetLinkedListIterator(policy_cache);
335 p=GetHeadElementInLinkedList(policy_cache);
336 if ((name == (
const char *) NULL) || (LocaleCompare(name,
"*") == 0))
338 UnlockSemaphoreInfo(policy_semaphore);
339 if (p != (ElementInfo *) NULL)
340 policy=(PolicyInfo *) p->value;
343 while (p != (ElementInfo *) NULL)
345 policy=(PolicyInfo *) p->value;
346 if ((domain == UndefinedPolicyDomain) || (policy->domain == domain))
347 if (LocaleCompare(policyname,policy->name) == 0)
351 if (p == (ElementInfo *) NULL)
352 policy=(PolicyInfo *) NULL;
354 (
void) SetHeadElementInLinkedList(policy_cache,p);
355 UnlockSemaphoreInfo(policy_semaphore);
386MagickExport
const PolicyInfo **GetPolicyInfoList(
const char *pattern,
387 size_t *number_policies,ExceptionInfo *exception)
398 assert(pattern != (
char *) NULL);
399 assert(number_policies != (
size_t *) NULL);
400 if (IsEventLogging() != MagickFalse)
401 (void) LogMagickEvent(TraceEvent,GetMagickModule(),
"%s",pattern);
403 if (IsPolicyCacheInstantiated(exception) == MagickFalse)
404 return((
const PolicyInfo **) NULL);
405 policies=(
const PolicyInfo **) AcquireQuantumMemory((
size_t)
406 GetNumberOfElementsInLinkedList(policy_cache)+1UL,
sizeof(*policies));
407 if (policies == (
const PolicyInfo **) NULL)
408 return((
const PolicyInfo **) NULL);
409 LockSemaphoreInfo(policy_semaphore);
410 p=GetHeadElementInLinkedList(policy_cache);
411 for (i=0; p != (ElementInfo *) NULL; )
416 policy=(
const PolicyInfo *) p->value;
417 if ((policy->stealth == MagickFalse) &&
418 (GlobExpression(policy->name,pattern,MagickFalse) != MagickFalse))
419 policies[i++]=policy;
422 UnlockSemaphoreInfo(policy_semaphore);
424 policies=(
const PolicyInfo **) RelinquishMagickMemory((
void*) policies);
426 policies[i]=(PolicyInfo *) NULL;
427 *number_policies=(size_t) i;
459static char *AcquirePolicyString(
const char *source,
const size_t pad)
468 if (source != (
char *) NULL)
469 length+=strlen(source);
470 destination=(
char *) NULL;
473 destination=(
char *) AcquireMagickMemory((length+pad)*
sizeof(*destination));
474 if (destination == (
char *) NULL)
475 ThrowFatalException(ResourceLimitFatalError,
"UnableToAcquireString");
476 if (source != (
char *) NULL)
477 (void) memcpy(destination,source,length*
sizeof(*destination));
478 destination[length]=
'\0';
482MagickExport
char **GetPolicyList(
const char *pattern,
size_t *number_policies,
483 ExceptionInfo *exception)
494 assert(pattern != (
char *) NULL);
495 assert(number_policies != (
size_t *) NULL);
496 if (IsEventLogging() != MagickFalse)
497 (void) LogMagickEvent(TraceEvent,GetMagickModule(),
"%s",pattern);
499 if (IsPolicyCacheInstantiated(exception) == MagickFalse)
500 return((
char **) NULL);
501 policies=(
char **) AcquireQuantumMemory((
size_t)
502 GetNumberOfElementsInLinkedList(policy_cache)+1UL,
sizeof(*policies));
503 if (policies == (
char **) NULL)
504 return((
char **) NULL);
505 LockSemaphoreInfo(policy_semaphore);
506 p=GetHeadElementInLinkedList(policy_cache);
507 for (i=0; p != (ElementInfo *) NULL; )
512 policy=(
const PolicyInfo *) p->value;
513 if ((policy->stealth == MagickFalse) &&
514 (GlobExpression(policy->name,pattern,MagickFalse) != MagickFalse))
515 policies[i++]=AcquirePolicyString(policy->name,1);
518 UnlockSemaphoreInfo(policy_semaphore);
520 policies=(
char **) RelinquishMagickMemory(policies);
522 policies[i]=(
char *) NULL;
523 *number_policies=(size_t) i;
549MagickExport
char *GetPolicyValue(
const char *name)
560 assert(name != (
const char *) NULL);
561 if (IsEventLogging() != MagickFalse)
562 (void) LogMagickEvent(TraceEvent,GetMagickModule(),
"%s",name);
563 exception=AcquireExceptionInfo();
564 policy_info=GetPolicyInfo(name,exception);
565 exception=DestroyExceptionInfo(exception);
566 if (policy_info == (PolicyInfo *) NULL)
567 return((
char *) NULL);
568 value=policy_info->value;
569 if ((value == (
const char *) NULL) || (*value ==
'\0'))
570 return((
char *) NULL);
571 return(AcquirePolicyString(value,1));
597static MagickBooleanType IsPolicyCacheInstantiated(ExceptionInfo *exception)
599 if (policy_cache == (LinkedListInfo *) NULL)
601 (void) GetMaxMemoryRequest();
603 ActivateSemaphoreInfo(&policy_semaphore);
604 LockSemaphoreInfo(policy_semaphore);
605 if (policy_cache == (LinkedListInfo *) NULL)
606 policy_cache=AcquirePolicyCache(PolicyFilename,exception);
607 UnlockSemaphoreInfo(policy_semaphore);
609 return(policy_cache != (LinkedListInfo *) NULL ? MagickTrue : MagickFalse);
646MagickPrivate MagickBooleanType IsRightsAuthorizedByName(
647 const PolicyDomain domain,
const char *name,
const PolicyRights rights,
651 *canonical_directory = (
char *) NULL,
652 *canonical_path = (
char *) NULL,
653 *canonical_candidate = (
char *) NULL,
654 directory[MagickPathExtent],
655 filename[MagickPathExtent];
664 matched_any = MagickFalse,
665 paths_provisioned = MagickFalse,
669 effective_rights = AllPolicyRights;
674 if ((GetLogEventMask() & PolicyEvent) != 0)
675 (void) LogMagickEvent(PolicyEvent,GetMagickModule(),
676 "Domain: %s; name: %s; rights=%s; pattern=\"%s\"; ...",
677 CommandOptionToMnemonic(MagickPolicyDomainOptions,domain),
678 name == (
const char *) NULL ?
"undefined" : name,
679 CommandOptionToMnemonic(MagickPolicyRightsOptions,rights),
680 pattern == (
const char *) NULL ?
"undefined" : pattern);
681 exception=AcquireExceptionInfo();
682 status=IsPolicyCacheInstantiated(exception);
683 exception=DestroyExceptionInfo(exception);
684 if (status == MagickFalse)
686 if ((GetLogEventMask() & PolicyEvent) != 0)
687 (void) LogMagickEvent(PolicyEvent,GetMagickModule(),
688 " authorized: true (no security policies found)");
694 LockSemaphoreInfo(policy_semaphore);
695 ResetLinkedListIterator(policy_cache);
696 p=GetHeadElementInLinkedList(policy_cache);
697 for ( ; p != (ElementInfo *) NULL; p=p->next)
700 *policy = (PolicyInfo *) p->value;
705 if (policy->domain != domain)
707 if ((name != (
char *) NULL) && (LocaleCompare(name,policy->name) != 0))
709 match=GlobExpression(pattern,policy->pattern,MagickFalse);
710 if (policy->domain == PathPolicyDomain)
712 if (paths_provisioned == MagickFalse)
717 paths_provisioned=MagickTrue;
718 GetPathComponent(pattern,HeadPath,directory);
719 GetPathComponent(pattern,TailPath,filename);
720 canonical_directory=realpath_utf8(directory);
721 if ((canonical_directory != (
char *) NULL) && (*filename !=
'\0'))
726 length=strlen(canonical_directory)+strlen(filename)+2;
727 canonical_candidate=(
char *) AcquireCriticalMemory(length*
728 sizeof(*canonical_candidate));
729 if (canonical_candidate != (
char *) NULL)
730 (void) FormatLocaleString(canonical_candidate,length,
"%s%s%s",
731 canonical_directory,DirectorySeparator,filename);
733 canonical_path=realpath_utf8(pattern);
738 if ((canonical_directory != (
char *) NULL) && (match == MagickFalse))
739 match=GlobExpression(canonical_directory,policy->pattern,MagickFalse);
740 if ((canonical_candidate != (
char *) NULL) && (match == MagickFalse))
741 match=GlobExpression(canonical_candidate,policy->pattern,MagickFalse);
742 if ((canonical_path != (
char *) NULL) && (match == MagickFalse))
743 match=GlobExpression(canonical_path,policy->pattern,MagickFalse);
745 if (match == MagickFalse)
747 matched_any=MagickTrue;
748 effective_rights=policy->rights;
750 UnlockSemaphoreInfo(policy_semaphore);
751 if (canonical_directory != (
char *) NULL)
752 canonical_directory=DestroyString(canonical_directory);
753 if (canonical_candidate != (
char *) NULL)
754 canonical_candidate=DestroyString(canonical_candidate);
755 if (canonical_path != (
char *) NULL)
756 canonical_path=DestroyString(canonical_path);
761 if (matched_any != MagickFalse)
763 if (((rights & ReadPolicyRights) != 0) &&
764 ((effective_rights & ReadPolicyRights) == 0))
766 if (((rights & WritePolicyRights) != 0) &&
767 ((effective_rights & WritePolicyRights) == 0))
769 if (((rights & ExecutePolicyRights) != 0) &&
770 ((effective_rights & ExecutePolicyRights) == 0))
773 if ((GetLogEventMask() & PolicyEvent) != 0)
774 (void) LogMagickEvent(PolicyEvent,GetMagickModule(),
775 " authorized: %s",status == MagickFalse ?
"false" :
"true");
779MagickExport MagickBooleanType IsRightsAuthorized(
const PolicyDomain domain,
780 const PolicyRights rights,
const char *pattern)
782 return(IsRightsAuthorizedByName(domain,(
const char *) NULL,rights,pattern));
809MagickExport MagickBooleanType ListPolicyInfo(FILE *file,
810 ExceptionInfo *exception)
828 if (file == (
const FILE *) NULL)
830 policy_info=GetPolicyInfoList(
"*",&number_policies,exception);
831 if (policy_info == (
const PolicyInfo **) NULL)
833 path=(
const char *) NULL;
834 for (i=0; i < (ssize_t) number_policies; i++)
836 if (policy_info[i]->stealth != MagickFalse)
838 if (((path == (
const char *) NULL) ||
839 (LocaleCompare(path,policy_info[i]->path) != 0)) &&
840 (policy_info[i]->path != (
char *) NULL))
841 (void) FormatLocaleFile(file,
"\nPath: %s\n",policy_info[i]->path);
842 path=policy_info[i]->path;
843 domain=CommandOptionToMnemonic(MagickPolicyDomainOptions,
844 policy_info[i]->domain);
845 (void) FormatLocaleFile(file,
" Policy: %s\n",domain);
846 if ((policy_info[i]->domain == CachePolicyDomain) ||
847 (policy_info[i]->domain == ResourcePolicyDomain) ||
848 (policy_info[i]->domain == SystemPolicyDomain))
850 if (policy_info[i]->name != (
char *) NULL)
851 (void) FormatLocaleFile(file,
" name: %s\n",policy_info[i]->name);
852 if (policy_info[i]->value != (
char *) NULL)
853 (void) FormatLocaleFile(file,
" value: %s\n",policy_info[i]->value);
857 (void) FormatLocaleFile(file,
" rights: ");
858 if (policy_info[i]->rights == NoPolicyRights)
859 (void) FormatLocaleFile(file,
"None ");
860 if ((policy_info[i]->rights & ReadPolicyRights) != 0)
861 (void) FormatLocaleFile(file,
"Read ");
862 if ((policy_info[i]->rights & WritePolicyRights) != 0)
863 (void) FormatLocaleFile(file,
"Write ");
864 if ((policy_info[i]->rights & ExecutePolicyRights) != 0)
865 (void) FormatLocaleFile(file,
"Execute ");
866 (void) FormatLocaleFile(file,
"\n");
867 if (policy_info[i]->pattern != (
char *) NULL)
868 (void) FormatLocaleFile(file,
" pattern: %s\n",
869 policy_info[i]->pattern);
872 policy_info=(
const PolicyInfo **) RelinquishMagickMemory((
void *)
908static MagickBooleanType LoadPolicyCache(LinkedListInfo *cache,
909 const char *policy,
const char *filename,
const size_t depth,
910 ExceptionInfo *exception)
913 keyword[MagickPathExtent],
931 (void) LogMagickEvent(ConfigureEvent,GetMagickModule(),
932 "Loading policy file \"%s\" ...",filename);
933 if (policy == (
char *) NULL)
936 policy_info=(PolicyInfo *) NULL;
937 token=AcquirePolicyString(policy,MagickPathExtent);
938 extent=strlen(token)+MagickPathExtent;
939 for (q=policy; *q !=
'\0'; )
944 (void) GetNextToken(q,&q,extent,token);
947 (void) CopyMagickString(keyword,token,MagickPathExtent);
948 if (LocaleNCompare(keyword,
"<!DOCTYPE",9) == 0)
953 while ((LocaleNCompare(q,
"]>",2) != 0) && (*q !=
'\0'))
954 (void) GetNextToken(q,&q,extent,token);
957 if (LocaleNCompare(keyword,
"<!--",4) == 0)
962 while ((LocaleNCompare(q,
"->",2) != 0) && (*q !=
'\0'))
963 (void) GetNextToken(q,&q,extent,token);
966 if (LocaleCompare(keyword,
"<include") == 0)
971 while (((*token !=
'/') && (*(token+1) !=
'>')) && (*q !=
'\0'))
973 (void) CopyMagickString(keyword,token,MagickPathExtent);
974 (void) GetNextToken(q,&q,extent,token);
977 (void) GetNextToken(q,&q,extent,token);
978 if (LocaleCompare(keyword,
"file") == 0)
980 if (depth > MagickMaxRecursionDepth)
981 (void) ThrowMagickException(exception,GetMagickModule(),
982 ConfigureError,
"IncludeElementNestedTooDeeply",
"`%s'",token);
986 path[MagickPathExtent],
989 GetPathComponent(filename,HeadPath,path);
991 (void) ConcatenateMagickString(path,DirectorySeparator,
993 if (*token == *DirectorySeparator)
994 (void) CopyMagickString(path,token,MagickPathExtent);
996 (
void) ConcatenateMagickString(path,token,MagickPathExtent);
997 file_xml=FileToXML(path,~0UL);
998 if (file_xml != (
char *) NULL)
1000 status&=(MagickStatusType) LoadPolicyCache(cache,file_xml,
1001 path,depth+1,exception);
1002 file_xml=DestroyString(file_xml);
1009 if (LocaleCompare(keyword,
"<policy") == 0)
1014 policy_info=(PolicyInfo *) AcquireCriticalMemory(
sizeof(*policy_info));
1015 (void) memset(policy_info,0,
sizeof(*policy_info));
1016 policy_info->path=AcquirePolicyString(filename,1);
1017 policy_info->exempt=MagickFalse;
1018 policy_info->signature=MagickCoreSignature;
1021 if (policy_info == (PolicyInfo *) NULL)
1023 if ((LocaleCompare(keyword,
"/>") == 0) ||
1024 (LocaleCompare(keyword,
"</policy>") == 0))
1026 status=AppendValueToLinkedList(cache,policy_info);
1027 if (status == MagickFalse)
1028 (void) ThrowMagickException(exception,GetMagickModule(),
1029 ResourceLimitError,
"MemoryAllocationFailed",
"`%s'",
1031 policy_info=(PolicyInfo *) NULL;
1034 (void) GetNextToken(q,(
const char **) NULL,extent,token);
1037 (void) GetNextToken(q,&q,extent,token);
1038 (void) GetNextToken(q,&q,extent,token);
1044 if (LocaleCompare((
char *) keyword,
"domain") == 0)
1046 policy_info->domain=(PolicyDomain) ParseCommandOption(
1047 MagickPolicyDomainOptions,MagickTrue,token);
1055 if (LocaleCompare((
char *) keyword,
"name") == 0)
1057 policy_info->name=AcquirePolicyString(token,1);
1065 if (LocaleCompare((
char *) keyword,
"pattern") == 0)
1067 policy_info->pattern=AcquirePolicyString(token,1);
1075 if (LocaleCompare((
char *) keyword,
"rights") == 0)
1077 policy_info->rights=(PolicyRights) ParseCommandOption(
1078 MagickPolicyRightsOptions,MagickTrue,token);
1086 if (LocaleCompare((
char *) keyword,
"stealth") == 0)
1088 policy_info->stealth=IsStringTrue(token);
1096 if (LocaleCompare((
char *) keyword,
"value") == 0)
1098 policy_info->value=AcquirePolicyString(token,1);
1107 token=(
char *) RelinquishMagickMemory(token);
1108 return(status != 0 ? MagickTrue : MagickFalse);
1129MagickPrivate MagickBooleanType PolicyComponentGenesis(
void)
1132 policy_semaphore=AcquireSemaphoreInfo();
1155static void *DestroyPolicyElement(
void *policy_info)
1160 p=(PolicyInfo *) policy_info;
1161 if (p->exempt == MagickFalse)
1163 if (p->value != (
char *) NULL)
1164 p->value=DestroyString(p->value);
1165 if (p->pattern != (
char *) NULL)
1166 p->pattern=DestroyString(p->pattern);
1167 if (p->name != (
char *) NULL)
1168 p->name=DestroyString(p->name);
1169 if (p->path != (
char *) NULL)
1170 p->path=DestroyString(p->path);
1172 p=(PolicyInfo *) RelinquishMagickMemory(p);
1173 return((
void *) NULL);
1176MagickPrivate
void PolicyComponentTerminus(
void)
1179 ActivateSemaphoreInfo(&policy_semaphore);
1180 LockSemaphoreInfo(policy_semaphore);
1181 if (policy_cache != (LinkedListInfo *) NULL)
1182 policy_cache=DestroyLinkedList(policy_cache,DestroyPolicyElement);
1183 UnlockSemaphoreInfo(policy_semaphore);
1184 RelinquishSemaphoreInfo(&policy_semaphore);
1214static MagickBooleanType ValidateSecurityPolicy(
const char *policy,
1215 const char *url,ExceptionInfo *exception)
1217#if defined(MAGICKCORE_XML_DELEGATE)
1224 document=xmlReadMemory(policy,(
int) strlen(policy),url,NULL,
1225 XML_PARSE_NOERROR | XML_PARSE_NOWARNING);
1226 if (document == (xmlDocPtr) NULL)
1228 (void) ThrowMagickException(exception,GetMagickModule(),ConfigureError,
1229 "PolicyValidationException",
"'%s'",url);
1230 return(MagickFalse);
1232 xmlFreeDoc(document);
1241MagickExport MagickBooleanType SetMagickSecurityPolicy(
const char *policy,
1242 ExceptionInfo *exception)
1256 assert(exception != (ExceptionInfo *) NULL);
1257 if (policy == (
const char *) NULL)
1258 return(MagickFalse);
1259 if (ValidateSecurityPolicy(policy,PolicyFilename,exception) == MagickFalse)
1260 return(MagickFalse);
1261 status=LoadPolicyCache(policy_cache,policy,
"[user-policy]",0,exception);
1262 if (status == MagickFalse)
1267 user_policies=NewLinkedList(0);
1268 status=LoadPolicyCache(user_policies,policy,
"[user-policy]",0,exception);
1269 if (status == MagickFalse)
1271 user_policies=DestroyLinkedList(user_policies,DestroyPolicyElement);
1272 return(MagickFalse);
1274 ResetLinkedListIterator(user_policies);
1275 p=(PolicyInfo *) GetNextValueInLinkedList(user_policies);
1276 while (p != (PolicyInfo *) NULL)
1278 if ((p->name != (
char *) NULL) && (p->value != (
char *) NULL))
1279 (void) SetMagickSecurityPolicyValue(p->domain,p->name,p->value,exception);
1280 p=(PolicyInfo *) GetNextValueInLinkedList(user_policies);
1282 user_policies=DestroyLinkedList(user_policies,DestroyPolicyElement);
1319MagickExport MagickBooleanType SetMagickSecurityPolicyValue(
1320 const PolicyDomain domain,
const char *name,
const char *value,
1321 ExceptionInfo *exception)
1323 magick_unreferenced(exception);
1324 assert(exception != (ExceptionInfo *) NULL);
1325 if ((name == (
const char *) NULL) || (value == (
const char *) NULL))
1326 return(MagickFalse);
1329 case CachePolicyDomain:
1331 if (LocaleCompare(name,
"memory-map") == 0)
1333 if (LocaleCompare(value,
"anonymous") != 0)
1334 return(MagickFalse);
1335 ResetCacheAnonymousMemory();
1336 ResetStreamAnonymousMemory();
1341 case ResourcePolicyDomain:
1346 type=ParseCommandOption(MagickResourceOptions,MagickFalse,name);
1352 limit=MagickResourceInfinity;
1353 if (LocaleCompare(
"unlimited",value) != 0)
1354 limit=StringToMagickSizeType(value,100.0);
1355 if ((ResourceType) type == TimeResource)
1356 limit=(MagickSizeType) ParseMagickTimeToLive(value);
1357 return(SetMagickResourceLimit((ResourceType) type,limit));
1361 case SystemPolicyDomain:
1363 if (LocaleCompare(name,
"max-memory-request") == 0)
1368 limit=MagickResourceInfinity;
1369 if (LocaleCompare(
"unlimited",value) != 0)
1370 limit=StringToMagickSizeType(value,100.0);
1371 SetMaxMemoryRequest(limit);
1374 if (LocaleCompare(name,
"max-profile-size") == 0)
1379 limit=MagickResourceInfinity;
1380 if (LocaleCompare(
"unlimited",value) != 0)
1381 limit=StringToMagickSizeType(value,100.0);
1382 SetMaxProfileSize(limit);
1385 if (LocaleCompare(name,
"memory-map") == 0)
1387 if (LocaleCompare(value,
"anonymous") != 0)
1388 return(MagickFalse);
1389 ResetVirtualAnonymousMemory();
1392 if (LocaleCompare(name,
"precision") == 0)
1397 limit=StringToInteger(value);
1398 SetMagickPrecision(limit);
1403 case CoderPolicyDomain:
1404 case DelegatePolicyDomain:
1405 case FilterPolicyDomain:
1406 case ModulePolicyDomain:
1407 case PathPolicyDomain:
1411 return(MagickFalse);