Assistive Technology Service Provider Interface Explained

AT-SPI
License:GNU LGPL (version 2)[1]

Assistive Technology Service Provider Interface (AT-SPI) is a platform-neutral framework for providing bi-directional communication between assistive technologies (AT) and applications.[2] It is the de facto standard for providing accessibility to free and open desktops, like Linux or OpenBSD, led by the GNOME Project.

One common nomenclature to explain an accessibility framework is a usual client-server architecture. In that way, Assistive Technologies (ATs), such as screen readers, would be the clients of that framework, and computer applications would be the server. In this architecture, client and server need to communicate with each other, usually using the IPC technology of the platform. Ideally the accessibility framework exposes this to the client and server in a transparent way.

Usually the API for both client-side and server-side applications are the same, and the accessibility framework provides a client-side and a server-side implementation of that API. In the case of GNOME, there are two different APIs, one for the client-side (AT-SPI) and a different one for the server-side (Accessibility Toolkit (ATK)) due to historical reasons related to the underlying technologies.[3]

Implementations

AT-SPI was originally designed for using Common Object Request Broker Architecture, an object-based IPC/RPC technology, for its transport protocol. The AT-SPI specification itself was tied to CORBA as it was defined in CORBA IDL. AT-SPI used the GNOME project's own fast and lightweight CORBA implementation, ORBit, and its own framework for creating CORBA components, Bonobo.[4]

The GNOME project decided that the 3.0 release would be free of ORBit and Bonobo, meaning that a D-Bus AT-SPI solution was required.[5] [6] In an effort to move AT-SPI forward, a D-Bus project was started in November 2006. This took the form of a performance and design review available on the GNOME wiki. Work began on the implementation in May 2007.[7] The D-Bus version of AT-SPI, AT-SPI version 2, was released along with GNOME 3.0 in April 2011.[8] [9]

Support

AT-SPI provides an ATK bridge, so all the widget systems or applications that implement ATK will automatically communicate all their events to AT-SPI. The GNOME widget system, GTK+, or Mozilla applications like Firefox and Thunderbird for Linux implement ATK, so they communicate out-of-box with AT-SPI. However, it is completely possible to use AT-SPI without implementing ATK. The D-Bus migration made possible that Qt added AT-SPI support. Qt implemented its own bridge to AT-SPI that was released in alpha status in August 2011 for testing purposes[10] and it was integrated into Qt for general use a year later.[11]

Development

AT/SPI is part of the GNOME Accessibility Framework that was released in 2001. The main development force behind ATK was the Accessibility Program Office (APO) of Sun Microsystems, Inc. (now Oracle) with contributions from many community members. When Oracle acquired Sun in 2010 they cut developer jobs of full-time developers working on GNOME accessibility components like the Accessibility Toolkit ATK and the Orca screen reader. Since then, it is mainly maintained by the GNOME community.

Maintainers

ATK development has been led by their maintainers with the help of its community. The maintainers so far are:[12]

Current:

Previous:

Other uses

AT-SPI can also be used for automated testing of user interfaces, with tools such as Linux Desktop Testing Project and Dogtail.[13]

Licensing

AT-SPI is released under the GNU Library General Public License (LGPL) version 2.

See also

References

  1. Web site: AT-SPI git source code repository, COPYING file . 2014-04-10 .
  2. Web site: ATK/AT-SPI SIG Overview. 2014-04-10. 2014-04-13. https://web.archive.org/web/20140413132602/http://www.linuxfoundation.org/collaborate/workgroups/accessibility/atk/at-spi/overview. dead.
  3. Web site: Sánchez Prada. Mario. Accessibility in [WebKit]GTK+]. February 3, 2013. 2014-04-10.
  4. Web site: Orca Documentation Series. 2014-04-10. 2014-04-13. https://web.archive.org/web/20140413132918/http://www.mit.edu/~rjc/orca-docs.html. dead.
  5. Web site: Planning for GNOME 3.0. 2014-04-10.
  6. Web site: GNOME 3 Porting Guide. 2014-04-10.
  7. Web site: Accessibility/ATK/AT-SPI/AT-SPI on D-Bus. 2014-04-10.
  8. Web site: GNOME 3.0 released: better for users, developers. 2014-04-10.
  9. Web site: Git source code released with GNOME 3.0. 2014-04-10.
  10. Web site: Accessibility on Linux. 2014-04-10. https://web.archive.org/web/20140707193743/http://blog.qt.digia.com/blog/2011/08/23/accessibility-on-linux/. 2014-07-07. dead.
  11. Web site: Qt accessibility APIs. 2014-04-10. https://web.archive.org/web/20140707201604/http://blog.qt.digia.com/blog/2012/06/18/qt-5-accessibility-apis/. 2014-07-07. dead.
  12. Web site: AT-SPI's Maintainers file . 2014-03-30 .
  13. Web site: ATK/AT-SPI Special Interest Group . 2020-11-26 .

External links