Как обновить запросы, когда используются несколько дБ и используются изображения - PullRequest
0 голосов
/ 09 апреля 2019

Попытка создания API, где пользователь создает сообщение, которое включает в себя заголовок и время приготовления пищи, и они могут разместить до 2 изображений в двух таблицах posts и post_images в двух разных базах данных. функция магазина работает отлично, но я понятия не имею о функции обновления. Я могу обновить все сообщения через почтальона, но изображения не обновляются

public function store(Request $request)
{
    $post = new Post;
    $post->setConnection('mysql1');
    $user = User::where('id', $request->id)->first();
    if ($user) {
        $post =  Auth::user()->posts()->create([
            'user_id' => Auth::id(),
            'post_id' => rand(),
            'title' => $request->title,
            'cooked_time' => strtotime($request->cooked_time),
        ]);
        $images = new PostImage;
        $destination_path = public_path('/images');
        if ($request->hasFile('image1')) {
            $image1 = $request->file('image1');
            $image_size1 = $image1->getClientSize();
            $image_ext1 = $image1->getClientOriginalExtension();
            $new_image_name1 = rand(123456, 99999999) . "." . $image_ext1;
            $image1->move($destination_path, $new_image_name1);
            $images->image_name1 = $new_image_name1;
        }
        if ($request->hasFile('image2')) {
            $image2 = $request->file('image2');
            $image_size2 = $image2->getClientSize();
            $image_ext2 = $image2->getClientOriginalExtension();
            $new_image_name2 = rand(123456, 99999999) . "." . $image_ext2;
            $image2->move($destination_path, $new_image_name2);
            $images->image_name2 = $new_image_name2;
        }
        $images->post_id = $post->post_id;
        $images->save();
        $post = json_decode($post);
        $post->image1 = $images->image_name1;
        $post->image2 = $images->image_name2;
        if ($post && $images) {
            return $this->successResponse($post);
        } else {
            return $this->errorResponse("Post Failed", 200);
        }
    }
}

Мой код обновления похож на

public function update(Request $request, $post_id)
{
    $posts = Post::findorFail($post_id);
    if (Auth::user()->id !== $posts->user_id) {
        return response()->json(['status' => 'error', 'message' => 'unauthorized'], 401);
    }
    $post1 = $request->all();
    $posts->fill($post1)->save();
    $image = PostImage::where('post_id', $posts->post_id)->get()->first();
    $images = PostImage::findorFail($image->id);
    if ($request->hasFile('image1')) {
        $image1 = $request->file('image1');
        $image_size1 = $image1->getClientSize();
        $image_ext1 = $image1->getClientOriginalExtension();
        $new_image_name1 = $post_image['image_name1'] . "." . $image_ext1;
        $image1->move($destination_path, $new_image_name1);
        $images->image_name1 = $new_image_name1;
    }
    if ($request->hasFile('image2')) {
        $image2 = $request->file('image2');
        $image_size2 = $image2->getClientSize();
        $image_ext2 = $image2->getClientOriginalExtension();
        $new_image_name2 = $post_image['image_name2'] . "." . $image_ext2;
        $image2->move($destination_path, $new_image_name2);
        $images->image_name2 = $new_image_name2;
    }
    $images->post_id = $post->post_id;
    $images->save();
    return response()->json(['status' => 'success', 'updated_post' => $posts, 'images' => $images], 200);
}

Я хотел выполнить запрос на обновление, чтобы обновлять как изображения, так и сообщения, если есть параметр изображения, переданный через почтальона.

...