Description
Use the chrome.documentScan API to discover and retrieve images from attached document scanners.
The Document Scan API is designed to allow apps and extensions to view the content of paper documents on an attached document scanner.
Permissions
documentScanAvailability
Concepts and usage
This API supports two means of scanning documents. If your use case can work
with any scanner and doesn't require control of the configuration, use the
scan() method. More complicated use cases require a combination of methods,
which are only supported in Chrome 124 and later.
Simple scanning
For simple use cases, meaning those that can work with any scanner and don't
require control of configuration, call scan(). This method takes a
ScanOptions object and returns a Promise that resolves with a ScanResults
object. The capabilities of this option are limited to the number of scans and
the MIME types that will be accepted by the caller. Scans are returned as URLs
for display in an <img> tag for a user interface.
Complex scanning
Complex scans are accomplished in three phases as described in this section. This outline does not describe every method argument or every property returned in a response. It is only intended to give you a general guide to writing scanner code.
Discovery
- Call - getScannerList(). Available scanners are returned in a Promise that resolves with a- GetScannerListResponse.- The response object contains an array of ScannerInfoobjects.
- The array may contain multiple entries for a single scanner if that scanner supports multiple protocols or connection methods.
 
- The response object contains an array of 
- Select a scanner from the returned array and save the value of its - scannerIdproperty.- Use the properties of individual - ScannerInfoobjects to distinguish among multiple objects for the same scanner. Objects from the same scanner will have the same value for the- deviceUuidproperty.- ScannerInfoalso contains an- imageFormatsproperty containing an array of supported image types.
Scanner configuration
- Call - openScanner(), passing in the saved scanner ID. It returns a Promise that resolves with an- OpenScannerResponse. The response object contains:- A - scannerHandleproperty, which you'll need to save.
- An options property containing scanner-specific properties, which you'll need to set. See Retrieve scanner options for more information. 
 
