public async Task WhenAsync(MergePatchRolePermissionDto c)
        {
            var idObj         = RolePermissionProxyUtils.ToIdString((c as IMergePatchRolePermission).Id);
            var uriParameters = new RolePermissionUriParameters();

            uriParameters.Id = idObj;

            var req  = new RolePermissionPatchRequest(uriParameters, (MergePatchRolePermissionDto)c);
            var resp = await _ramlClient.RolePermission.Patch(req);

            RolePermissionProxyUtils.ThrowOnHttpResponseError(resp);
        }
        public async Task <IRolePermissionState> GetAsync(RolePermissionId id)
        {
            IRolePermissionState state = null;
            var idObj         = RolePermissionProxyUtils.ToIdString(id);
            var uriParameters = new RolePermissionUriParameters();

            uriParameters.Id = idObj;

            var req = new RolePermissionGetRequest(uriParameters);

            var resp = await _ramlClient.RolePermission.Get(req);

            RolePermissionProxyUtils.ThrowOnHttpResponseError(resp);
            state = resp.Content;
            return(state);
        }
        public async Task WhenAsync(DeleteRolePermissionDto c)
        {
            var idObj         = RolePermissionProxyUtils.ToIdString((c as IDeleteRolePermission).Id);
            var uriParameters = new RolePermissionUriParameters();

            uriParameters.Id = idObj;

            var q = new RolePermissionDeleteQuery();

            q.CommandId   = c.CommandId;
            q.RequesterId = c.RequesterId;
            q.Version     = Convert.ToString(c.Version);

            var req = new RolePermissionDeleteRequest(uriParameters);

            req.Query = q;

            var resp = await _ramlClient.RolePermission.Delete(req);

            RolePermissionProxyUtils.ThrowOnHttpResponseError(resp);
        }