Ir para conteúdo

POWERED BY:

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

claudiojuniorfabiao

Abstração de classes

Recommended Posts

Oi, galera!

 

Bem, acredito estar postando na área certa, apesar de isso também estar relacionado com a estrutura da aplicação e não necessariamente PHP.

 

É o seguinte, estou criando uma aplicação orientada a objetos; nela preciso de algumas funções comuns como cadastro de clientes, cadastro de funcionários, alguns produtos cadastrados, é básico, nada difícil de fazer do ponto de vista de um programador: conheço a sintaxe e sei trabalhar legal com a linguagem, mas minha dúvida é sobre a divisão das responsabilidades entre os tipos de objetos.

 

Por exemplo, no cadastro de um novo cliente, quem está executando esta ação é um funcionário no sistema, mas quem deve ser o responsável pelo método? Ele deve ser parte da classe do funcionário, ou do cliente? Se for na classe "funcionário", seria algo como "cadastrarCliente", mas se for na classe do cliente (o que eu jugo mais correto, pelo princípio de responsabilidade única), seria como?

 

Desde já agradeço qualquer luz que possam me dar sobre o assunto.

Compartilhar este post


Link para o post
Compartilhar em outros sites

você pode criar em sua tabela uma coluna com o nível desse funcionário/usuário, e antes de cadastrar você coloca a mensagem "você não pode cadastrar usuários".

 

id | nome | email | senha | nivel | data

1  | Rick   | c@c.c |  pass  |    0    | 2017-07-06

2  |  Alli   | a@a.a |  pass  |    1    | 2017-07-05

3  | John | j@j.j     |  pass  |    2    | 2017-07-04

Compartilhar este post


Link para o post
Compartilhar em outros sites

Oi, quimera, obrigado pelo seu post!

 

Bem, então, implementar níveis de permissões eu consigo fazer bem, vou introduzir um conceito de papéis e capacidades parecidas com o do WordPress, é bem flexível para mim.

 

Minha dúvida é mais sobre a questão organizacional e metódica do desenvolvimento mesmo, tenho lido sobre OOP, UML, padrões de projeto, enfim, quero uma aplicação mais padronizada...

Compartilhar este post


Link para o post
Compartilhar em outros sites

O funcionário é uma entidade/classe, o cliente é outra entidade/classe.

 

Geralmente é feito outra classe para inserção do banco de dados tipo ClienteDAO para criar um novo usuário, tipo assim talvez:

class ClienteDAO {
    public function inserirCliente(Cliente cliente, Funcionario funcionario) {}
}

DAO é um padrão de projeto mais ou menos antigo e que muita gente ainda usa e existe muita coisa na internet sobre ele. Geralmente você quer que as classes Funcionario e Cliente sejam bem simples somente para representar elas mesmas, e não tomar ações.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Oi, Kononome, tudo bem?

 

Rapaz, nesse tempo que estava esperando algumas respostas no tópico acabei me atentando para o DAO, e que ele supria essa minha necessidade, mas estava esperando alguém mais experiente no assunto para me dar um parecer aqui.

 

Nesse caso, acho que vou separar assim (que é o que me parece o certo à se fazer): ações em tempo de execução sobre uma entidade serão executadas através de suas respectivas classes (Cliente, Funcionario), já a parte de persistência dos dados vou deixar com as classes DAO (ClienteDAO, FuncionarioDAO).

 

Como eu disse, programo em PHP há um tempo, mas minhas noções de OOP e padrões de projeto de software só começaram a fluir agora, acho que é uma transição natural.

 

Enfim, se alguém tiver algo a acrescentar à esta discussão, como exemplos ou links, serei grato. Obrigado, Kononome!

Compartilhar este post


Link para o post
Compartilhar em outros sites

Existem muitos patterns a serem seguidos, só recomendei o mais prático para PHP puro. Geralmente adotamos algum framework para evitarmos o trabalho muito pesado de Padrões de Projeto, pois estes frameworks adotam patterns como MVC, Repositories, ORM, Facades, Dependency Injection e por aí vai.

 

