// POST /webpages_Controllers/token/ public HttpResponseMessage Post(string token, [FromBody] Models.Object.CadastroController param) { // Abre nova conexão using (painel_taxservices_dbContext _db = new painel_taxservices_dbContext()) { tbLogAcessoUsuario log = new tbLogAcessoUsuario(); try { HttpResponseMessage retorno = new HttpResponseMessage(); log = Bibliotecas.LogAcaoUsuario.New(token, JsonConvert.SerializeObject(param), "Post", _db); if (Permissoes.Autenticado(token, _db)) { Int32 dados = GatewayWebpagesControllers.Add(token, param, _db); log.codResposta = (int)HttpStatusCode.OK; Bibliotecas.LogAcaoUsuario.Save(log, _db); return(Request.CreateResponse <Int32>(HttpStatusCode.OK, dados)); } else { log.codResposta = (int)HttpStatusCode.Unauthorized; Bibliotecas.LogAcaoUsuario.Save(log, _db); return(Request.CreateResponse(HttpStatusCode.Unauthorized)); } } catch (Exception e) { log.codResposta = (int)HttpStatusCode.InternalServerError; log.msgErro = e.Message; Bibliotecas.LogAcaoUsuario.Save(log); throw new HttpResponseException(HttpStatusCode.InternalServerError); } } }
/// <summary> /// Adiciona nova Webpages_Controllers /// </summary> /// <param name="param"></param> /// <returns></returns> public static Int32 Add(string token, Models.Object.CadastroController param, painel_taxservices_dbContext _dbContext = null) { painel_taxservices_dbContext _db; if (_dbContext == null) { _db = new painel_taxservices_dbContext(); } else { _db = _dbContext; } try { if (param.Webpagescontrollers.nm_controller == null) { param.Webpagescontrollers.nm_controller = param.Webpagescontrollers.ds_controller; } _db.webpages_Controllers.Add(param.Webpagescontrollers); _db.SaveChanges(); if (param.Methodspadrao) { webpages_Methods put = new webpages_Methods { ds_method = "Atualização", id_controller = param.Webpagescontrollers.id_controller }; webpages_Methods post = new webpages_Methods { ds_method = "Cadastro", id_controller = param.Webpagescontrollers.id_controller }; webpages_Methods get = new webpages_Methods { ds_method = "Leitura", id_controller = param.Webpagescontrollers.id_controller }; webpages_Methods delete = new webpages_Methods { ds_method = "Remoção", id_controller = param.Webpagescontrollers.id_controller }; //webpages_Methods filtroempresa = new webpages_Methods { ds_method = "Filtro Empresa", id_controller = param.Webpagescontrollers.id_controller }; try { GatewayWebpagesMethods.Add(token, put); } catch (Exception e) { throw new Exception(e.InnerException == null ? e.Message : e.InnerException.InnerException == null ? e.InnerException.Message : e.InnerException.InnerException.Message); } try { GatewayWebpagesMethods.Add(token, post); } catch (Exception e) { throw new Exception(e.InnerException == null ? e.Message : e.InnerException.InnerException == null ? e.InnerException.Message : e.InnerException.InnerException.Message); } try { GatewayWebpagesMethods.Add(token, get); } catch (Exception e) { throw new Exception(e.InnerException == null ? e.Message : e.InnerException.InnerException == null ? e.InnerException.Message : e.InnerException.InnerException.Message); } try { GatewayWebpagesMethods.Add(token, delete); } catch (Exception e) { throw new Exception(e.InnerException == null ? e.Message : e.InnerException.InnerException == null ? e.InnerException.Message : e.InnerException.InnerException.Message); } //GatewayWebpagesMethods.Add(token, filtroempresa); } return(param.Webpagescontrollers.id_controller); } catch (Exception e) { if (e is DbEntityValidationException) { string erro = MensagemErro.getMensagemErro((DbEntityValidationException)e); throw new Exception(erro.Equals("") ? "Falha ao salvar controller" : erro); } throw new Exception(e.InnerException == null ? e.Message : e.InnerException.InnerException == null ? e.InnerException.Message : e.InnerException.InnerException.Message); } finally { if (_dbContext == null) { // Fecha conexão _db.Database.Connection.Close(); _db.Dispose(); } } }