Adaptive systems improve their efficiency by modifying their behaviour to respond to changes in their operational\ud
environment. Also, security must adapt to these changes and policy enforcement becomes dependent on the dynamic contexts.\ud
We study these issues within MLCoDa, (the core of) an adaptive declarative language proposed recently. A main characteristic\ud
of MLCoDa is to have two components: a logical one for handling the context and a functional one for computing. We extend\ud
this language with security policies that are expressed in logical terms. They are of two different kinds: context and application\ud
policies. The first, unknown a priori to an application, protect the context from unwanted changes. The others protect the\ud
applications from malicious actions of the context, can be nested and can be activated and deactivated according to their scope.\ud
An execution step can only occur if all the policies in force hold, under the control of an execution monitor. Beneficial to this is\ud
a type and effect system, which safely approximates the behaviour of an application, and a further static analysis, based on the\ud
computed effect. The last analysis can only be carried on at load time, when the execution context is known, and it enables us to\ud
efficiently enforce the security policies on the code execution, by instrumenting applications. The monitor is thus implemented\ud
within MLCoDa, and it is only activated on those policies that may be infringed, and switched off otherwise