[Execute]
IntelliTect.Coalesce.DataAnnotations.ExecuteAttribute
Controls various aspects of Custom Methods, including role-based permissions, HTTP behavior, and more.
For other security controls, see Security Attributes.
Example Usage
public class Person
{
public int PersonId { get; set; }
[Coalesce, Execute(Roles = "Payroll,HR")]
public void GiveRaise(int centsPerHour) {
...
}
...
}Properties
public string Roles { get; set; }
public string Roles { get; set; }A comma-separated list of roles which are allowed to execute the method.
public SecurityPermissionLevels PermissionLevel { get; set; } = SecurityPermissionLevels.AllowAuthorized;
public SecurityPermissionLevels PermissionLevel { get; set; } = SecurityPermissionLevels.AllowAuthorized;The level of access to allow for the action for the method.
Enum values are:
SecurityPermissionLevels.AllowAllAllow all users to perform the action for the attribute, including users who are not authenticated at all.SecurityPermissionLevels.AllowAuthorizedAllow only users who are members of the roles specified on the attribute to perform the action. If no roles are specified on the attribute, then all authenticated users are allowed (no anonymous access).SecurityPermissionLevels.DenyAllDeny the action to all users, regardless of authentication status or authorization level. IfDenyAllis used, no API endpoint for the action will be generated.
public bool AutoClear { get; set; }
public bool AutoClear { get; set; }If true, the method's arguments will be cleared after a successful invocation on admin pages.
public bool? ValidateAttributes { get; set; }
public bool? ValidateAttributes { get; set; }If non-null, overrides the value of CoalesceOptions.ValidateAttributesForMethods when determining whether to perform automatic server-side validation of the method's parameters.
If validation is performed, the method's parameters will be validated by the server and the method invocation prevented if errors are found.
public HttpMethod HttpMethod { get; set; } = HttpMethod.Post;
public HttpMethod HttpMethod { get; set; } = HttpMethod.Post;The HTTP method to use on the generated API Controller.
Enum values are:
HttpMethod.PostUse the POST method.HttpMethod.GetUse the GET method.HttpMethod.PutUse the PUT method.HttpMethod.DeleteUse the DELETE method.HttpMethod.PatchUse the PATCH method.
public string? VaryByProperty { get; set; }
public string? VaryByProperty { get; set; }For HTTP GET model instance methods, if VaryByProperty is set to the name of a property on the parent model class, ETag headers based on the value of this property will be used to implement caching. If the client provides a matching If-None-Match Header with the request, the method will not be invoked and HTTP Status `304 Not Modified`` will be returned.
Additionally, if the VaryByProperty is set to a client-exposed property, the value of the property will be included in the query string when performing API calls to invoke the method. If the query string value matches the current value on the model, a long-term Cache-Control header will be set on the response, allowing the client to avoid making future invocations to the same method while the value of the VaryByProperty remains the same.
public Type? DataSource { get; set; }
public Type? DataSource { get; set; }Specifies that the targeted model instance method should load the instance it is called on from the specified data source when invoked from an API endpoint. If not defined, the model's default data source is used.