blob: 99475b9ed6a502ca1ec6616803d55ed2188fe4d8 [file] [log] [blame]
// 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 <cstdint>
#include <string>
#include <vector>
#include "base/files/file_path.h"
#include "base/files/file_util.h"
#include "base/logging.h"
#include "components/crx_file/crx_creator.h"
#include "crypto/keypair.h"
// This program, invoked via `crx_build_action out zip key` constructs a CRX3 at
// `out` from the input zip archive at `zip` and signed with the key at `key`.
// The file at `key` should be a DER-formatted PKCS #8 PrivateKeyInfo block.
//
// Consult crx3.gni for more information.
int main(int argc, char** raw_argv) {
UNSAFE_BUFFERS(
// SAFETY: The OS guarantees that there are at least argc argument values
// starting at raw_argv.
base::span<char*> argv(raw_argv, base::checked_cast<size_t>(argc));)
std::string key_file;
if (!base::ReadFileToString(
base::MakeAbsoluteFilePath(base::FilePath::FromASCII(argv[3])),
&key_file)) {
VLOG(0) << "Failed to read key material from " << argv[3];
return -1;
}
return static_cast<int>(crx_file::Create(
base::FilePath::FromASCII(argv[1]), base::FilePath::FromASCII(argv[2]),
*crypto::keypair::PrivateKey::FromPrivateKeyInfo(
base::as_byte_span(key_file))));
}