2
0

More than 1 year has passed since last update.

Adminer Editorでデータ更新依頼を自動化できないか検討

Last updated at Posted at 2022-02-27

概要

データの修正依頼を受けてDB運用者が依頼に沿ってデータ修正するのではなく、直接依頼者がデータ修正できるようにできないかという想像から始まった。
phpmyadminやAdminerなどは機能豊富で生のSQLを叩けるのでなかなかハードルが高いし、だからといっていちいちツールを開発するのは大変。

そこで、いろいろ調べてみるとAdmin Editorというツールを見つけた。

Adminer Editorは非開発者でもわかりやすいようなUIを提供するデータ修正ツールで、Adminer同様多数のDBMSに対応している。
Adminerの機能制限版といった感じ?テーブルの作成やスキーマの修正などの機能を提供せずデータの追加、修正、削除のみを実施することができる。
そのため、アプリを立ち上げて依頼者にURLを提供すれば安全に修正できるようにならないか?という発想です。

公式サイトによると以下の制約があるようです。

  • SQLは直接実行できない
  • データベースは1つしか選べない

このページではAdminer EditorをDockerで試してみます。

環境構築

ローカルのDocker上でMySQL、Adminer Editorを構築する。

実行環境

AdminerはDockerイメージが公式で提供されているがAdminer Editorはなさそうだったので作成した。

mysqlのクライアントをインストールする。

Dockerfile
FROM php:apache

RUN docker-php-ext-install pdo_mysql mysqli

それで、docker-compose.yamlでadminerをマウントするだけ。

docker-compose.yml
version: '3.1'

services:

  db:
    image: mysql
    restart: always
    environment:
      MYSQL_ROOT_PASSWORD: password

  adminer:
    build:
      context: .
    restart: always
    ports:
      - 80:80
    volumes:
      - ./adminer:/var/www/html

ソース

editor.phpの1ファイルでソースは完結しているので公式ページからダウンロードして配置する。ただし、各種設定が必要なためindex.phpを新規作成して設定する。

設定方法は以下のページに記載されている。基本クラスのAdminerをオーバーライドして関数を書くことで各種設定ができる。
設定ファイル等ではないのでとっつきにくいがいろいろできるとも言える?

 tree ./adminer
./adminer
├── editor.php
├── index.php
index.php
<?php
function adminer_object()
{
  class AdminerSoftware extends Adminer
  {

    // 画面表示されるタイトル
    function name()
    {
      return 'tool';
    }

    // DB設定
    function credentials()
    {
      return array('db', 'root', 'password');
    }

    // 使用するデータベース
    function database()
    {
      return 'world';
    }

    // 認証方法、trueを返すと何も入力しなくても認証が通る。
    function login($login, $password)
    {
      return true;
    }
  }


  return new AdminerSoftware();
}

include './editor.php';

確認

確認のためMySQLにMySQL公式で提供されているworld databaseをインポートした。

localhost/adminer にアクセスしログイン画面が表示された。

image.png

なんでも認証を通しているのでログイン成功。予め設定したDBのテーブルのみが表示されている。

image.png

テーブル一覧が表示された。
image.png

画面下部にはCSVインポート、エクスポートなどもある。
image.png

編集をクリックするとデータ変更できる。

image.png

データ修正しかできないのが良い感じ。

さらにカスタマイズしてみる

関数を書き換えるのでハードルが高いが以下のカスタムを試してみた。

  • 不要なテーブルを表示しない
  • 不要なカラムを表示しない

tableNameとfieldNameをオーバーライドする。

    function tableName($tableStatus)
    {
      // countryテーブルを非表示
      $ignored_list = [
        'country',
      ];
      if (in_array($tableStatus["Name"], $ignored_list, true)) {
        return '';
      }
      return h($tableStatus["Name"]);
    }

    function fieldName($field, $order = 0)
    {
      // ID列を非表示
      $ignored_list = [
        'ID'
      ];
      if (in_array($field["field"], $ignored_list, true)) {
        return '';
      }
      return '<span title="' . h($field["full_type"]) . '">' . h($field["field"]) . '</span>';
    }

countryテーブルが消えた。

image.png

IDカラムが消えた。

image.png

編集画面からも消えている。

image.png

これでIDや論理削除、作成日時などの列があれば非表示にできる。

感想

汎用的な修正ツールとして活用できそうだが、
実用を考えると操作ログがアクセスログくらいしかないことや認証周りの機能が少ないので解決する必要があるという感想を持った。

2
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
0