blob: 8d8c7052019c5c2935a2e1568ca3c68361ce9e39 [file] [log] [blame]
// Copyright 2024 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
syntax = "proto3";
option optimize_for = LITE_RUNTIME;
import "print_job_options.proto";
// Describes one managed printer configuration.
// A list of `ManagedPrinterConfiguration` messages converted to a JSON array
// corresponds to the contents `PrintersBulkConfiguration` and `DevicePrinters`
// chromium policies.
// Printers that have a `guid` field which is not in `PrintersBulkAllowlist`
// or `DevicePrintersAllowlist` will be ignored. Invalid printers (e.g.
// missing required fields, invalid URI) will be ignored.
message ManagedPrinterConfiguration {
// Required. Unique identifier for the printer. This is referenced in the
// `PrintersBulkConfiguration` and `DevicePrintersAllowlist` policies.
optional string guid = 1;
// Required. Printer name visible in the print preview dialog.
optional string display_name = 2 [json_name = "display_name"];
// Optional. Printer description visible in the print preview dialog.
optional string description = 3;
// Serialized to JSON as an int (not a string).
enum UsbProtocol {
USB_PROTOCOL_UNSPECIFIED = 0;
USB_PROTOCOL_LEGACY_USB = 1;
USB_PROTOCOL_IPP_USB = 2;
}
message UsbDeviceId {
// Required.
int32 vendor_id = 1 [json_name = "vendor_id"];
// Required.
int32 product_id = 2 [json_name = "product_id"];
// Required.
UsbProtocol usb_protocol = 3 [json_name = "usb_protocol"];
}
// Required. Specifies the way the printer is connected to the device.
oneof connection_type {
// The URI used to connect to the printer.
string uri = 4;
// The IDs of the printer connected via USB.
UsbDeviceId usb_device_id = 7 [json_name = "usb_device_id"];
}
// Defines the source of the PPD file to be used during printer setup.
message PpdResource {
oneof resource {
// The PPD file matching `effective_model` from the PPD index will be
// used.
string effective_model = 1 [json_name = "effective_model"];
// A PPD file will be generated by querying the printer for its
// capabilities and available options. Suitable for IPP-Everywhere
// printers.
bool autoconf = 2;
// The PPD file hosted at `user_supplied_ppd_uri` will be downloaded and
// used during printer setup.
string user_supplied_ppd_uri = 3 [json_name = "user_supplied_ppd_uri"];
}
}
// Required. Source of the PPD file to use during printer setup.
optional PpdResource ppd_resource = 5 [json_name = "ppd_resource"];
// Optional. Contains print job options specific to this particular printer.
optional PrintJobOptions print_job_options = 6
[json_name = "print_job_options"];
}