Beispiel #1
0
        /// <summary>
        /// Valida a existencia do veículo.
        /// </summary>
        /// <param name="cliente"></param>
        /// <returns></returns>
        IMessageFormattable[] Entidades.IValidadorVeiculo.ValidaExistencia(Entidades.Veiculo veiculo)
        {
            var mensagens = new List <string>();

            // Handler para tratar o resultado da consulta de validação
            var tratarResultado = new Func <string, Colosoft.Query.QueryCallBack>(mensagem =>
                                                                                  (sender, query, result) =>
            {
                if (result.Select(f => f.GetInt32(0)).FirstOrDefault() > 0 &&
                    !mensagens.Contains(mensagem))
                {
                    mensagens.Add(mensagem);
                }
            });

            SourceContext.Instance.CreateMultiQuery()
            .Add(SourceContext.Instance.CreateQuery()
                 .From <Data.Model.Carregamento>()
                 .Where("Placa=?id")
                 .Add("?id", veiculo.Placa)
                 .Count(),
                 tratarResultado("Há carregamentos associados ao mesmo."))

            .Execute();

            return(mensagens.Select(f => f.GetFormatter()).ToArray());
        }
Beispiel #2
0
        /// <summary>
        /// Apaga os dados do veículo.
        /// </summary>
        /// <param name="veiculo"></param>
        /// <returns></returns>
        public Colosoft.Business.DeleteResult ApagarVeiculo(Entidades.Veiculo veiculo)
        {
            veiculo.Require("veiculo").NotNull();

            using (var session = SourceContext.Instance.CreateSession())
            {
                var resultado = veiculo.Delete(session);

                if (!resultado)
                {
                    return(resultado);
                }

                return(session.Execute(false).ToDeleteResult());
            }
        }