blob: 3fc0d2335bebfbc7920575bb4e5840d34610d8f0 [file] [log] [blame]
Greg Kerra6c0c522016-07-25 11:15:31 -07001// Copyright 2016 The Chromium OS Authors. All rights reserved.
2// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
Greg Kerr2f76fde2016-08-29 16:39:45 -07004#ifndef IMAGELOADER_IMAGELOADER_IMPL_H_
5#define IMAGELOADER_IMAGELOADER_IMPL_H_
Greg Kerra6c0c522016-07-25 11:15:31 -07006
7#include <string>
8#include <vector>
9
10#include <base/files/file_path.h>
11#include <base/gtest_prod_util.h>
12#include <base/macros.h>
13
Greg Kerr9944e242017-01-26 15:09:31 -080014#include "helper_process.h"
Greg Kerr89be05f2016-07-27 10:40:32 -070015
Greg Kerra6c0c522016-07-25 11:15:31 -070016namespace imageloader {
17
18struct ImageLoaderConfig {
Greg Kerr89be05f2016-07-27 10:40:32 -070019 ImageLoaderConfig(const std::vector<uint8_t> key, const char* storage_path,
Greg Kerr9944e242017-01-26 15:09:31 -080020 const char* mount_path)
Greg Kerr89be05f2016-07-27 10:40:32 -070021 : key(key),
22 storage_dir(storage_path),
Greg Kerr9944e242017-01-26 15:09:31 -080023 mount_path(mount_path) {}
Greg Kerr89be05f2016-07-27 10:40:32 -070024
Greg Kerra6c0c522016-07-25 11:15:31 -070025 std::vector<uint8_t> key;
26 base::FilePath storage_dir;
Greg Kerr89be05f2016-07-27 10:40:32 -070027 base::FilePath mount_path;
Greg Kerra6c0c522016-07-25 11:15:31 -070028};
29
30class ImageLoaderImpl {
31 public:
32 // Instantiate an object with a configuration object.
Greg Kerr89be05f2016-07-27 10:40:32 -070033 explicit ImageLoaderImpl(ImageLoaderConfig config)
34 : config_(std::move(config)) {}
Greg Kerra6c0c522016-07-25 11:15:31 -070035
36 // Register a component.
37 bool RegisterComponent(const std::string& name, const std::string& version,
38 const std::string& component_folder_abs_path);
39
40 // Get component version given component name.
41 std::string GetComponentVersion(const std::string& name);
42
Greg Kerr019d59c2016-11-17 14:28:49 -080043 // Load the specified component. This returns the mount point or an empty
44 // string on failure.
Greg Kerr9944e242017-01-26 15:09:31 -080045 std::string LoadComponent(const std::string& name, HelperProcess* process);
Greg Kerra6c0c522016-07-25 11:15:31 -070046
Greg Kerrc5b91692016-09-14 12:09:22 -070047 // Load the specified component at a set mount point.
Greg Kerr9944e242017-01-26 15:09:31 -080048 bool LoadComponent(const std::string& name, const std::string& mount_point,
49 HelperProcess* process);
Greg Kerrc5b91692016-09-14 12:09:22 -070050
Greg Kerr019d59c2016-11-17 14:28:49 -080051 // The directory hierarchy for a component consists of the storage_root (i.e.
52 // `/var/lib/imageloader`), the component_root
53 // (`/var/lib/imageloader/ComponentName`), and the version folder (i.e.
54 // `/var/lib/imageloader/ComponentName/23.0.0.205`). That is:
55 // [storage_root]/
56 // [storage_root]/[component_root]
57 // [storage_root]/[component_root]/[version]
58 //
59 // Inside the `component_root` there is a current version hint file:
60 // [storage_root]/[component_root]/latest-version
61
62 // Return the path to latest-version file for |component_name|.
63 base::FilePath GetLatestVersionFilePath(const std::string& component_name);
64
65 // Return the path to the [component_root] folder for |component_name|.
66 base::FilePath GetComponentRoot(const std::string& component_name);
67
68 // Return the path to a given version of |component_name|.
69 base::FilePath GetVersionPath(const std::string& component_name,
70 const std::string& version);
71
72 // Return the path to the current version of |component_name|.
73 bool GetPathToCurrentComponentVersion(const std::string& component_name,
74 base::FilePath* result);
75
Greg Kerra6c0c522016-07-25 11:15:31 -070076 private:
Greg Kerra6c0c522016-07-25 11:15:31 -070077 // The configuration traits.
78 ImageLoaderConfig config_;
79
80 DISALLOW_COPY_AND_ASSIGN(ImageLoaderImpl);
81};
82
83} // namespace imageloader
84
Greg Kerr2f76fde2016-08-29 16:39:45 -070085#endif // IMAGELOADER_IMAGELOADER_IMPL_H_