- (Optional) If you need the user to provide values for scanner options, construct a user interface. You will need the scanner options provided by the previous step, and you'll need to retrieve option groups provided by the scanner. See Construct a user interface for more information. 
- Construct an array of - OptionSettingobjects using programmatic or user-provided values. See Set scanner options for more information.
- Pass the array of - OptionSettingobjects to- setOptions()to set options for the scanner. It returns a Promise that resolves with a- SetOptionsResponse. This object contains an updated version of the scanner options retrieved in step 1 of scanner configuration.- Since changing one option can alter constraints on another option, you may need to repeat these steps several times. 
Scanning
- Construct a - StartScanOptionsobject and pass it to- startScan(). It returns a Promise that resolves with a- StartScanResponse. Its- jobproperty is a handle that you will use to either read scan data or cancel the scan.
- Pass the job handle to - readScanData(). It returns a Promise that resolves with a- ReadScanDataResponseobject. If data was read successfully, its- resultproperty equals- SUCCESSand its- dataproperty contains an- ArrayBufferwith part of the scan. Note that- estimatedCompletioncontains an estimated percentage of the total data that has been delivered so far.
- Repeat the previous step until the - resultproperty equals- EOFor an error.
When the end of the scan is reached, call
closeScanner() with the scanner handle saved in step
3. It returns a Promise that resolves with a
CloseScannerResponse. Calling
cancelScan() at any time after the job is created will
end scanning.
Response objects
All methods return a Promise that resolves with a response object of some kind.
Most of these contain a result property whose value is a member of
OperationResult. Some properties of response objects
won't contain values unless the value of result has a specific value. These
relationships are described in the reference for each response object.
For example, OpenScannerResponse.scannerHandle will only have a value when
OpenScannerResponse.result equals SUCCESS.
Scanner options
Scanner options vary considerably by device. Consequently, it's not possible to
reflect scanner options directly within the documentScan API. To get around
this, the OpenScannerResponse (retrieved using
openScanner()) and the
SetOptionsResponse (the response object for
setOptions()) contain an options property which is an
object containing scanner-specific options. Each option is a key-value mapping
where the key is a device-specific option and the value is an instance of
ScannerOption.
The structure generally looks like this:
{
  "key1": { scannerOptionInstance }
  "key2": { scannerOptionInstance }
}
For example, imagine a scanner that returns options named "source" and
"resolution". The structure of the returned options object will look something
like the following example. For simplicity, only partial ScannerOption
responses are shown.
{
  "source": {
    "name": "source",
    "type": OptionType.STRING,
...
},
  "resolution": {
    "name": "resolution",
    "type": OptionType.INT,
...
  },
...
}
Construct a user interface
Though not required to use this API, you may want a user to choose the value for
a particular option. This requires a user interface. Use the
OpenScannerResponse (opened by
openScanner()) to retrieve the options for the attached
scanner as described in the previous section.
Some scanners group options in device-specific ways. They don't affect option
behaviors, but since these groups may be mentioned in a scanner's product
documentation, such groups should be shown to the user. You can retrieve these
groups by calling getOptionGroups(). This returns a
Promise that resolves with a
GetOptionGroupsResponse object. Its groups
property contains a scanner-specific array of groups. Use the information in
these groups to organize the options in the
OpenScannerResponse for display.
{
  scannerHandle: "123456",
  result: SUCCESS,
  groups: [
    {
      title: "Standard",
      members: [ "resolution", "mode", "source" ]
    }
  ]
}
As stated under Scanner configuration, changing one option can alter constraints
on another option. This is why
setOptionsResponse (the response object for
setOptions()) contains another options property. Use
this to update the user interface. Then repeat as needed until all options are
set.
Set scanner options
Set scanner options by passing an array of
OptionSetting objects to
setOptions(). For an example, see the following Scan one letter-size page section.
Examples
Retrieve a page as a blob
This example shows one way to retrieve a page from the scanner as a blob and
demonstrates use of startScan() and readScanData() using the value of
OperationResult.
async function pageAsBlob(handle) {
  let response = await chrome.documentScan.startScan(
      handle, {format: "image/jpeg"});
  if (response.result != chrome.documentScan.OperationResult.SUCCESS) {
    return null;
  }
  const job = response.job;
  let imgParts = [];
  response = await chrome.documentScan.readScanData(job);
  while (response.result == chrome.documentScan.OperationResult.SUCCESS) {
    if (response.data && response.data.byteLength > 0) {
        imgParts.push(response.data);
    } else {
      // Delay so hardware can make progress.
      await new Promise(r => setTimeout(r, 100));
    }
    response = await chrome.documentScan.readScanData(job);
  }
  if (response.result != chrome.documentScan.OperationResult.EOF) {
    return null;
  }
  if (response.data && response.data.byteLength > 0) {
    imgParts.push(response.data);
  }
  return new Blob(imgParts, { type: "image/jpeg" });
}
Scan one letter-size page
This example shows how to select a scanner, set its options, and open it. It
then retrieves the contents of a single page and closes the scanner. This process
demonstrates using getScannerList(), openScanner(), setOptions(), and
closeScanner(). Note that the contents of the page are retrieved by calling
the pageAsBlob() function from the previous example.
async function scan() {
    let response = await chrome.documentScan.getScannerList({ secure: true });
    let scanner = await chrome.documentScan.openScanner(
        response.scanners[0].scannerId);
    const handle = scanner.scannerHandle;
    let options = [];
    for (source of scanner.options["source"].constraint.list) {
        if (source.includes("ADF")) {
            options.push({
                name: "source",
                type: chrome.documentScan.OptionType.STRING,
                value: { value: source }
            });
            break;
        }
    }
    options.push({
        name: "tl-x",
        type: chrome.documentScan.OptionType.FIXED,
        value: 0.0
    });
    options.push({
        name: "br-x",
        type: chrome.documentScan.OptionType.FIXED,
        value: 215.9  // 8.5" in mm
    });
    options.push({
        name: "tl-y",
        type: chrome.documentScan.OptionType.FIXED,
        value: 0.0
    });
    options.push({
        name: "br-y",
        type: chrome.documentScan.OptionType.FIXED,
        value: 279.4  // 11" in mm
    });
    response = await chrome.documentScan.setOptions(handle, options);
    let imgBlob = await pageAsBlob(handle);
    if (imgBlob != null) {
        // Insert imgBlob into DOM, save to disk, etc
    }
    await chrome.documentScan.closeScanner(handle);
}
Show the configuration
As stated elsewhere, showing a scanner's configuration options to a user requires
calling getOptionGroups() in addition to the scanner options returned from a
call to openScanner(). This is so that options can be shown to users in
manufacturer-defined groups. This example shows how to do that.
async function showConfig() {
  let response = await chrome.documentScan.getScannerList({ secure: true });
  let scanner = await chrome.documentScan.openScanner(
      response.scanners[0].scannerId);
  let groups = await chrome.documentScan.getOptionGroups(scanner.scannerHandle);
  for (const group of groups.groups) {
    console.log("=== " + group.title + " ===");
    for (const member of group.members) {
      const option = scanner.options[member];
      if (option.isActive) {
        console.log("  " + option.name + " = " + option.value);
      } else {
        console.log("  " + option.name + " is inactive");
      }
    }
  }
}
Types
CancelScanResponse
Properties
- 
    jobstring Provides the same job handle that was passed to cancelScan().
