blob: e220624f9ce8e96e19cb41c06e80561e385ebd51 [file] [log] [blame]
// Copyright 2017 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
// Utility routines for working with UsbDevices that are printers.
#ifndef CHROME_BROWSER_ASH_PRINTING_USB_PRINTER_UTIL_H_
#define CHROME_BROWSER_ASH_PRINTING_USB_PRINTER_UTIL_H_
#include <optional>
#include <string>
#include "chrome/browser/ash/printing/printer_detector.h"
#include "mojo/public/cpp/bindings/remote.h"
#include "services/device/public/mojom/usb_device.mojom-forward.h"
namespace chromeos {
class Printer;
class UsbPrinterId;
} // namespace chromeos
namespace ash {
// Given a usb device, guesses the make and model for a driver lookup.
std::string GuessEffectiveMakeAndModel(
const device::mojom::UsbDeviceInfo& device_info);
std::string GetManufacturerName(
const device::mojom::UsbDeviceInfo& device_info);
std::string GetProductName(const device::mojom::UsbDeviceInfo& device_info);
std::u16string GetSerialNumber(const device::mojom::UsbDeviceInfo& device_info);
bool UsbDeviceIsPrinter(const device::mojom::UsbDeviceInfo& device_info);
// Attempt to gather all the information we need to work with this printer by
// querying the USB device. This should only be called using devices we believe
// are printers, not arbitrary USB devices, as we may get weird partial results
// from arbitrary devices. The results are saved in the second parameter.
//
// Returns false and logs an error on failure.
bool UsbDeviceToPrinter(const device::mojom::UsbDeviceInfo& device_info,
PrinterDetector::DetectedPrinter* entry);
// Expects `device` to be linked to a Printer-class USB Device described by
// `device_info`. Queries the printer for its IEEE 1284 Standard Device ID.
using GetDeviceIdCallback = base::OnceCallback<void(chromeos::UsbPrinterId)>;
void GetDeviceId(const device::mojom::UsbDeviceInfo& device_info,
mojo::Remote<device::mojom::UsbDevice> device,
GetDeviceIdCallback cb);
// Create a USB printer display name that incorporates any non-empty values from
// |make| and |model|.
std::string MakeDisplayName(const std::string& make, const std::string& model);
// Add device info from `device_id` to the PPD search information in `printer`.
// If `printer` contains generic USB strings, replace the default search data
// from `device_id` entirely.
void UpdateSearchDataFromDeviceId(const chromeos::UsbPrinterId& device_id,
PrinterDetector::DetectedPrinter* printer);
// Implementation details exposed only for testing.
namespace internal {
// Where to send GET_DEVICE_ID class-specific requests.
struct PrinterInterfaceTarget {
// Device VID:PID for logging.
std::string vidpid;
// Zero-based config index.
uint8_t config;
// Zero-based interface index.
uint8_t interface;
// Zero-based interface alternate.
uint8_t alternate;
// True if SET_INTERFACE is needed before sending printer class requests,
// primarily if the interface has more than one alternate.
bool set_alternate;
bool operator==(const PrinterInterfaceTarget&) const = default;
};
// Find a valid printer class interface for sending GET_DEVICE_ID requests.
std::optional<PrinterInterfaceTarget> FindPrinterInterfaceTarget(
const device::mojom::UsbDeviceInfo& device_info);
} // namespace internal
} // namespace ash
#endif // CHROME_BROWSER_ASH_PRINTING_USB_PRINTER_UTIL_H_