File: web_app_internals_utils.cc

package info (click to toggle)
chromium 139.0.7258.127-1
  • links: PTS, VCS
  • area: main
  • in suites:
  • size: 6,122,068 kB
  • sloc: cpp: 35,100,771; ansic: 7,163,530; javascript: 4,103,002; python: 1,436,920; asm: 946,517; xml: 746,709; pascal: 187,653; perl: 88,691; sh: 88,436; objc: 79,953; sql: 51,488; cs: 44,583; fortran: 24,137; makefile: 22,147; tcl: 15,277; php: 13,980; yacc: 8,984; ruby: 7,485; awk: 3,720; lisp: 3,096; lex: 1,327; ada: 727; jsp: 228; sed: 36
file content (136 lines) | stat: -rw-r--r-- 4,762 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
// Copyright 2021 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#include "chrome/browser/web_applications/web_app_internals_utils.h"

#include <string_view>

#include "base/files/file_path.h"
#include "base/json/json_file_value_serializer.h"
#include "base/memory/scoped_refptr.h"
#include "base/task/task_traits.h"
#include "base/task/thread_pool.h"
#include "base/values.h"
#include "chrome/browser/web_applications/file_utils_wrapper.h"
#include "chrome/browser/web_applications/web_app_utils.h"
#include "content/public/browser/browser_thread.h"

namespace web_app {

namespace {

struct ErrorLogData {
  Result result;
  base::Value error_log;
};

constexpr base::TaskTraits kTaskTraits = {
    base::MayBlock(), base::TaskPriority::USER_VISIBLE,
    base::TaskShutdownBehavior::BLOCK_SHUTDOWN};

base::FilePath GetErrorLogDirectory(const base::FilePath& web_apps_directory) {
  return web_apps_directory.AppendASCII("Logs");
}

base::FilePath GetErrorLogFileName(const base::FilePath& web_apps_directory,
                                   std::string_view subsystem_name) {
  return GetErrorLogDirectory(web_apps_directory)
      .AppendASCII(subsystem_name.data())
      .AddExtensionASCII("log");
}

ErrorLogData ReadErrorLogBlocking(scoped_refptr<FileUtilsWrapper> utils,
                                  const base::FilePath& web_apps_directory,
                                  std::string_view subsystem_name) {
  base::FilePath log_file_name =
      GetErrorLogFileName(web_apps_directory, subsystem_name);

  ErrorLogData data;

  JSONFileValueDeserializer deserializer(log_file_name);
  std::string error_msg;
  std::unique_ptr<base::Value> error_log =
      deserializer.Deserialize(nullptr, &error_msg);

  if (error_log) {
    data.result = Result::kOk;
    data.error_log = std::move(*error_log);
  } else {
    data.result = Result::kError;
  }

  return data;
}

void OnReadErrorLogBlocking(ReadErrorLogCallback callback, ErrorLogData data) {
  std::move(callback).Run(data.result, std::move(data.error_log));
}

Result WriteErrorLogBlocking(scoped_refptr<FileUtilsWrapper> utils,
                             const base::FilePath& web_apps_directory,
                             std::string_view subsystem_name,
                             base::Value error_log) {
  if (!utils->CreateDirectory(GetErrorLogDirectory(web_apps_directory)))
    return Result::kError;

  base::FilePath log_file_name =
      GetErrorLogFileName(web_apps_directory, subsystem_name);

  JSONFileValueSerializer serializer(log_file_name);
  return serializer.Serialize(error_log) ? Result::kOk : Result::kError;
}

Result ClearErrorLogBlocking(scoped_refptr<FileUtilsWrapper> utils,
                             const base::FilePath& web_apps_directory,
                             std::string_view subsystem_name) {
  base::FilePath log_file_name =
      GetErrorLogFileName(web_apps_directory, subsystem_name);

  return utils->DeleteFile(log_file_name, /*recursive=*/false) ? Result::kOk
                                                               : Result::kError;
}

}  // namespace

void ReadErrorLog(const base::FilePath& web_apps_directory,
                  std::string_view subsystem_name,
                  ReadErrorLogCallback callback) {
  DCHECK_CURRENTLY_ON(content::BrowserThread::UI);

  base::ThreadPool::PostTaskAndReplyWithResult(
      FROM_HERE, kTaskTraits,
      base::BindOnce(ReadErrorLogBlocking,
                     base::MakeRefCounted<FileUtilsWrapper>(),
                     web_apps_directory, subsystem_name),
      base::BindOnce(OnReadErrorLogBlocking, std::move(callback)));
}

void WriteErrorLog(const base::FilePath& web_apps_directory,
                   std::string_view subsystem_name,
                   base::Value error_log,
                   FileIoCallback callback) {
  DCHECK_CURRENTLY_ON(content::BrowserThread::UI);

  base::ThreadPool::PostTaskAndReplyWithResult(
      FROM_HERE, kTaskTraits,
      base::BindOnce(WriteErrorLogBlocking,
                     base::MakeRefCounted<FileUtilsWrapper>(),
                     web_apps_directory, subsystem_name, std::move(error_log)),
      std::move(callback));
}

void ClearErrorLog(const base::FilePath& web_apps_directory,
                   std::string_view subsystem_name,
                   FileIoCallback callback) {
  DCHECK_CURRENTLY_ON(content::BrowserThread::UI);

  base::ThreadPool::PostTaskAndReplyWithResult(
      FROM_HERE, kTaskTraits,
      base::BindOnce(ClearErrorLogBlocking,
                     base::MakeRefCounted<FileUtilsWrapper>(),
                     web_apps_directory, subsystem_name),
      std::move(callback));
}

}  // namespace web_app