file and some fix
This commit is contained in:
parent
2fd90cd65a
commit
f861f3eea9
@ -71,4 +71,21 @@ class File extends \yii\db\ActiveRecord
|
|||||||
'status' => 'Status',
|
'status' => 'Status',
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return string[]
|
||||||
|
*/
|
||||||
|
public function fields(): array
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'id',
|
||||||
|
'name',
|
||||||
|
'created_at',
|
||||||
|
'updated_at',
|
||||||
|
'url',
|
||||||
|
'type',
|
||||||
|
'mime-type',
|
||||||
|
'status',
|
||||||
|
];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
79
common/models/FileEntity.php
Normal file
79
common/models/FileEntity.php
Normal file
@ -0,0 +1,79 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace common\models;
|
||||||
|
|
||||||
|
use Yii;
|
||||||
|
use yii\behaviors\TimestampBehavior;
|
||||||
|
use yii\db\Expression;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This is the model class for table "file_entity".
|
||||||
|
*
|
||||||
|
* @property int $id
|
||||||
|
* @property int $file_id
|
||||||
|
* @property int $entity_type
|
||||||
|
* @property int $entity_id
|
||||||
|
* @property string $created_at
|
||||||
|
* @property string $updated_at
|
||||||
|
* @property int $status
|
||||||
|
*
|
||||||
|
* @property File $file
|
||||||
|
*/
|
||||||
|
class FileEntity extends \yii\db\ActiveRecord
|
||||||
|
{
|
||||||
|
public function behaviors()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
[
|
||||||
|
'class' => TimestampBehavior::class,
|
||||||
|
'createdAtAttribute' => 'created_at',
|
||||||
|
'updatedAtAttribute' => 'updated_at',
|
||||||
|
'value' => new Expression('NOW()'),
|
||||||
|
],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public static function tableName()
|
||||||
|
{
|
||||||
|
return 'file_entity';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public function rules()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
[['file_id', 'entity_type', 'entity_id', 'status'], 'integer'],
|
||||||
|
[['created_at', 'updated_at'], 'safe'],
|
||||||
|
[['file_id'], 'exist', 'skipOnError' => true, 'targetClass' => File::className(), 'targetAttribute' => ['file_id' => 'id']],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public function attributeLabels()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'id' => 'ID',
|
||||||
|
'file_id' => 'File ID',
|
||||||
|
'entity_type' => 'Entity Type',
|
||||||
|
'entity_id' => 'Entity ID',
|
||||||
|
'created_at' => 'Created At',
|
||||||
|
'updated_at' => 'Updated At',
|
||||||
|
'status' => 'Status',
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return \yii\db\ActiveQuery
|
||||||
|
*/
|
||||||
|
public function getFile()
|
||||||
|
{
|
||||||
|
return $this->hasOne(File::className(), ['id' => 'file_id']);
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,51 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
use yii\db\Migration;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class m230526_105126_create_file_entity_teble
|
||||||
|
*/
|
||||||
|
class m230526_105126_create_file_entity_teble extends Migration
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public function safeUp()
|
||||||
|
{
|
||||||
|
$this->createTable('{{%file_entity}}', [
|
||||||
|
'id' => $this->primaryKey(),
|
||||||
|
'file_id' => $this->integer(11),
|
||||||
|
'entity_type' => $this->integer(2),
|
||||||
|
'entity_id' => $this->integer(11),
|
||||||
|
'created_at' => $this->dateTime(),
|
||||||
|
'updated_at' => $this->dateTime(),
|
||||||
|
'status' => $this->integer(1)->defaultValue(1),
|
||||||
|
]);
|
||||||
|
|
||||||
|
$this->addForeignKey('fk_file_entity_file', 'file_entity', 'file_id', 'file', 'id');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public function safeDown()
|
||||||
|
{
|
||||||
|
$this->dropForeignKey('fk_file_entity_file', 'file_entity');
|
||||||
|
$this->dropTable('{{%file_entity}}');
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
// Use up()/down() to run migration code without a transaction.
|
||||||
|
public function up()
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public function down()
|
||||||
|
{
|
||||||
|
echo "m230526_105126_create_file_entity_teble cannot be reverted.\n";
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
}
|
@ -4,7 +4,9 @@ namespace frontend\modules\api\controllers;
|
|||||||
|
|
||||||
use common\classes\Debug;
|
use common\classes\Debug;
|
||||||
use common\models\File;
|
use common\models\File;
|
||||||
|
use frontend\modules\api\models\FileEntity;
|
||||||
use yii\helpers\FileHelper;
|
use yii\helpers\FileHelper;
|
||||||
|
use yii\web\NotFoundHttpException;
|
||||||
use yii\web\ServerErrorHttpException;
|
use yii\web\ServerErrorHttpException;
|
||||||
use yii\web\UploadedFile;
|
use yii\web\UploadedFile;
|
||||||
|
|
||||||
@ -14,9 +16,47 @@ class FileController extends ApiController
|
|||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
'upload' => ['post'],
|
'upload' => ['post'],
|
||||||
|
'attach' => ['post'],
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @OA\Post(path="/file/upload",
|
||||||
|
* summary="Загрузить файл",
|
||||||
|
* description="Метод для загрузки файлов",
|
||||||
|
* security={
|
||||||
|
* {"bearerAuth": {}}
|
||||||
|
* },
|
||||||
|
* tags={"File"},
|
||||||
|
*
|
||||||
|
* @OA\RequestBody(
|
||||||
|
* @OA\MediaType(
|
||||||
|
* mediaType="multipart/form-data",
|
||||||
|
* @OA\Schema(
|
||||||
|
* required={"uploadFile"},
|
||||||
|
* @OA\Property(
|
||||||
|
* property="uploadFile",
|
||||||
|
* type="file",
|
||||||
|
* description="Файл который необходимо загрузить",
|
||||||
|
* ),
|
||||||
|
* ),
|
||||||
|
* ),
|
||||||
|
* ),
|
||||||
|
* @OA\Response(
|
||||||
|
* response=200,
|
||||||
|
* description="Возвращает объект Файла",
|
||||||
|
* @OA\MediaType(
|
||||||
|
* mediaType="application/json",
|
||||||
|
* @OA\Schema(ref="#/components/schemas/FileExample"),
|
||||||
|
* ),
|
||||||
|
* ),
|
||||||
|
* )
|
||||||
|
*
|
||||||
|
* @return array
|
||||||
|
* @throws ServerErrorHttpException
|
||||||
|
* @throws \yii\base\Exception
|
||||||
|
*/
|
||||||
public function actionUpload()
|
public function actionUpload()
|
||||||
{
|
{
|
||||||
$uploads = UploadedFile::getInstancesByName("uploadFile");
|
$uploads = UploadedFile::getInstancesByName("uploadFile");
|
||||||
@ -39,11 +79,11 @@ class FileController extends ApiController
|
|||||||
$fileModel = new File();
|
$fileModel = new File();
|
||||||
$fileModel->name = $file->name;
|
$fileModel->name = $file->name;
|
||||||
$fileModel->path = $path;
|
$fileModel->path = $path;
|
||||||
$fileModel->url = "/files/". $md5[0] . $md5[1] . "/" . $md5[2] . $md5[3] . "/" . $md5 . '.' . $file->getExtension();
|
$fileModel->url = "/files/" . $md5[0] . $md5[1] . "/" . $md5[2] . $md5[3] . "/" . $md5 . '.' . $file->getExtension();
|
||||||
$fileModel->type = $file->getExtension();
|
$fileModel->type = $file->getExtension();
|
||||||
$fileModel->{'mime-type'} = $file->type;
|
$fileModel->{'mime-type'} = $file->type;
|
||||||
|
|
||||||
if (!$fileModel->validate()){
|
if (!$fileModel->validate()) {
|
||||||
throw new ServerErrorHttpException(json_encode($fileModel->errors));
|
throw new ServerErrorHttpException(json_encode($fileModel->errors));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -55,4 +95,80 @@ class FileController extends ApiController
|
|||||||
return $savedFiles;
|
return $savedFiles;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @OA\Post(path="/file/attach",
|
||||||
|
* summary="Прикрепить файл",
|
||||||
|
* description="Метод для прикрепления файлов",
|
||||||
|
* security={
|
||||||
|
* {"bearerAuth": {}}
|
||||||
|
* },
|
||||||
|
* tags={"File"},
|
||||||
|
*
|
||||||
|
* @OA\RequestBody(
|
||||||
|
* @OA\MediaType(
|
||||||
|
* mediaType="multipart/form-data",
|
||||||
|
* @OA\Schema(
|
||||||
|
* required={"file_id", "entity_type", "entity_id"},
|
||||||
|
* @OA\Property(
|
||||||
|
* property="file_id",
|
||||||
|
* type="intager",
|
||||||
|
* example=232,
|
||||||
|
* description="Идентификатор файла",
|
||||||
|
* ),
|
||||||
|
* @OA\Property(
|
||||||
|
* property="entity_type",
|
||||||
|
* type="intager",
|
||||||
|
* example=2,
|
||||||
|
* description="Идентификатор типа сущности",
|
||||||
|
* ),
|
||||||
|
* @OA\Property(
|
||||||
|
* property="entity_id",
|
||||||
|
* type="intager",
|
||||||
|
* example=234,
|
||||||
|
* description="Идентификатор сущности",
|
||||||
|
* ),
|
||||||
|
* @OA\Property(
|
||||||
|
* property="status",
|
||||||
|
* type="intager",
|
||||||
|
* example=1,
|
||||||
|
* description="Статус",
|
||||||
|
* ),
|
||||||
|
* ),
|
||||||
|
* ),
|
||||||
|
* ),
|
||||||
|
* @OA\Response(
|
||||||
|
* response=200,
|
||||||
|
* description="Возвращает объект прикрепления",
|
||||||
|
* @OA\MediaType(
|
||||||
|
* mediaType="application/json",
|
||||||
|
* @OA\Schema(ref="#/components/schemas/FileEntity"),
|
||||||
|
* ),
|
||||||
|
* ),
|
||||||
|
* )
|
||||||
|
*
|
||||||
|
* @return FileEntity
|
||||||
|
* @throws NotFoundHttpException
|
||||||
|
* @throws ServerErrorHttpException
|
||||||
|
*/
|
||||||
|
public function actionAttach()
|
||||||
|
{
|
||||||
|
$request = \Yii::$app->request->post();
|
||||||
|
$file = File::findOne($request['file_id']);
|
||||||
|
if (!$file) {
|
||||||
|
throw new NotFoundHttpException('File bot found');
|
||||||
|
}
|
||||||
|
|
||||||
|
$fileEntity = new FileEntity();
|
||||||
|
$fileEntity->load($request, '');
|
||||||
|
|
||||||
|
if(!$fileEntity->validate()){
|
||||||
|
throw new ServerErrorHttpException(json_encode($fileEntity->errors));
|
||||||
|
}
|
||||||
|
|
||||||
|
$fileEntity->save();
|
||||||
|
|
||||||
|
return $fileEntity;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
@ -141,7 +141,7 @@ class ProjectController extends ApiController
|
|||||||
}
|
}
|
||||||
if (!empty($user_id)) {
|
if (!empty($user_id)) {
|
||||||
$projectIdList = ProjectUser::find()->where(['user_id' => $user_id])->select('project_id')->column();
|
$projectIdList = ProjectUser::find()->where(['user_id' => $user_id])->select('project_id')->column();
|
||||||
$query = Project::find()->where(['IN', 'id', $projectIdList])->andWhere(['status' => Project::STATUS_OTHER])->orWhere(['owner_id' => $user_id]);
|
$query = Project::find()->where(['IN', 'id', $projectIdList])->orWhere(['owner_id' => $user_id, 'status' => Project::STATUS_OTHER]);
|
||||||
} else {
|
} else {
|
||||||
$query = Project::find();
|
$query = Project::find();
|
||||||
}
|
}
|
||||||
|
66
frontend/modules/api/models/File.php
Normal file
66
frontend/modules/api/models/File.php
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace frontend\modules\api\models;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @OA\Schema(
|
||||||
|
* schema="File",
|
||||||
|
* @OA\Property(
|
||||||
|
* property="id",
|
||||||
|
* type="int",
|
||||||
|
* example=1,
|
||||||
|
* description="Идентификатор файла"
|
||||||
|
* ),
|
||||||
|
* @OA\Property(
|
||||||
|
* property="name",
|
||||||
|
* type="string",
|
||||||
|
* example="image.png",
|
||||||
|
* description="Имя файла"
|
||||||
|
* ),
|
||||||
|
* @OA\Property(
|
||||||
|
* property="path",
|
||||||
|
* type="string",
|
||||||
|
* example="/frontend/web/files/c3/8b/c38bf511e3082e3021bed1572c2c8144.png",
|
||||||
|
* description="Путь к файлу"
|
||||||
|
* ),
|
||||||
|
* @OA\Property(
|
||||||
|
* property="url",
|
||||||
|
* type="string",
|
||||||
|
* example="/files/c3/8b/c38bf511e3082e3021bed1572c2c8144.png",
|
||||||
|
* description="URL файла"
|
||||||
|
* ),
|
||||||
|
* @OA\Property(
|
||||||
|
* property="type",
|
||||||
|
* type="string",
|
||||||
|
* example="png",
|
||||||
|
* description="Расширение файла"
|
||||||
|
* ),
|
||||||
|
* @OA\Property(
|
||||||
|
* property="mime-type",
|
||||||
|
* type="string",
|
||||||
|
* example="image/png",
|
||||||
|
* description="Mime-type файла"
|
||||||
|
* ),
|
||||||
|
* @OA\Property(
|
||||||
|
* property="status",
|
||||||
|
* type="integer",
|
||||||
|
* example=1,
|
||||||
|
* description="Статус файла"
|
||||||
|
* ),
|
||||||
|
*)
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @OA\Schema(
|
||||||
|
* schema="FileExample",
|
||||||
|
* type="array",
|
||||||
|
* @OA\Items(
|
||||||
|
* ref="#/components/schemas/File",
|
||||||
|
* ),
|
||||||
|
*)
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
class File extends \common\models\File
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
45
frontend/modules/api/models/FileEntity.php
Normal file
45
frontend/modules/api/models/FileEntity.php
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace frontend\modules\api\models;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @OA\Schema(
|
||||||
|
* schema="FileEntity",
|
||||||
|
* @OA\Property(
|
||||||
|
* property="id",
|
||||||
|
* type="int",
|
||||||
|
* example=1,
|
||||||
|
* description="Идентификатор файла"
|
||||||
|
* ),
|
||||||
|
* @OA\Property(
|
||||||
|
* property="file_id",
|
||||||
|
* type="integer",
|
||||||
|
* example=232,
|
||||||
|
* description="Идентификатор файла"
|
||||||
|
* ),
|
||||||
|
* @OA\Property(
|
||||||
|
* property="entity_type",
|
||||||
|
* type="integer",
|
||||||
|
* example=2,
|
||||||
|
* description="Идентификатор типа сущности"
|
||||||
|
* ),
|
||||||
|
* @OA\Property(
|
||||||
|
* property="entity_id",
|
||||||
|
* type="integer",
|
||||||
|
* example=24,
|
||||||
|
* description="Идентификатор сущности"
|
||||||
|
* ),
|
||||||
|
* @OA\Property(
|
||||||
|
* property="status",
|
||||||
|
* type="integer",
|
||||||
|
* example=1,
|
||||||
|
* description="Статус прикрепления"
|
||||||
|
* ),
|
||||||
|
*)
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
class FileEntity extends \common\models\FileEntity
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user