Example #1
0
        public IActionResult Extract(Request request)
        {
            try
            {
                String         content = request.EmailContent;
                RelevantDataBO relevantDataBO;

                if (_contentExtractor.GetRelevantData(content, out relevantDataBO))
                {
                    // Extract Success. Mapping BO to Contract.
                    var response = _mapper.Map <Response>(relevantDataBO);
                    Log.Debug <string>("Extract Done.", content);
                    return(Ok(response));
                }
                else
                {
                    // Extract Fail. Because of invalid data.
                    Log.Debug <string>("Extract Failed.", content);
                    return(BadRequest());
                }
            }
            catch (ArgumentOutOfRangeException ex)
            {
                // Argument Out Of Range
                Log.Debug <string>("ArgumentOutOfRange", ex.Message);
                return(BadRequest());
            }
            catch (Exception ex)
            {
                // Fail. Because of Internal Server Error.
                Log.Error(ex, "Get unexpected exception during process.");
                return(StatusCode(500));
            }
        }