agents.md
This commit is contained in:
@@ -0,0 +1,101 @@
|
||||
# AGENTS.md — инструкция для агентов
|
||||
|
||||
## О проекте
|
||||
|
||||
**ocStore (OpenCart) 3.0.3.7** — интернет-магазин на PHP с Twig-шаблонами.
|
||||
|
||||
- **Платформа:** ocStore 3.0.3.7 (форк OpenCart)
|
||||
- **PHP:** >= 8.5
|
||||
- **Шаблонизатор:** Twig 3.0
|
||||
- **Язык:** русский (ru-ru)
|
||||
- **База данных:** MySQL (драйвер mysqli)
|
||||
- **Веб-сервер:** Apache с mod_rewrite
|
||||
|
||||
## Структура проекта
|
||||
|
||||
```
|
||||
public/
|
||||
├── admin/ # Админ-панель (MVC)
|
||||
│ ├── controller/ # Контроллеры
|
||||
│ ├── language/ # Языковые файлы ru-ru
|
||||
│ ├── model/ # Модели
|
||||
│ ├── view/ # Twig-шаблоны (.twig)
|
||||
│ └── index.php
|
||||
├── store/ # Витрина / каталог (MVC)
|
||||
│ ├── controller/
|
||||
│ ├── language/
|
||||
│ ├── model/
|
||||
│ └── view/theme/ # Тема оформления
|
||||
├── system/ # Ядро (фреймворк, библиотеки, хелперы)
|
||||
│ ├── engine/ # Роутинг, экшены, загрузчик
|
||||
│ ├── library/ # Библиотеки (language, config, template, …)
|
||||
│ ├── helper/ # Хелперы
|
||||
│ └── config/ # Конфигурация ядра
|
||||
├── image/ # Изображения товаров
|
||||
├── config.php # Конфигурация (в .gitignore!)
|
||||
└── index.php # Точка входа
|
||||
storage/
|
||||
├── cache/ # Кэш (в .gitignore)
|
||||
├── logs/ # Логи (в .gitignore)
|
||||
├── modification/ # Модификации OCMOD (в .gitignore)
|
||||
├── session/ # Сессии PHP (в .gitignore)
|
||||
├── upload/ # Загрузки (в .gitignore)
|
||||
├── download/ # Файлы для скачивания (в .gitignore)
|
||||
└── vendor/ # Composer-зависимости (в .gitignore, Twig)
|
||||
```
|
||||
|
||||
## Важные правила
|
||||
|
||||
### Никогда не коммитить
|
||||
- `public/config.php` и `public/admin/config.php` — содержат пароли БД
|
||||
- `storage/` целиком (кроме `index.html`)
|
||||
- `vendor/` — устанавливается через Composer
|
||||
- Файлы кэша, логов, сессий
|
||||
- `public/image/` — изображения хранятся отдельно
|
||||
|
||||
### Коммиты
|
||||
- Сообщения коммитов — **на русском языке**
|
||||
- Стиль: кратко, что сделано (пример: `"Блог в меню"`, `"Удалил googleshopping"`)
|
||||
|
||||
### Код-стайл
|
||||
- PHP: без строгой типизации, используется `$_` суперглобальный массив для языковых переменных
|
||||
- Языковые файлы — ассоциативный массив `$_['key'] = 'значение';`
|
||||
- Контроллеры — классы в `Controller*` namespace
|
||||
- Модели — классы в `Model*` namespace
|
||||
- Шаблоны — `.twig` файлы
|
||||
- Формат языковых переменных в шаблонах: `{{ text_yes }}`, `{{ button_save }}`
|
||||
- Формат языковых констант: `$_['text_yes']`, `$_['button_save']` и т.д.
|
||||
|
||||
### OpenCart MVC (паттерн)
|
||||
- URL-роутинг: `index.php?route=common/home` загружает `controller/common/home.php`
|
||||
- Контроллер вызывает `$this->load->model('catalog/product')` для загрузки модели
|
||||
- Контроллер вызывает `$this->load->language('product/product')` для языкового файла
|
||||
- Шаблоны рендерятся через `$this->response->setOutput($this->load->view(...))`
|
||||
|
||||
### Модификации (OCMOD)
|
||||
- OCMOD-модификации лежат в `public/system/modification.xml`
|
||||
- Изменённые файлы попадают в `storage/modification/` — не трогать вручную
|
||||
|
||||
### Composer
|
||||
- Зависимости: Twig 3.0
|
||||
- Установка: `composer install` в `storage/`
|
||||
|
||||
## Работа с расширениями
|
||||
|
||||
Расширения (модули, темы, платёжные шлюзы и т.д.) устанавливаются через админ-панель или вручную:
|
||||
- Модули: `public/admin/controller/extension/module/`, `public/store/controller/extension/module/`
|
||||
- Темы: `public/store/view/theme/`
|
||||
- Языковые файлы расширений: `public/admin/language/ru-ru/extension/`
|
||||
|
||||
## Полезные команды
|
||||
|
||||
```bash
|
||||
# Очистка кэша
|
||||
rm -rf storage/cache/*
|
||||
|
||||
# Установка зависимостей
|
||||
cd storage && composer install
|
||||
|
||||
# Просмотр логов
|
||||
tail -f storage/logs/error.log
|
||||
```
|
||||
Reference in New Issue
Block a user