- 
    resultThe backend's cancel scan result. If the result is OperationResult.SUCCESSorOperationResult.CANCELLED, the scan has been cancelled and the scanner is ready to start a new scan. If the result isOperationResult.DEVICE_BUSY, the scanner is still processing the requested cancellation; the caller should wait a short time and try the request again. Other result values indicate a permanent error that should not be retried.
CloseScannerResponse
Properties
- 
    resultThe result of closing the scanner. Even if this value is not SUCCESS, the handle will be invalid and should not be used for any further operations.
- 
    scannerHandlestring The same scanner handle as was passed to closeScanner.
Configurability
How an option can be changed.
Enum
"NOT_CONFIGURABLE"  "SOFTWARE_CONFIGURABLE"  "HARDWARE_CONFIGURABLE" 
 The option is read-only.
 The option can be set in software.
 The option can be set by the user toggling or pushing a button on the scanner.
ConnectionType
Indicates how the scanner is connected to the computer.
Enum
"UNSPECIFIED"  "USB"  "NETWORK" 
 
 
 
Enum
"INT_RANGE"  "FIXED_RANGE"  "INT_LIST"  "FIXED_LIST"  "STRING_LIST" 
 The constraint on a range of OptionType.INT values. The min, max, and quant properties of OptionConstraint will be long, and its list propety will be unset.
 The constraint on a range of OptionType.FIXED values. The min, max, and quant properties of OptionConstraint will be double, and its list property will be unset.
 The constraint on a specific list of OptionType.INT values. The OptionConstraint.list property will contain long values, and the other properties will be unset.
 The constraint on a specific list of OptionType.FIXED values. The OptionConstraint.list property will contain double values, and the other properties will be unset.
 The constraint on a specific list of OptionType.STRING values. The OptionConstraint.list property will contain DOMString values, and the other properties will be unset.
DeviceFilter
Properties
- 
    localboolean optional Only return scanners that are directly attached to the computer. 
- 
    secureboolean optional Only return scanners that use a secure transport, such as USB or TLS. 
GetOptionGroupsResponse
Properties
- 
    groupsOptionGroup[] optional If resultisSUCCESS, provides a list of option groups in the order supplied by the scanner driver.
- 
    resultThe result of getting the option groups. If the value of this is SUCCESS, thegroupsproperty will be populated.
- 
    scannerHandlestring The same scanner handle as was passed to getOptionGroups.
GetScannerListResponse
Properties
- 
    resultThe enumeration result. Note that partial results could be returned even if this indicates an error. 
- 
    scannersA possibly-empty list of scanners that match the provided DeviceFilter.
OpenScannerResponse
Properties
- 
    optionsobject optional If resultisSUCCESS, provides a key-value mapping where the key is a device-specific option and the value is an instance ofScannerOption.
- 
    resultThe result of opening the scanner. If the value of this is SUCCESS, thescannerHandleandoptionsproperties will be populated.
