mirror of
https://github.com/Kovah/LinkAce.git
synced 2025-02-25 03:32:59 +01:00
120 lines
3.5 KiB
PHP
120 lines
3.5 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\App;
|
|
|
|
use App\Helper\HtmlMeta;
|
|
use App\Helper\LinkIconMapper;
|
|
use App\Http\Controllers\Controller;
|
|
use App\Http\Requests\DoImportRequest;
|
|
use App\Models\Link;
|
|
use App\Models\Tag;
|
|
use Carbon\Carbon;
|
|
use Exception;
|
|
use Illuminate\Contracts\Filesystem\FileNotFoundException;
|
|
use Illuminate\Http\JsonResponse;
|
|
use Illuminate\Support\Facades\Log;
|
|
use Illuminate\Contracts\View\View;
|
|
use Shaarli\NetscapeBookmarkParser\NetscapeBookmarkParser;
|
|
|
|
class ImportController extends Controller
|
|
{
|
|
/**
|
|
* Display the initial screen to start the import.
|
|
*
|
|
* @return View
|
|
*/
|
|
public function getImport(): View
|
|
{
|
|
return view('actions.import.import');
|
|
}
|
|
|
|
/**
|
|
* Load the provided HTML bookmarks file and save all parsed results as new
|
|
* links including tags. This method is called via an Ajax call to prevent
|
|
* timeouts during the link creation.
|
|
*
|
|
* @param DoImportRequest $request
|
|
* @return JsonResponse
|
|
* @throws FileNotFoundException
|
|
*/
|
|
public function doImport(DoImportRequest $request)
|
|
{
|
|
$data = $request->file('import-file')->get();
|
|
|
|
$parser = new NetscapeBookmarkParser(true, [], '0', storage_path('logs'));
|
|
|
|
try {
|
|
$links = $parser->parseString($data);
|
|
} catch (Exception $e) {
|
|
Log::error($e->getMessage());
|
|
|
|
return response()->json([
|
|
'success' => false,
|
|
'message' => trans('import.import_error'),
|
|
]);
|
|
}
|
|
|
|
if (empty($links)) {
|
|
// This will never be reached at the moment because the bookmark parser is not capable of handling
|
|
// empty bookmarks exports. See https://github.com/shaarli/netscape-bookmark-parser/issues/50
|
|
return response()->json([
|
|
'success' => false,
|
|
'message' => trans('import.import_empty'),
|
|
]);
|
|
}
|
|
|
|
$userId = auth()->id();
|
|
$imported = 0;
|
|
$skipped = 0;
|
|
|
|
foreach ($links as $link) {
|
|
if (Link::whereUrl($link['uri'])->first()) {
|
|
$skipped++;
|
|
continue;
|
|
}
|
|
|
|
$linkMeta = HtmlMeta::getFromUrl($link['uri']);
|
|
|
|
$title = $link['title'] ?: $linkMeta['title'];
|
|
|
|
$newLink = Link::create([
|
|
'user_id' => $userId,
|
|
'url' => $link['uri'],
|
|
'title' => $title,
|
|
'description' => $link['note'] ?: $linkMeta['description'],
|
|
'icon' => LinkIconMapper::mapLink($link['uri']),
|
|
'is_private' => $link['pub'],
|
|
'created_at' => Carbon::createFromTimestamp($link['time']),
|
|
'updated_at' => Carbon::now(),
|
|
]);
|
|
|
|
// Get all tags
|
|
if (!empty($link['tags'])) {
|
|
$tags = explode(' ', $link['tags']);
|
|
|
|
$newTags = [];
|
|
foreach ($tags as $tag) {
|
|
$newTag = Tag::firstOrCreate([
|
|
'user_id' => $userId,
|
|
'name' => $tag,
|
|
]);
|
|
|
|
$newTags[] = $newTag->id;
|
|
}
|
|
|
|
$newLink->tags()->sync($newTags);
|
|
}
|
|
|
|
$imported++;
|
|
}
|
|
|
|
return response()->json([
|
|
'success' => true,
|
|
'message' => trans('import.import_successfully', [
|
|
'imported' => $imported,
|
|
'skipped' => $skipped,
|
|
]),
|
|
]);
|
|
}
|
|
}
|