From 68832756538d132e30549df3d9c5dca9878e5804 Mon Sep 17 00:00:00 2001 From: Eelco Dolstra Date: Thu, 10 Nov 2016 17:40:56 +0100 Subject: [PATCH] Ignore package listings with malformed UTF-8 For example, https://cache.nixos.org/5q3s4vfwwd9n9499yg11ydziwxgn644m.ls.xz contains the string "bokml.alias". This causes nlohmann::json to barf. --- generate-programs-index.cc | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/generate-programs-index.cc b/generate-programs-index.cc index 74507b5..96ad294 100644 --- a/generate-programs-index.cc +++ b/generate-programs-index.cc @@ -50,6 +50,7 @@ static const char * programsSchema = R"sql( )sql"; +MakeError(BadJSON, Error); void mainWrapped(int argc, char * * argv) { @@ -198,7 +199,15 @@ void mainWrapped(int argc, char * * argv) auto now1 = std::chrono::steady_clock::now(); DownloadRequest req(binaryCacheUri + "/" + storePathToHash(storePath) + ".ls.xz"); req.showProgress = DownloadRequest::no; - auto ls = json::parse(*decompress("xz", *getDownloader()->download(req).data)); + json ls; + try { + ls = json::parse(*decompress("xz", *getDownloader()->download(req).data)); + } catch (std::invalid_argument & e) { + // FIXME: some filenames have non-UTF8 characters in them, + // which is not supported by nlohmann::json. So we have to + // skip the entire package. + throw BadJSON(e.what()); + } if (ls.value("version", 0) != 1) throw Error("NAR index for ā€˜%sā€™ has an unsupported version", storePath); @@ -292,6 +301,8 @@ void mainWrapped(int argc, char * * argv) } catch (DownloadError & e) { printInfo("warning: no listing of %s (%s) in binary cache", package->attrPath, storePath); + } catch (BadJSON & e) { + printError("error: in %s (%s): %s", package->attrPath, storePath, e.what()); } };