- 
    scannerHandlestring optional If resultisSUCCESS, a handle to the scanner that can be used for further operations.
- 
    scannerIdstring The scanner ID passed to openScanner().
OperationResult
An enum that indicates the result of each operation.
Enum
"UNKNOWN"  "SUCCESS"  "UNSUPPORTED"  "CANCELLED"  "DEVICE_BUSY"  "INVALID"  "WRONG_TYPE"  "EOF"  "ADF_JAMMED"  "ADF_EMPTY"  "COVER_OPEN"  "IO_ERROR"  "ACCESS_DENIED"  "NO_MEMORY"  "UNREACHABLE"  "MISSING"  "INTERNAL_ERROR" 
 An unknown or generic failure occurred.
 The operation succeeded.
 The operation is not supported.
 The operation was cancelled.
 The device is busy.
 Either the data or an argument passed to the method is not valid.
 The supplied value is the wrong data type for the underlying option.
 No more data is available.
 The document feeder is jammed.
 The document feeder is empty.
 The flatbed cover is open.
 An error occurred while communicating with the device.
 The device requires authentication.
 Not enough memory is available on the Chromebook to complete the operation.
 The device is not reachable.
 The device is disconnected.
 An error has occurred somewhere other than the calling application.
OptionConstraint
Properties
- 
    liststring[] | number[] optional 
- 
    maxnumber optional 
- 
    minnumber optional 
- 
    quantnumber optional 
- 
    type
OptionGroup
Properties
- 
    membersstring[] An array of option names in driver-provided order. 
- 
    titlestring Provides a printable title, for example "Geometry options". 
OptionSetting
Properties
- 
    namestring Indicates the name of the option to set. 
- 
    typeIndicates the data type of the option. The requested data type must match the real data type of the underlying option. 
- 
    valuestring | number | boolean | number[] optional Indicates the value to set. Leave unset to request automatic setting for options that have autoSettableenabled. The data type supplied forvaluemust matchtype.
OptionType
The data type of an option.
Enum
"UNKNOWN"  "BOOL"  "INT"  "FIXED"  "STRING"  "BUTTON"  "GROUP" 
 The option's data type is unknown. The value property will be unset.
 The value property will be one of truefalse.
 A signed 32-bit integer. The value property will be long or long[], depending on whether the option takes more than one value.
 A double in the range -32768-32767.9999 with a resolution of 1/65535. The value property will be double or double[] depending on whether the option takes more than one value. Double values that can't be exactly represented will be rounded to the available range and precision.
 A sequence of any bytes except NUL ('\0'). The value property will be a DOMString.
 An option of this type has no value. Instead, setting an option of this type causes an option-specific side effect in the scanner driver. For example, a button-typed option could be used by a scanner driver to provide a means to select default values or to tell an automatic document feeder to advance to the next sheet of paper.
 Grouping option. No value. This is included for compatibility, but will not normally be returned in ScannerOption values. Use getOptionGroups() to retrieve the list of groups with their member options.
Enum
"UNITLESS"  "PIXEL"  "BIT"  "MM"  "DPI"  "PERCENT"  "MICROSECOND" 
 The value is a unitless number. For example, it can be a threshold.
 The value is a number of pixels, for example, scan dimensions.
 The value is the number of bits, for example, color depth.
 The value is measured in millimeters, for example, scan dimensions.
 The value is measured in dots per inch, for example, resolution.
 The value is a percent, for example, brightness.
 The value is measured in microseconds, for example, exposure time.
ReadScanDataResponse
Properties
- 
    dataArrayBuffer optional If resultisSUCCESS, contains the next chunk of scanned image data. IfresultisEOF, contains the last chunk of scanned image data.
- 
    estimatedCompletionnumber optional If resultisSUCCESS, an estimate of how much of the total scan data has been delivered so far, in the range 0 to 100.
- 
    jobstring Provides the job handle passed to readScanData().
- 
    resultThe result of reading data. If its value is SUCCESS, thendatacontains the next (possibly zero-length) chunk of image data that is ready for reading. If its value isEOF, thedatacontains the last chunk of image data.
ScannerInfo
Properties
- 
    connectionTypeIndicates how the scanner is connected to the computer. 
