プラグインで推奨の命名規則
プラグインコード
重複を避けるため, [ベンダー名][プラグイン]の形式を推奨
キャメルケースで記述する
AcmeCategoryContent
テーブル名
※プラグイン固有のテーブルを作成する場合
plg_[プラグインコードのスネークケース]_xxx
use Doctrine\ORM\Mapping as ORM;
/**
 * Config
 *
 * @ORM\Table(name="plg_acme_category_content_config")
 * @ORM\Entity(repositoryClass="Plugin\AcmeCategoryContent\Repository\ConfigRepository")
 */
class Config
テーブルのカラム名およびgetter/setter
※traitを使用してカラムを追加する場合
[プラグインコードのスネークケース]_xxx
getter/setterはキャメルケースで記述する
use Eccube\Annotation\EntityExtension;
use Doctrine\ORM\Mapping as ORM;
/**
 * @EntityExtension("Eccube\Entity\Customer")
 */
trait CustomerTrait
{
    /**
     * @ORM\Column(name="acme_category_content_xxx" type="integer", nullable=true)
     */
    private $acme_category_content_xxx;
    public function getAcmeCategoryContentXxx()
    {
    }
    public function setAcmeCategoryContentXxx($xxx)
    {
    }
}
ルーティング
フロント画面
[プラグインコードのスネークケース]_xxx
class PageController extends AbstractController
{
    /**
     * @Route("/acme_category_content/page", name="acme_category_content_page")
     * @Template("@AcmeCategoryContent/page.twig")
     */
    public function index(Request $request)
管理画面
管理画面は先頭に admin_ をつける
admin_[プラグインコードのスネークケース]_xxx
class ConfigController extends AbstractController
{
    /**
     * @Route("/%eccube_admin_route%/acme_category_content/config", name="admin_acme_category_content_config")
     * @Template("@AcmeCategoryContent/admin/config.twig")
     */
    public function index(Request $request)
URL
/[プラグインコードのスネークケース]/xxx/xxx
class ConfigController extends AbstractController
{
    /**
     * @Route("/%eccube_admin_route%/acme_category_content/config", name="acme_category_content_admin_config")
     * @Template("@AcmeCategoryContent/admin/config.twig")
     */
    public function index(Request $request)
FormExtensionで追加するフィールド
[プラグインコードのスネークケース]_xxx
class XxxExtention extends AbstractTypeExtension
{
    public function buildForm(FormBuilderInterface $builder, array $options)
    {
        $builder->add('acme_category_content_name', TextType::class);
htmlで使用するID, class
[プラグインコードのスネークケース]_xxx
<div id="acme_category_content_info" class="card rounded border-0 mb-4">
コマンド名
[プラグインコードのスネークケース]:xxx:xxx
class XxxCommand extends Command
{
    protected static $defaultName = 'acme_category_content:xxx:yyy';
言語ファイル
[プラグインコードのスネークケース].xxx.xxx
# nav
acme_category_content.admin.nav.category: カテゴリコンテンツ一覧
# flash messages
acme_category_content.admin.save.success: 登録しました。
acme_category_content.admin.save.failed: 登録に失敗しました。
プラグインコード以降の命名規則はEC-CUBE本体の命名規則に従う
パラメータ
[プラグインコードのスネークケース].xxx.xxx
parameters:
  acme_category_content.xxx: 1
services:
  acme_category_content.log.formatter.line:
      class: Monolog\Formatter\LineFormatter
      arguments: ...