No Laravel, ele já vem com Models incríveis para você criar um Cliente e Funcionário já conectado ao banco. Após você colocar a configuração do banco de dados em um config do Laravel, você simplesmente faz isso para adicionar ao banco:

// App/Model/Cliente.php
class Cliente extends Eloquent {}

// App/Controller/Cliente.php
class ClienteController extends Controller {
    public function inserir() {
         $c = new Cliente();
         $c->nome = 'Fulano';
         $c->save();
    }
}

E fazer as ligações entre clientes e funcionários também é coisa de uma função com uma linha dentro. Se você já tem toda a prática de desenvolvimento PHP, recomendo você ter certeza disso lendo isso: http://br.phptherightway.com/.

 

Após isso, você deveria aprender utilizar um framework.

 

Voltando o assunto de OOP, se você já tem um MVC, o padrão Repositories seria o próximo a ser implementado. É um DAO mais inteligente eu diria.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Ah, agradeço suas sugestões!

 

Bem, conheço e já usei alguns destes frameworks em alguns sistemas aos quais prestei manutenção, ou implementei novas funcionalidades, mas como tenho estudado sobre modelagem de dados e tentado sair daquele ciclo de "aprende/executa", entendendo realmente o quê e porquê estou implementando algo de determinada maneira, me surgiu essa dúvida.

 

Conheço alguns destes padrões de projeto que você citou, outros não, estou estudando sobre eles ainda, checando a melhor abordagem, até porque, divido o tempo entre estudar e aplicar o que estudei, numa empresa em que eu sou o responsável pelo T.I; é difícil.

 

Agradeço muito pelo link e pelos conselhos, já usei o Zend, o CodeIgniter, o Cake, mas nunca testei o Laravel, acho que é um bom momento para aprender ainda mais.

 

Novamente, muito obrigado!

Compartilhar este post


Link para o post
Compartilhar em outros sites

O Single of responsiblity, é especificamente para fazer com que cada classe tenha uma única responsabilidade.

Por exemplo:

Eu tenho um algoritmo desenvolvido para uma loja. Eu possuo uma classe cliente e através dessa classe eu consigo fazer:

Cadastro de novos clientes

Editar clientes existentes

Remover clientes

Adicionar dívidas do cliente

Remover dívidas do cliente

Exibir as dívidas do cliente

Editar dívidas do cliente

Enviar e-mail para cliente quanto estiver próximo ao vencimento.

 

Essa classe está de acordo com este princípio? De fato não.

 

Poderíamos ter a seguinte estrutura:

MainCliente

Gerenciamento cliente

Comunicar vencimento

 

Desta forma cada classe teria sua única responsabilidade.

Você poderia usar um middleware, de forma com que você primeiro faz uma verificação em algo relacionado ao funcionário para depois executar à ação do cliente.

 