- 
    deviceUuidstring For matching against other ScannerInfoentries that point to the same physical device.
- 
    imageFormatsstring[] An array of MIME types that can be requested for returned scans. 
- 
    manufacturerstring The scanner manufacturer. 
- 
    modelstring The scanner model if it is available, or a generic description. 
- 
    namestring A human-readable name for the scanner to display in the UI. 
- 
    protocolTypestring A human-readable description of the protocol or driver used to access the scanner, such as Mopria, WSD, or epsonds. This is primarily useful for allowing a user to choose between protocols if a device supports multiple protocols. 
- 
    scannerIdstring The ID of a specific scanner. 
- 
    secureboolean If true, the scanner connection's transport cannot be intercepted by a passive listener, such as TLS or USB. 
ScannerOption
Properties
- 
    configurabilityIndicates whether and how the option can be changed. 
- 
    constraintOptionConstraint optional Defines OptionConstrainton the current scanner option.
- 
    descriptionstring A longer description of the option. 
- 
    isActiveboolean Indicates the option is active and can be set or retrieved. If false, the valueproperty will not be set.
- 
    isAdvancedboolean Indicates that the UI should not display this option by default. 
- 
    isAutoSettableboolean Can be automatically set by the scanner driver. 
- 
    isDetectableboolean Indicates that this option can be detected from software. 
- 
    isEmulatedboolean Emulated by the scanner driver if true. 
- 
    namestring The option name using lowercase ASCII letters, numbers, and dashes. Diacritics are not allowed. 
- 
    titlestring A printable one-line title. 
- 
    typeThe data type contained in the valueproperty, which is needed for setting this option.
- 
    unitThe unit of measurement for this option. 
- 
    valuestring | number | boolean | number[] optional The current value of the option, if relevant. Note that the data type of this property must match the data type specified in type.
ScanOptions
Properties
- 
    maxImagesnumber optional The number of scanned images allowed. The default is 1. 
- 
    mimeTypesstring[] optional The MIME types that are accepted by the caller. 
ScanResults
Properties
- 
    dataUrlsstring[] An array of data image URLs in a form that can be passed as the "src" value to an image tag. 
- 
    mimeTypestring The MIME type of the dataUrls.
SetOptionResult
Properties
- 
    namestring Indicates the name of the option that was set. 
- 
    resultIndicates the result of setting the option. 
SetOptionsResponse
Properties
- 
    optionsobject optional An updated key-value mapping from option names to ScannerOptionvalues containing the new configuration after attempting to set all supplied options. This has the same structure as theoptionsproperty inOpenScannerResponse.This property will be set even if some options were not set successfully, but will be unset if retrieving the updated configuration fails (for example, if the scanner is disconnected in the middle of scanning). 
- 
    resultsAn array of results, one each for every passed-in OptionSetting.
- 
    scannerHandlestring Provides the scanner handle passed to setOptions().
StartScanOptions
Properties
- 
    formatstring Specifies the MIME type to return scanned data in. 
- 
    maxReadSizenumber optional If a non-zero value is specified, limits the maximum scanned bytes returned in a single readScanDataresponse to that value. The smallest allowed value is 32768 (32 KB). If this property is not specified, the size of a returned chunk may be as large as the entire scanned image.
StartScanResponse
Properties
- 
    jobstring optional If resultisSUCCESS, provides a handle that can be used to read scan data or cancel the job.
- 
    resultThe result of starting a scan. If the value of this is SUCCESS, thejobproperty will be populated.
- 
    scannerHandlestring Provides the same scanner handle that was passed to startScan().
Methods
cancelScan()
chrome.documentScan.cancelScan(
job: string,
): Promise<CancelScanResponse>
Cancels a started scan and returns a Promise that resolves with a CancelScanResponse object. If a callback is used, the object is passed to it instead.
Parameters
- 
    jobstring The handle of an active scan job previously returned from a call to startScan.
Returns
- 
            Promise<CancelScanResponse> 
