コード例 #1
0
        public async Task <IActionResult> Create([FromBody] LogModels.Metric metric)
        {
            IActionResult result = null;

            try
            {
                if (result == null && (!metric.DomainId.HasValue || metric.DomainId.Value.Equals(Guid.Empty)))
                {
                    result = BadRequest("Missing domain guid value");
                }
                if (result == null)
                {
                    using ILifetimeScope scope = _container.BeginLifetimeScope();
                    SettingsFactory settingsFactory = scope.Resolve <SettingsFactory>();
                    if (!(await VerifyDomainAccountWriteAccess(metric.DomainId.Value, settingsFactory, _settings.Value, scope.Resolve <IDomainService>())))
                    {
                        result = StatusCode(StatusCodes.Status401Unauthorized);
                    }
                    if (result == null)
                    {
                        CoreSettings   settings    = settingsFactory.CreateCore(_settings.Value);
                        IMetricFactory factory     = scope.Resolve <IMetricFactory>();
                        IMetric        innerMetric = factory.Create(metric.DomainId.Value, metric.CreateTimestamp, metric.EventCode);
                        IMapper        mapper      = MapperConfigurationFactory.CreateMapper();
                        mapper.Map <LogModels.Metric, IMetric>(metric, innerMetric);
                        IMetricSaver saver = scope.Resolve <IMetricSaver>();
                        await saver.Create(settings, innerMetric);

                        result = Ok(mapper.Map <LogModels.Metric>(innerMetric));
                    }
                }
            }
            catch (Exception ex)
            {
                using (ILifetimeScope scope = _container.BeginLifetimeScope())
                {
                    await LogException(ex, scope.Resolve <IExceptionService>(), scope.Resolve <SettingsFactory>(), _settings.Value);
                }
                result = StatusCode(StatusCodes.Status500InternalServerError);
            }
            return(result);
        }