zotero-connectors

Chrome, Firefox, and Safari extensions for Zotero

  • 所有者: zotero/zotero-connectors
  • 平台:
  • 許可證: Other
  • 分類:
  • 主題:
  • 喜歡:
    0
      比較:

Github星跟蹤圖

Zotero Connectors

Build Status

Building

  1. git clone --recursive https://github.com/zotero/zotero-connectors.git
  2. cd zotero-connectors
  3. npm install
  4. ./build.sh -d

The connectors are built in build/.

Running from the build directory

Chrome

  1. Go to chrome://extensions/
  2. Enable "Developer Mode".
  3. Click "Load unpacked extension…" and select the build/browserExt directory.

Firefox

  1. Go to about:debugging
  2. Click "Load Temporary Add-on" and select the build/browserExt/manifest.json file.

OR

  1. Get and install the Mozilla web-ext tool
  2. cd to project root
  3. ./scripts/firefox/run_xpi

Safari

See https://github.com/zotero/safari-app-extension

Automatic rebuilding/reloading

Chrome on MacOS

  1. brew install chrome-cli
  2. npm install -g gulp
  3. cd to project root
  4. npm install
  5. build.sh -d
  6. gulp watch-chrome

As files are changed, the connectors will be rebuilt automatically and Chrome will reload the extension.

Firefox

  1. Get and install the Mozilla web-ext tool
  2. cd to project root
  3. npm install
  4. build.sh -d
  5. gulp watch
  6. ./scripts/firefox/run_xpi (in a different terminal window)

As files are changed, the connectors will be rebuilt automatically and Firefox will reload the extension.

Others

  1. cd to project root
  2. npm install
  3. build.sh -d
  4. gulp watch

As files are changed, the connectors will be rebuilt automatically. You will need to manually reload the extension
in the browser being developed for.

Requirements for packaging extensions from the command line

Tests

To run tests locally, build the extension with the -d flag, and then run

$ ./test/run_tests -p c

Test files are located at src/common/test. See src/common/test/testSetup.js for
test framework documentation

Developing

Zotero Connectors are built with standard tools, such as browser extension APIs, but the architecture is quite complex.
This section is a short overview of some of the complexities, to make it more accessible for newcomers.

Technologies

Chrome/Firefox Browser Extension Framework

The functionality exposed on Chrome and Firefox is provided by the Chrome extension framework,
which has also been adopted by Firefox. See Chrome Extension docs
and Firefox Extension docs for more information.

Safari Extension Framework

For Safari specifics see https://github.com/zotero/safari-app-extension

Zotero Translator Framework

The Connectors share code with Zotero desktop application, to support translation.
A basic understanding of how translation works or at least the handlers it exposes in Zotero will be highly useful in
understanding the codebase.

Components

Saving resources to Zotero library is facilitated by two major components: the Zotero Connector running in the browser
and either the Zotero client or zotero.org web api. The Zotero Connector itself is split into two components:
code running on the webpage and a background process.

a) Injected scripts for individual webpages

Each webpage is injected (Chrome/Firefox/Safari)
with a full Zotero translation framework.
A Zotero.Translate.Web
instance orchestrates running individual translators for detection and translation.

The translation framework shares some code with the Zotero codebase and provides custom classes concerning
translator retrieval
and item saving.
These custom classes talk to the background process (b) of the Zotero Connector for functionality outside the translation
framework, such as retrieving translator code and sending translated items either to Zotero (c) or zotero.org (d).

b) Background process

The Connector runs a background process
(Chrome/Firefox/Safari)
which works as a middle-layer between the translation framework running in inject scripts (a) and Zotero (c) or zotero.org (d).

The background process maintains a cache of translators and performs the initial translator detection using URL matching.
Translators whose target regexp matches the URL of a given webpage are then further tested by running detectWeb()
in injected scripts. A list of translators and their code is
fetched either from Zotero (c) or zotero.org (d).

The background process is also responsible for updating the extension UI, kicking off translations, storing and
retrieving connector preferences and sending translated items to Zotero or zotero.org. Browser specific scripts are
available for BrowserExt
and Safari.

c) Connector server in Zotero

When Zotero is open it runs a connector HTTP server
on port 23119. The HTTP server API accommodates interactions between the Connectors and Zotero client. Calls to
Zotero.Connector.callMethod(endpoint)
in this codebase are translated to HTTP requests to the connector server.

Note that Zotero cannot interact with the connectors on its own accord. All communication is Connector initiated.

d) zotero.org API

When Zotero is not available item saving falls back to
using zotero.org API.
The interactions with zotero.org API are defined in api.js

Message passing

The only way for the background extension process and injected scripts to communicate is using the message passing
protocol provided by the browsers (Chrome/Firefox/Safari).
Injected scripts often need to communicate to background scripts. To simplify
these interactions, calls to functions in background scripts are monkey-patched in injected scripts. These calls are
asynchronous and if a return value is required, it is provided either to a callback function as the last argument of
the call or as a resolving value of a promise returned.

messages.js
contains the list of the monkey-patched methods. If the method value is false no response is expected, otherwise
the calls provide a response. An optional pre-send processing on the background end and post-receive processing
on the injected end is possible to treat values that cannot be sent as-is via the messaging protocol.

The background process registers message listeners in messaging.js.
Zotero.Messaging class also provides a way to send messages to injected scripts and add custom message listeners.

The injected scripts monkey-patch methods in messaging_injected.js(BrowserExt/Safari)
Zotero.Messaging class also provides a way to send messages to the background process and add message listeners.

Build process

The build process combines files from the Zotero codebase, common files to all connectors and specific files for
Chrome/Firefox/Safari connectors. At the moment the build process is awkward and uses a SH script and gulp procedures.
This will be reconciled in the future to only use gulp.

  1. build.sh copies images
    and extension files
  2. gulp process-custom-files initiated by
    build.sh performs post-processing
    on copied files

Contact

If you have any questions about developing Zotero Connectors you can join the discussion in the
zotero-dev mailing list.

主要指標

概覽
名稱與所有者zotero/zotero-connectors
主編程語言JavaScript
編程語言HTML (語言數: 5)
平台
許可證Other
所有者活动
創建於2011-08-18 19:48:21
推送於2025-06-09 09:28:04
最后一次提交2024-04-29 14:26:19
發布數168
最新版本名稱5.0.167 (發布於 2025-06-04 02:32:13)
第一版名稱3.0b1 (發布於 2012-01-22 12:41:31)
用户参与
星數601
關注者數22
派生數136
提交數1.6k
已啟用問題?
問題數424
打開的問題數96
拉請求數56
打開的拉請求數10
關閉的拉請求數51
项目设置
已啟用Wiki?
已存檔?
是復刻?
已鎖定?
是鏡像?
是私有?