it-swarm-ja.tech

カスタムコンポーネントのユーザー情報テーブルのユーザー情報を更新する最善の方法は何ですか?

一部のユーザー情報を個別のテーブルに保存するカスタムコンポーネントを開発しました。ユーザーが管理セクションまたはフロントエンドから削除または更新されたときに、ユーザー情報を保存/更新したいと考えています。

3
lokeshpahal

ユーザープラグインを使用してデータを保存する必要があります。データは非常に簡単に書き込むことができます。例は Creating a profile plugin にありますが、例には必要以上のものが含まれている場合があります。

コードが入るイベントはonUserAfterSaveonUserAfterDeleteであり、 Plugin/Events/User に記載されています。これらのイベントは、ユーザーが管理者またはフロントエンドで保存または削除されたときに発生します。

プラグインの根性はこれだろう:

defined('_JEXEC') or die;
class PlgUserMyPlugin extends JPlugin
{
    protected $app;
    protected $db;

    public function onUserAfterDelete($user, $success, $msg) {
        if (!$success) 
            return false;

        $query = $this->db->getQuery(true)
        ->delete($this->db->quoteName('#__mytable'))
        ->where($this->db->quoteName('userid') . ' = ' . (int) $user['id']);
        $this->db->setQuery($query)->execute();
        return true;
    }

    public function onUserAfterSave($user, $isnew, $success, $msg) {
        if (!$success) 
            return false;

        // Update your table here
        if ($isnew) {
            // New User
        }else{
            // Existing User
        }
    }
}
6
GDP