closeScanner()
chrome.documentScan.closeScanner(
scannerHandle: string,
): Promise<CloseScannerResponse>
Closes the scanner with the passed in handle and returns a Promise that resolves with a CloseScannerResponse object. If a callback is used, the object is passed to it instead. Even if the response is not a success, the supplied handle becomes invalid and should not be used for further operations.
Parameters
- 
    scannerHandlestring Specifies the handle of an open scanner that was previously returned from a call to openScanner.
Returns
- 
            Promise<CloseScannerResponse> 
getOptionGroups()
chrome.documentScan.getOptionGroups(
scannerHandle: string,
): Promise<GetOptionGroupsResponse>
Gets the group names and member options from a scanner previously opened by openScanner. This method returns a Promise that resolves with a GetOptionGroupsResponse object. If a callback is passed to this function, returned data is passed to it instead.
Parameters
- 
    scannerHandlestring The handle of an open scanner returned from a call to openScanner.
Returns
- 
            Promise<GetOptionGroupsResponse> 
getScannerList()
chrome.documentScan.getScannerList(
filter: DeviceFilter,
): Promise<GetScannerListResponse>
Gets the list of available scanners and returns a Promise that resolves with a GetScannerListResponse object. If a callback is passed to this function, returned data is passed to it instead.
Parameters
- 
    filterA DeviceFilterindicating which types of scanners should be returned.
Returns
- 
            Promise<GetScannerListResponse> 
openScanner()
chrome.documentScan.openScanner(
scannerId: string,
): Promise<OpenScannerResponse>
Opens a scanner for exclusive access and returns a Promise that resolves with an OpenScannerResponse object. If a callback is passed to this function, returned data is passed to it instead.
Parameters
- 
    scannerIdstring The ID of a scanner to be opened. This value is one returned from a previous call to getScannerList.
Returns
- 
            Promise<OpenScannerResponse> 
readScanData()
chrome.documentScan.readScanData(
job: string,
): Promise<ReadScanDataResponse>
Reads the next chunk of available image data from an active job handle, and returns a Promise that resolves with a ReadScanDataResponse object. If a callback is used, the object is passed to it instead.
**Note:**It is valid for a response result to be SUCCESS with a zero-length data member. This means the scanner is still working but does not yet have additional data ready. The caller should wait a short time and try again.
When the scan job completes, the response will have the result value of EOF. This response may contain a final non-zero data member.
Parameters
- 
    jobstring Active job handle previously returned from startScan.
Returns
- 
            Promise<ReadScanDataResponse> 
scan()
chrome.documentScan.scan(
options: ScanOptions,
): Promise<ScanResults>
Performs a document scan and returns a Promise that resolves with a ScanResults object. If a callback is passed to this function, the returned data is passed to it instead.
Parameters
- 
    optionsAn object containing scan parameters. 
Returns
- 
            Promise<ScanResults> Chrome 96+
setOptions()
chrome.documentScan.setOptions(
scannerHandle: string,
options: OptionSetting[],
): Promise<SetOptionsResponse>
Sets options on the specified scanner and returns a Promise that resolves with a SetOptionsResponse object containing the result of trying to set every value in the order of the passed-in OptionSetting object. If a callback is used, the object is passed to it instead.
Parameters
- 
    scannerHandlestring The handle of the scanner to set options on. This should be a value previously returned from a call to openScanner.
- 
    optionsA list of OptionSettingobjects to be applied to the scanner.
Returns
- 
            Promise<SetOptionsResponse> 
startScan()
chrome.documentScan.startScan(
scannerHandle: string,
options: StartScanOptions,
): Promise<StartScanResponse>
Starts a scan on the specified scanner and returns a Promise that resolves with a StartScanResponse. If a callback is used, the object is passed to it instead. If the call was successful, the response includes a job handle that can be used in subsequent calls to read scan data or cancel a scan.
Parameters
- 
    scannerHandlestring The handle of an open scanner. This should be a value previously returned from a call to openScanner.
- 
    optionsA StartScanOptionsobject indicating the options to be used for the scan. TheStartScanOptions.formatproperty must match one of the entries returned in the scanner'sScannerInfo.
Returns
- 
            Promise<StartScanResponse>