Ou simplesmente o padrão facade.

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por violin101
      Caros amigos, saudações.
       
      Por favor, me permita tirar uma dúvida com os amigos.

      Tenho um Formulário onde o Usuário digita todos os Dados necessários.

      Minha dúvida:
      --> como faço após o usuário digitar os dados e salvar, o Sistema chamar uma Modal ou mensagem perguntando se deseja imprimir agora ?

      Grato,
       
      Cesar
    • Por Carcleo
      Tenho uma abela de usuarios e uma tabela de administradores e clientes.
      Gostaria de uma ajuda para implementar um cadastro
       
      users -> name, login, passord (pronta) admins -> user_id, registratiom, etc.. client -> user_id, registratiom, etc...
      Queria ajuda para extender de user as classes Admin e Client
      Olhem como estáAdmin
      <?php namespace App\Models; use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Database\Eloquent\Model; class Admin extends User {     use HasFactory;            protected $fillable = [         'name',         'email',         'password',         'registration'     ];      private string $registration;     public function create(         string $name,          string $email,          string $password,         string $registration     )     {         //parent::create(['name'=>$name, 'email'=>$email, 'password'=>$password]);         parent::$name = $name;         parent::$email = $email;         parent::$password = $password;         $this->registration = $registration;     } } User
      <?php namespace App\Models; // use Illuminate\Contracts\Auth\MustVerifyEmail; use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Foundation\Auth\User as Authenticatable; use Illuminate\Notifications\Notifiable; use Illuminate\Database\Eloquent\Relations\BelongsToMany; class User extends Authenticatable {     /** @use HasFactory<\Database\Factories\UserFactory> */     use HasFactory, Notifiable;     static string $name;     static string $email;     static string $password;     /**      * The attributes that are mass assignable.      *      * @var list<string>      */     protected $fillable = [         'name',         'email',         'password',     ];          /**      * The attributes that should be hidden for serialization.      *      * @var list<string>      */     protected $hidden = [         'remember_token',     ];     /**      * Get the attributes that should be cast.      *      * @return array<string, string>      */     protected function casts(): array     {         return [             'email_verified_at' => 'datetime',             'password' => 'hashed',         ];     }          public function roles() : BelongsToMany {         return $this->belongsToMany(Role::class);     }       public function hasHole(Array $roleName): bool     {                 foreach ($this->roles as $role) {             if ($role->name === $roleName) {                 return true;             }         }         return false;     }         public function hasHoles(Array $rolesName): bool     {                 foreach ($this->roles as $role) {             foreach ($rolesName as $rolee) {             if ($role->name === $rolee) {                 return true;             }          }         }         return false;     }         public function hasAbility(string $ability): bool     {         foreach ($this->roles as $role) {             if ($role->abilities->contains('name', $ability)) {                 return true;             }         }         return false;     }     } Como gravar um Admin na tabela admins sendo que ele é um User por extensão?
      Tentei assim mas é claro que está errado...
      public function store(Request $request, Admin $adminModel) {         $dados = $request->validate([             "name" => "required",             "email" => "required|email",             "password" => "required",             "registration" => "required"         ]);         $dados["password"] =  Hash::make($dados["password"]);                  $admin = Admin::where("registration",  $dados["registration"])->first();                  if ($admin)              return                    redirect()->route("admin.new")                             ->withErrors([                                 'fail' => 'Administrador já cadastrados<br>, favor verificar!'                   ]);                            $newAdmin = $adminModel->create(                                    $dados['name'],                                    $dados['email'],                                    $dados['password'],                                    $dados['registration']                                 );         dd($newAdmin);         $adminModel->save();         //$adminModel::create($admin);                  return redirect()->route("admin.new")->with("success",'Cadastrado com sucesso');     }  
    • Por violin101
      Caros amigos, saudações.
       
      Gostaria de tirar uma dúvida com os amigos, referente a PDV.
       
      Estou escrevendo um Sistema com Ponto de Vendas, a minha dúvida é o seguinte, referente ao procedimento mais correto.

      Conforme o caixa vai efetuando a venda, o Sistema de PDV já realiza:
      a baixa direto dos produtos no estoque
      ou
      somente após concretizar a venda o sistema baixa os produtos do estoque ?
       
      Grato,
       
      Cesar
       
    • Por violin101
      Caros amigos do grupo, saudações e um feliz 2025.
       
      Estou com uma pequena dúvida referente a Teclas de Atalho.

      Quando o Caps Lock está ativado o Comando da Tecla de Atalho não funciona.
      ou seja:
      se estiver para letra minúscula ====> funciona
      se estiver para letra maiúscula ====> não funciona
       
      Como consigo evitar essa falha, tanto para Letra Maiúscula quanto Minúscula ?

      o Código está assim:
      document.addEventListener( 'keydown', evt => { if (!evt.ctrlKey || evt.key !== 'r' ) return;// Não é Ctrl+r, portanto interrompemos o script evt.preventDefault(); });  
      Grato,
       
      Cesar
    • Por violin101
      Caros amigos, saudações.
       
      Por favor, poderiam me ajudar.

      Estou com a seguinte dúvida:
      --> como faço para para implementar o input código do produto, para quando o usuário digitar o ID o sistema espera de 1s a 2s, sem ter que pressionar a tecla ENTER.

      exemplo:
      código   ----   descrição
           1       -----   produto_A
       
      Grato,
       
      Cesar
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.