rpaframework


Namerpaframework JSON
Version 29.0.0 PyPI version JSON
download
home_pagehttps://rpaframework.org/
SummaryA collection of tools and libraries for RPA
upload_time2024-12-08 10:39:25
maintainerNone
docs_urlNone
authorRPA Framework
requires_python<4.0,>=3.9
licenseApache-2.0
keywords robotframework rpa automation
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            RPA Framework
=============

REQUEST for user input!
-----------------------

We are looking at improving our keyword usage to cover situations where developer might be
struggling to smoothly write task for a Robot. Describe the situation where your **implementation speed slows** due to the lack of easier syntax.

`Comment HERE <https://github.com/robocorp/rpaframework/issues/738>`_

.. contents:: Table of Contents
   :local:
   :depth: 1


.. include-docs-readme

Introduction
------------

`RPA Framework` is a collection of open-source libraries and tools for
Robotic Process Automation (RPA), and it is designed to be used with both
`Robot Framework`_ and `Python`_. The goal is to offer well-documented and
actively maintained core libraries for Software Robot Developers.

Learn more about RPA at `Robocorp Documentation`_.

**The project is:**

- 100% Open Source
- Sponsored by Robocorp_
- Optimized for Robocorp `Control Room`_ and `Developer Tools`_
- Accepting external contributions

.. _Robot Framework: https://robotframework.org
.. _Robot Framework Foundation: https://robotframework.org/foundation/
.. _Python: https://www.python.org/
.. _Robocorp: https://robocorp.com
.. _Robocorp Documentation: https://robocorp.com/docs-robot-framework
.. _Control Room: https://robocorp.com/docs/control-room
.. _Developer Tools: https://robocorp.com/downloads
.. _Installing Python Packages: https://robocorp.com/docs/setup/installing-python-package-dependencies

Links
^^^^^

- Homepage: `<https://www.github.com/robocorp/rpaframework/>`_
- Documentation: `<https://rpaframework.org/>`_
- PyPI: `<https://pypi.org/project/rpaframework/>`_
- Release notes: `<https://rpaframework.org/releasenotes.html>`_
- RSS feed: `<https://rpaframework.org/releases.xml>`_

------------

.. image:: https://img.shields.io/github/actions/workflow/status/robocorp/rpaframework/main.yaml?style=for-the-badge
   :target: https://github.com/robocorp/rpaframework/actions/workflows/main.yaml
   :alt: Status

.. image:: https://img.shields.io/pypi/dw/rpaframework?style=for-the-badge
   :target: https://pypi.python.org/pypi/rpaframework
   :alt: rpaframework

.. image:: https://img.shields.io/pypi/l/rpaframework.svg?style=for-the-badge&color=brightgreen
   :target: http://www.apache.org/licenses/LICENSE-2.0.html
   :alt: License

------------


Packages
--------

.. image:: https://img.shields.io/pypi/v/rpaframework.svg?label=rpaframework&style=for-the-badge
   :target: https://pypi.python.org/pypi/rpaframework
   :alt: rpaframework latest version

.. image:: https://img.shields.io/pypi/v/rpaframework-assistant.svg?label=rpaframework-assistant&style=for-the-badge
   :target: https://pypi.python.org/pypi/rpaframework-assistant
   :alt: rpaframework-assistant latest version

.. image:: https://img.shields.io/pypi/v/rpaframework-aws.svg?label=rpaframework-aws&style=for-the-badge
   :target: https://pypi.python.org/pypi/rpaframework-aws
   :alt: rpaframework-aws latest version

.. image:: https://img.shields.io/pypi/v/rpaframework-core.svg?label=rpaframework-core&style=for-the-badge
   :target: https://pypi.python.org/pypi/rpaframework-core
   :alt: rpaframework-core latest version

.. image:: https://img.shields.io/pypi/v/rpaframework-google.svg?label=rpaframework-google&style=for-the-badge&color=blue
   :target: https://pypi.python.org/pypi/rpaframework-google
   :alt: rpaframework-google latest version

.. image:: https://img.shields.io/pypi/v/rpaframework-hubspot.svg?label=rpaframework-hubspot&style=for-the-badge&color=blue
   :target: https://pypi.python.org/pypi/rpaframework-hubspot
   :alt: rpaframework-hubspot latest version

.. image:: https://img.shields.io/pypi/v/rpaframework-openai.svg?label=rpaframework-openai&style=for-the-badge&color=blue
   :target: https://pypi.python.org/pypi/rpaframework-openai
   :alt: rpaframework-openai latest version

.. image:: https://img.shields.io/pypi/v/rpaframework-pdf.svg?label=rpaframework-pdf&style=for-the-badge&color=blue
   :target: https://pypi.python.org/pypi/rpaframework-pdf
   :alt: rpaframework-pdf latest version

.. image:: https://img.shields.io/pypi/v/rpaframework-recognition.svg?label=rpaframework-recognition&style=for-the-badge&color=blue
   :target: https://pypi.python.org/pypi/rpaframework-recognition
   :alt: rpaframework-recognition latest version

.. image:: https://img.shields.io/pypi/v/rpaframework-windows.svg?label=rpaframework-windows&style=for-the-badge&color=blue
   :target: https://pypi.python.org/pypi/rpaframework-windows
   :alt: rpaframework-windows latest version

----

From the above packages, ``rpaframework-core`` and ``rpaframework-recognition`` are
support packages, which alone do **not** contain any libraries.


Libraries
---------

The RPA Framework project currently includes the following libraries:

The ``x`` in the **PACKAGE** column means that library **is** included in the **rpaframework** package and for example. ``x,pdf`` means that ``RPA.PDF`` library is provided in both the **rpaframework** and **rpaframework-pdf** packages.

+----------------------------+-------------------------------------------------------+------------------------+
| **LIBRARY NAME**           | **DESCRIPTION**                                       | **PACKAGE**            |
+----------------------------+-------------------------------------------------------+------------------------+
| `Archive`_                 | Archiving TAR and ZIP files                           | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `Assistant`_               | Display information to a user and request input.      | assistant              |
+----------------------------+-------------------------------------------------------+------------------------+
| `Browser.Selenium`_        | Control browsers and automate the web                 | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `Browser.Playwright`_      | Newer way to control browsers                         | special (more below)   |
+----------------------------+-------------------------------------------------------+------------------------+
| `Calendar`_                | For date and time manipulations                       | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `Cloud.AWS`_               | Use Amazon AWS services                               | x,aws                  |
+----------------------------+-------------------------------------------------------+------------------------+
| `Cloud.Azure`_             | Use Microsoft Azure services                          | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `Cloud.Google`_            | Use Google Cloud services                             | google                 |
+----------------------------+-------------------------------------------------------+------------------------+
| `Crypto`_                  | Common hashing and encryption operations              | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `Database`_                | Interact with databases                               | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `Desktop`_                 | Cross-platform desktop automation                     | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `Desktop.Clipboard`_       | Interact with the system clipboard                    | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `Desktop.OperatingSystem`_ | Read OS information and manipulate processes          | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `DocumentAI`_              | Intelligent Document Processing wrapper               | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `DocumentAI.Base64AI`_     | Intelligent Document Processing service               | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `DocumentAI.Nanonets`_     | Intelligent Document Processing service               | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `Email.Exchange`_          | E-Mail operations (Exchange protocol)                 | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `Email.ImapSmtp`_          | E-Mail operations (IMAP & SMTP)                       | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `Excel.Application`_       | Control the Excel desktop application                 | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `Excel.Files`_             | Manipulate Excel files directly                       | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `FileSystem`_              | Read and manipulate files and paths                   | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `FTP`_                     | Interact with FTP servers                             | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `HTTP`_                    | Interact directly with web APIs                       | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `Hubspot`_                 | Access HubSpot CRM data objects                       | hubspot                |
+----------------------------+-------------------------------------------------------+------------------------+
| `Images`_                  | Manipulate images                                     | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `JavaAccessBridge`_        | Control Java applications                             | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `JSON`_                    | Manipulate JSON objects                               | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `MFA`_                     | Authenticate using one-time passwords (OTP) & OAuth2  | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `Notifier`_                | Notify messages using different services              | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `OpenAI`_                  | Artificial Intelligence service                       | openai                 |
+----------------------------+-------------------------------------------------------+------------------------+
| `Outlook.Application`_     | Control the Outlook desktop application               | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `PDF`_                     | Read and create PDF documents                         | x,pdf                  |
+----------------------------+-------------------------------------------------------+------------------------+
| `Robocorp.Process`_        | Use the Robocorp Process API                          | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `Robocorp.WorkItems`_      | Use the Robocorp Work Items API                       | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `Robocorp.Vault`_          | Use the Robocorp Secrets API                          | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `Robocorp.Storage`_        | Use the Robocorp Asset Storage API                    | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `Salesforce`_              | Salesforce operations                                 | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `SAP`_                     | Control SAP GUI desktop client                        | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `Smartsheet`_              | Access Smartsheet sheets                              | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `Tables`_                  | Manipulate, sort, and filter tabular data             | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `Tasks`_                   | Control task execution                                | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `Twitter`_                 | Twitter API interface                                 | x                      |
+----------------------------+-------------------------------------------------------+------------------------+
| `Windows`_                 | Alternative library for Windows automation            | x,windows              |
+----------------------------+-------------------------------------------------------+------------------------+
| `Word.Application`_        | Control the Word desktop application                  | x                      |
+----------------------------+-------------------------------------------------------+------------------------+

.. _Archive: https://rpaframework.org/libraries/archive/
.. _Assistant: https://rpaframework.org/libraries/assistant/
.. _Browser.Playwright: https://rpaframework.org/libraries/browser_playwright/
.. _Browser.Selenium: https://rpaframework.org/libraries/browser_selenium/
.. _Calendar: https://rpaframework.org/libraries/calendar/
.. _Cloud.AWS: https://rpaframework.org/libraries/cloud_aws/
.. _Cloud.Azure: https://rpaframework.org/libraries/cloud_azure/
.. _Cloud.Google: https://rpaframework.org/libraries/cloud_google/
.. _Crypto: https://rpaframework.org/libraries/crypto/
.. _Database: https://rpaframework.org/libraries/database/
.. _Desktop: https://rpaframework.org/libraries/desktop/
.. _Desktop.Clipboard: https://rpaframework.org/libraries/desktop_clipboard/
.. _Desktop.Operatingsystem: https://rpaframework.org/libraries/desktop_operatingsystem/
.. _DocumentAI: https://rpaframework.org/libraries/documentai
.. _DocumentAI.Base64AI: https://rpaframework.org/libraries/documentai_base64ai/
.. _DocumentAI.Nanonets: https://rpaframework.org/libraries/documentai_nanonets/
.. _Email.Exchange: https://rpaframework.org/libraries/email_exchange/
.. _Email.ImapSmtp: https://rpaframework.org/libraries/email_imapsmtp/
.. _Excel.Application: https://rpaframework.org/libraries/excel_application/
.. _Excel.Files: https://rpaframework.org/libraries/excel_files/
.. _FileSystem: https://rpaframework.org/libraries/filesystem/
.. _FTP: https://rpaframework.org/libraries/ftp/
.. _HTTP: https://rpaframework.org/libraries/http/
.. _Hubspot: https://rpaframework.org/libraries/hubspot/
.. _Images: https://rpaframework.org/libraries/images/
.. _JavaAccessBridge: https://rpaframework.org/libraries/javaaccessbridge/
.. _JSON: https://rpaframework.org/libraries/json/
.. _MFA: https://rpaframework.org/libraries/mfa/
.. _Notifier: https://rpaframework.org/libraries/notifier/
.. _OpenAI: https://rpaframework.org/libraries/openai/
.. _Outlook.Application: https://rpaframework.org/libraries/outlook_application/
.. _PDF: https://rpaframework.org/libraries/pdf/
.. _Robocorp.Process: https://rpaframework.org/libraries/robocorp_process/
.. _Robocorp.WorkItems: https://rpaframework.org/libraries/robocorp_workitems/
.. _Robocorp.Vault: https://rpaframework.org/libraries/robocorp_vault/
.. _Robocorp.Storage: https://rpaframework.org/libraries/robocorp_storage/
.. _Salesforce: https://rpaframework.org/libraries/salesforce/
.. _SAP: https://rpaframework.org/libraries/sap/
.. _Smartsheet: https://rpaframework.org/libraries/smartsheet/
.. _Tables: https://rpaframework.org/libraries/tables/
.. _Tasks: https://rpaframework.org/libraries/tasks/
.. _Twitter: https://rpaframework.org/libraries/twitter/
.. _Windows: https://rpaframework.org/libraries/windows/
.. _Word.Application: https://rpaframework.org/libraries/word_application/

Installation of RPA.Browser.Playwright
--------------------------------------

The **RPA.Browser.Playwright** at the moment requires special installation, because
of the package size and the post install step it needs to be fully installed.

Minimum required `conda.yaml` to install Playwright:

.. code-block:: yaml

    channels:
      - conda-forge
    dependencies:
      - python=3.10.14
      - nodejs=22.9.0
      - pip=24.0
      - pip:
        - robotframework-browser==18.8.1
        - rpaframework==28.6.3
    rccPostInstall:
      - rfbrowser init

Installation
------------

Learn about installing Python packages at `Installing Python Packages`_.

Default installation method with Robocorp `Developer Tools`_ using `conda.yaml`:

.. code-block:: yaml

   channels:
     - conda-forge
   dependencies:
     - python=3.10.14
     - pip=24.0
     - pip:
       - rpaframework==28.6.3

To install all extra packages (including Playwright dependencies), you can use:

.. code-block:: yaml

   channels:
     - conda-forge
   dependencies:
     - python=3.10.14
     - tesseract=5.4.1
     - nodejs=22.9.0
     - pip=24.0
     - pip:
       - robotframework-browser==18.8.1
       - rpaframework==28.6.3
       - rpaframework-aws==5.3.3
       - rpaframework-google==9.0.2
       - rpaframework-recognition==5.2.5
   rccPostInstall:
     - rfbrowser init

Separate installation of AWS, PDF and Windows libraries without the main
``rpaframework``:

.. code-block:: yaml

   channels:
     - conda-forge
   dependencies:
     - python=3.10.14
     - pip=24.0
     - pip:
       - rpaframework-aws==5.3.3  # included in the rpaframework as an extra
       - rpaframework-pdf==7.3.3  # included in the rpaframework by default
       - rpaframework-windows==7.5.2  # included in the rpaframework by default

Installation method with `pip` using Python `venv`_:

.. code-block:: shell

   python -m venv .venv
   source .venv/bin/activate
   pip install rpaframework


.. note:: Python 3.8 or higher is required

Example
-------

After installation the libraries can be directly imported inside
`Robot Framework`_:

.. code:: robotframework

    *** Settings ***
    Library    RPA.Browser.Selenium

    *** Tasks ***
    Login as user
        Open available browser    https://example.com
        Input text    id:user-name    ${USERNAME}
        Input text    id:password     ${PASSWORD}

The libraries are also available inside Python_:

.. code:: python

    from RPA.Browser.Selenium import Selenium

    lib = Selenium()

    lib.open_available_browser("https://example.com")
    lib.input_text("id:user-name", username)
    lib.input_text("id:password", password)

Support and contact
-------------------

- `rpaframework.org <https://rpaframework.org/>`_ for library documentation
- `Robocorp Documentation`_ for guides and tutorials
- **#rpaframework** channel in `Robot Framework Slack`_ if you
  have open questions or want to contribute
- Communicate with your fellow Software Robot Developers and Robocorp experts
  at `Robocorp Developers Slack`_

.. _Robot Framework Slack: https://robotframework-slack-invite.herokuapp.com/
.. _Robocorp Developers Slack: https://robocorp-developers.slack.com

Contributing
------------

Found a bug? Missing a critical feature? Interested in contributing?
Head over to the `Contribution guide <https://rpaframework.org/contributing/guide.html>`_
to see where to get started.

Development
-----------

Repository development is `Python`_ based and requires at minimum
Python version 3.8+ installed on the development machine. The default Python version used in the
Robocorp Robot template is 3.10.14 so it is a good choice for the version to install. Not recommended
versions are 3.7.6 and 3.8.1, because they have issues with some of the dependencies related to ``rpaframework``.
At the time the newer Python versions starting from 3.12 are also not recommended, because some of
the dependencies might cause issues.

Repository development tooling is based on `poetry`_ and `invoke`_. Poetry is the
underlying tool used for compiling, building and running the package. Invoke is used
for scripting purposes, for example for linting, testing and publishing tasks.

Before writing any code, please read and acknowledge our extensive `Dev Guide`_.

.. _Dev Guide: https://github.com/robocorp/rpaframework/blob/master/docs/source/contributing/development.md

First steps to start developing:

1. initial poetry configuration

.. code:: shell

   poetry config virtualenvs.path null
   poetry config virtualenvs.in-project true
   poetry config repositories.devpi "https://devpi.robocorp.cloud/ci/test"

2. git clone the repository
#. create a new Git branch or switch to correct branch or stay in master branch

   - some branch naming conventions **feature/name-of-feature**, **hotfix/name-of-the-issue**, **release/number-of-release**

#. ``poetry install`` which install package with its dependencies into the **.venv** directory of the package, for example **packages/main/.venv**
#. if testing against Robocorp Robot which is using **devdata/env.json**

   - set environment variables
   - or ``poetry build`` and use resulting .whl file (in the **dist/** directory) in the Robot **conda.yaml**
   - or ``poetry build`` and push resulting .whl file  (in the **dist/** directory) into a repository and use raw url
     to include it in the Robot **conda.yaml**
   - another possibility for Robocorp internal development is to use Robocorp **devpi** instance, by ``poetry publish --ci``
     and point **conda.yaml** to use rpaframework version in devpi

#. ``poetry run python -m robot <ROBOT_ARGS> <TARGET_ROBOT_FILE>``

   - common *ROBOT_ARGS* from Robocorp Robot template: ``--report NONE --outputdir output --logtitle "Task log"``

#. ``poetry run python <TARGET_PYTHON_FILE>``
#. ``invoke lint`` to make sure that code formatting is according to **rpaframework** repository guidelines.
   It is possible and likely that Github action will fail the if developer has not linted the code changes. Code
   formatting is based on `black`_ and `flake8`_ and those are run with the ``invoke lint``.
#. the library documentation can be created in the repository root (so called "meta" package level). The documentation is
   built by the docgen tools using the locally installed version of the project, local changes for the main package
   will be reflected each time you generate the docs, but if you want to see local changes for optional packages, you must
   utilize ``invoke install-local --package <package_name>`` using the appropriate package name (e.g., ``rpaframework-aws``). This
   will reinstall that package as a local editable version instead of from PyPI. Multiple such packages can be added by
   repeating the use of the ``--package`` option. In order to reset this, use ``invoke install --reset``.

   - ``poetry update`` and/or ``invoke install-local --package <package name>``
   - ``make docs``
   - open ``docs/build/html/index.html`` with the browser to view the changes or execute ``make local`` and navigate to
     ``localhost:8000`` to view docs as a live local webpage.

   .. code-block:: toml

      # Before
      [tool.poetry.dependencies]
      python = "^3.8"
      rpaframework = { path = "packages/main", extras = ["cv", "playwright", "aws"] }
      rpaframework-google = "^4.0.0"
      rpaframework-windows = "^4.0.0"

      # After
      [tool.poetry.dependencies]
      python = "^3.8"
      rpaframework = { path = "packages/main", extras = ["cv", "playwright"] }
      rpaframework-aws = { path = "packages/aws" }
      rpaframework-google = "^4.0.0"
      rpaframework-windows = "^4.0.0"

#. ``invoke test`` (this will run both Python unittests and robotframework tests defined in the packages **tests/ directory**)

   - to run specific Python test: ``poetry run pytest path/to/test.py::test_function``
   - to run specific Robotframework test: ``inv testrobot -r <robot_name> -t <task_name>``

#. git commit changes
#. git push changes to remote
#. create pull request from the branch describing changes included in the description
#. update **docs/source/releasenotes.rst** with changes (commit and push)

Packaging and publishing are done after changes have been merged into master branch.
All the following steps should be done within master branch.

#. git pull latest changes into master branch
#. in the package directory containing changes execute ``invoke lint`` and ``invoke test``
#. update **pyproject.toml** with new version according to semantic versioning
#. update **docs/source/releasenotes.rst** with changes
#. in the repository root (so called "meta" package level) run command ``poetry update``
#. git commit changed **poetry.lock** files (on meta and target package level), **releasenotes.rst**
   and **pyproject.toml** with message "PACKAGE. version x.y.z"
#. git push
#. ``invoke publish`` after Github action on master branch is all green

Some recommended tools for development

- `Visual Studio Code`_ as a code editor with following extensions:

   - `Sema4.ai`_
   - `Robot Framework Language Server`_
   - `GitLens`_
   - `Python extension`_

- `GitHub Desktop`_ will make version management less prone to errors

.. _poetry: https://python-poetry.org
.. _invoke: https://www.pyinvoke.org
.. _Visual Studio Code: https://code.visualstudio.com
.. _GitHub Desktop: https://desktop.github.com
.. _Sema4.ai: https://marketplace.visualstudio.com/items?itemName=sema4ai.sema4ai
.. _Robot Framework Language Server: https://marketplace.visualstudio.com/items?itemName=robocorp.robotframework-lsp
.. _GitLens: https://marketplace.visualstudio.com/items?itemName=eamodio.gitlens
.. _Python extension: https://marketplace.visualstudio.com/items?itemName=ms-python.python
.. _black: https://pypi.org/project/black/
.. _flake8: https://pypi.org/project/flake8/
.. _venv: https://docs.python.org/3/library/venv.html

License
-------

This project is open-source and licensed under the terms of the
`Apache License 2.0 <http://apache.org/licenses/LICENSE-2.0>`_.

            

Raw data

            {
    "_id": null,
    "home_page": "https://rpaframework.org/",
    "name": "rpaframework",
    "maintainer": null,
    "docs_url": null,
    "requires_python": "<4.0,>=3.9",
    "maintainer_email": null,
    "keywords": "robotframework, rpa, automation",
    "author": "RPA Framework",
    "author_email": "rpafw@robocorp.com",
    "download_url": "https://files.pythonhosted.org/packages/2c/0a/e231d31410c607a34d4450dc23bf5e03d0cba1dcfa9db6f820e59a23d8a3/rpaframework-29.0.0.tar.gz",
    "platform": null,
    "description": "RPA Framework\n=============\n\nREQUEST for user input!\n-----------------------\n\nWe are looking at improving our keyword usage to cover situations where developer might be\nstruggling to smoothly write task for a Robot. Describe the situation where your **implementation speed slows** due to the lack of easier syntax.\n\n`Comment HERE <https://github.com/robocorp/rpaframework/issues/738>`_\n\n.. contents:: Table of Contents\n   :local:\n   :depth: 1\n\n\n.. include-docs-readme\n\nIntroduction\n------------\n\n`RPA Framework` is a collection of open-source libraries and tools for\nRobotic Process Automation (RPA), and it is designed to be used with both\n`Robot Framework`_ and `Python`_. The goal is to offer well-documented and\nactively maintained core libraries for Software Robot Developers.\n\nLearn more about RPA at `Robocorp Documentation`_.\n\n**The project is:**\n\n- 100% Open Source\n- Sponsored by Robocorp_\n- Optimized for Robocorp `Control Room`_ and `Developer Tools`_\n- Accepting external contributions\n\n.. _Robot Framework: https://robotframework.org\n.. _Robot Framework Foundation: https://robotframework.org/foundation/\n.. _Python: https://www.python.org/\n.. _Robocorp: https://robocorp.com\n.. _Robocorp Documentation: https://robocorp.com/docs-robot-framework\n.. _Control Room: https://robocorp.com/docs/control-room\n.. _Developer Tools: https://robocorp.com/downloads\n.. _Installing Python Packages: https://robocorp.com/docs/setup/installing-python-package-dependencies\n\nLinks\n^^^^^\n\n- Homepage: `<https://www.github.com/robocorp/rpaframework/>`_\n- Documentation: `<https://rpaframework.org/>`_\n- PyPI: `<https://pypi.org/project/rpaframework/>`_\n- Release notes: `<https://rpaframework.org/releasenotes.html>`_\n- RSS feed: `<https://rpaframework.org/releases.xml>`_\n\n------------\n\n.. image:: https://img.shields.io/github/actions/workflow/status/robocorp/rpaframework/main.yaml?style=for-the-badge\n   :target: https://github.com/robocorp/rpaframework/actions/workflows/main.yaml\n   :alt: Status\n\n.. image:: https://img.shields.io/pypi/dw/rpaframework?style=for-the-badge\n   :target: https://pypi.python.org/pypi/rpaframework\n   :alt: rpaframework\n\n.. image:: https://img.shields.io/pypi/l/rpaframework.svg?style=for-the-badge&color=brightgreen\n   :target: http://www.apache.org/licenses/LICENSE-2.0.html\n   :alt: License\n\n------------\n\n\nPackages\n--------\n\n.. image:: https://img.shields.io/pypi/v/rpaframework.svg?label=rpaframework&style=for-the-badge\n   :target: https://pypi.python.org/pypi/rpaframework\n   :alt: rpaframework latest version\n\n.. image:: https://img.shields.io/pypi/v/rpaframework-assistant.svg?label=rpaframework-assistant&style=for-the-badge\n   :target: https://pypi.python.org/pypi/rpaframework-assistant\n   :alt: rpaframework-assistant latest version\n\n.. image:: https://img.shields.io/pypi/v/rpaframework-aws.svg?label=rpaframework-aws&style=for-the-badge\n   :target: https://pypi.python.org/pypi/rpaframework-aws\n   :alt: rpaframework-aws latest version\n\n.. image:: https://img.shields.io/pypi/v/rpaframework-core.svg?label=rpaframework-core&style=for-the-badge\n   :target: https://pypi.python.org/pypi/rpaframework-core\n   :alt: rpaframework-core latest version\n\n.. image:: https://img.shields.io/pypi/v/rpaframework-google.svg?label=rpaframework-google&style=for-the-badge&color=blue\n   :target: https://pypi.python.org/pypi/rpaframework-google\n   :alt: rpaframework-google latest version\n\n.. image:: https://img.shields.io/pypi/v/rpaframework-hubspot.svg?label=rpaframework-hubspot&style=for-the-badge&color=blue\n   :target: https://pypi.python.org/pypi/rpaframework-hubspot\n   :alt: rpaframework-hubspot latest version\n\n.. image:: https://img.shields.io/pypi/v/rpaframework-openai.svg?label=rpaframework-openai&style=for-the-badge&color=blue\n   :target: https://pypi.python.org/pypi/rpaframework-openai\n   :alt: rpaframework-openai latest version\n\n.. image:: https://img.shields.io/pypi/v/rpaframework-pdf.svg?label=rpaframework-pdf&style=for-the-badge&color=blue\n   :target: https://pypi.python.org/pypi/rpaframework-pdf\n   :alt: rpaframework-pdf latest version\n\n.. image:: https://img.shields.io/pypi/v/rpaframework-recognition.svg?label=rpaframework-recognition&style=for-the-badge&color=blue\n   :target: https://pypi.python.org/pypi/rpaframework-recognition\n   :alt: rpaframework-recognition latest version\n\n.. image:: https://img.shields.io/pypi/v/rpaframework-windows.svg?label=rpaframework-windows&style=for-the-badge&color=blue\n   :target: https://pypi.python.org/pypi/rpaframework-windows\n   :alt: rpaframework-windows latest version\n\n----\n\nFrom the above packages, ``rpaframework-core`` and ``rpaframework-recognition`` are\nsupport packages, which alone do **not** contain any libraries.\n\n\nLibraries\n---------\n\nThe RPA Framework project currently includes the following libraries:\n\nThe ``x`` in the **PACKAGE** column means that library **is** included in the **rpaframework** package and for example. ``x,pdf`` means that ``RPA.PDF`` library is provided in both the **rpaframework** and **rpaframework-pdf** packages.\n\n+----------------------------+-------------------------------------------------------+------------------------+\n| **LIBRARY NAME**           | **DESCRIPTION**                                       | **PACKAGE**            |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Archive`_                 | Archiving TAR and ZIP files                           | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Assistant`_               | Display information to a user and request input.      | assistant              |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Browser.Selenium`_        | Control browsers and automate the web                 | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Browser.Playwright`_      | Newer way to control browsers                         | special (more below)   |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Calendar`_                | For date and time manipulations                       | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Cloud.AWS`_               | Use Amazon AWS services                               | x,aws                  |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Cloud.Azure`_             | Use Microsoft Azure services                          | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Cloud.Google`_            | Use Google Cloud services                             | google                 |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Crypto`_                  | Common hashing and encryption operations              | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Database`_                | Interact with databases                               | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Desktop`_                 | Cross-platform desktop automation                     | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Desktop.Clipboard`_       | Interact with the system clipboard                    | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Desktop.OperatingSystem`_ | Read OS information and manipulate processes          | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `DocumentAI`_              | Intelligent Document Processing wrapper               | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `DocumentAI.Base64AI`_     | Intelligent Document Processing service               | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `DocumentAI.Nanonets`_     | Intelligent Document Processing service               | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Email.Exchange`_          | E-Mail operations (Exchange protocol)                 | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Email.ImapSmtp`_          | E-Mail operations (IMAP & SMTP)                       | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Excel.Application`_       | Control the Excel desktop application                 | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Excel.Files`_             | Manipulate Excel files directly                       | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `FileSystem`_              | Read and manipulate files and paths                   | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `FTP`_                     | Interact with FTP servers                             | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `HTTP`_                    | Interact directly with web APIs                       | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Hubspot`_                 | Access HubSpot CRM data objects                       | hubspot                |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Images`_                  | Manipulate images                                     | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `JavaAccessBridge`_        | Control Java applications                             | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `JSON`_                    | Manipulate JSON objects                               | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `MFA`_                     | Authenticate using one-time passwords (OTP) & OAuth2  | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Notifier`_                | Notify messages using different services              | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `OpenAI`_                  | Artificial Intelligence service                       | openai                 |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Outlook.Application`_     | Control the Outlook desktop application               | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `PDF`_                     | Read and create PDF documents                         | x,pdf                  |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Robocorp.Process`_        | Use the Robocorp Process API                          | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Robocorp.WorkItems`_      | Use the Robocorp Work Items API                       | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Robocorp.Vault`_          | Use the Robocorp Secrets API                          | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Robocorp.Storage`_        | Use the Robocorp Asset Storage API                    | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Salesforce`_              | Salesforce operations                                 | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `SAP`_                     | Control SAP GUI desktop client                        | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Smartsheet`_              | Access Smartsheet sheets                              | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Tables`_                  | Manipulate, sort, and filter tabular data             | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Tasks`_                   | Control task execution                                | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Twitter`_                 | Twitter API interface                                 | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Windows`_                 | Alternative library for Windows automation            | x,windows              |\n+----------------------------+-------------------------------------------------------+------------------------+\n| `Word.Application`_        | Control the Word desktop application                  | x                      |\n+----------------------------+-------------------------------------------------------+------------------------+\n\n.. _Archive: https://rpaframework.org/libraries/archive/\n.. _Assistant: https://rpaframework.org/libraries/assistant/\n.. _Browser.Playwright: https://rpaframework.org/libraries/browser_playwright/\n.. _Browser.Selenium: https://rpaframework.org/libraries/browser_selenium/\n.. _Calendar: https://rpaframework.org/libraries/calendar/\n.. _Cloud.AWS: https://rpaframework.org/libraries/cloud_aws/\n.. _Cloud.Azure: https://rpaframework.org/libraries/cloud_azure/\n.. _Cloud.Google: https://rpaframework.org/libraries/cloud_google/\n.. _Crypto: https://rpaframework.org/libraries/crypto/\n.. _Database: https://rpaframework.org/libraries/database/\n.. _Desktop: https://rpaframework.org/libraries/desktop/\n.. _Desktop.Clipboard: https://rpaframework.org/libraries/desktop_clipboard/\n.. _Desktop.Operatingsystem: https://rpaframework.org/libraries/desktop_operatingsystem/\n.. _DocumentAI: https://rpaframework.org/libraries/documentai\n.. _DocumentAI.Base64AI: https://rpaframework.org/libraries/documentai_base64ai/\n.. _DocumentAI.Nanonets: https://rpaframework.org/libraries/documentai_nanonets/\n.. _Email.Exchange: https://rpaframework.org/libraries/email_exchange/\n.. _Email.ImapSmtp: https://rpaframework.org/libraries/email_imapsmtp/\n.. _Excel.Application: https://rpaframework.org/libraries/excel_application/\n.. _Excel.Files: https://rpaframework.org/libraries/excel_files/\n.. _FileSystem: https://rpaframework.org/libraries/filesystem/\n.. _FTP: https://rpaframework.org/libraries/ftp/\n.. _HTTP: https://rpaframework.org/libraries/http/\n.. _Hubspot: https://rpaframework.org/libraries/hubspot/\n.. _Images: https://rpaframework.org/libraries/images/\n.. _JavaAccessBridge: https://rpaframework.org/libraries/javaaccessbridge/\n.. _JSON: https://rpaframework.org/libraries/json/\n.. _MFA: https://rpaframework.org/libraries/mfa/\n.. _Notifier: https://rpaframework.org/libraries/notifier/\n.. _OpenAI: https://rpaframework.org/libraries/openai/\n.. _Outlook.Application: https://rpaframework.org/libraries/outlook_application/\n.. _PDF: https://rpaframework.org/libraries/pdf/\n.. _Robocorp.Process: https://rpaframework.org/libraries/robocorp_process/\n.. _Robocorp.WorkItems: https://rpaframework.org/libraries/robocorp_workitems/\n.. _Robocorp.Vault: https://rpaframework.org/libraries/robocorp_vault/\n.. _Robocorp.Storage: https://rpaframework.org/libraries/robocorp_storage/\n.. _Salesforce: https://rpaframework.org/libraries/salesforce/\n.. _SAP: https://rpaframework.org/libraries/sap/\n.. _Smartsheet: https://rpaframework.org/libraries/smartsheet/\n.. _Tables: https://rpaframework.org/libraries/tables/\n.. _Tasks: https://rpaframework.org/libraries/tasks/\n.. _Twitter: https://rpaframework.org/libraries/twitter/\n.. _Windows: https://rpaframework.org/libraries/windows/\n.. _Word.Application: https://rpaframework.org/libraries/word_application/\n\nInstallation of RPA.Browser.Playwright\n--------------------------------------\n\nThe **RPA.Browser.Playwright** at the moment requires special installation, because\nof the package size and the post install step it needs to be fully installed.\n\nMinimum required `conda.yaml` to install Playwright:\n\n.. code-block:: yaml\n\n    channels:\n      - conda-forge\n    dependencies:\n      - python=3.10.14\n      - nodejs=22.9.0\n      - pip=24.0\n      - pip:\n        - robotframework-browser==18.8.1\n        - rpaframework==28.6.3\n    rccPostInstall:\n      - rfbrowser init\n\nInstallation\n------------\n\nLearn about installing Python packages at `Installing Python Packages`_.\n\nDefault installation method with Robocorp `Developer Tools`_ using `conda.yaml`:\n\n.. code-block:: yaml\n\n   channels:\n     - conda-forge\n   dependencies:\n     - python=3.10.14\n     - pip=24.0\n     - pip:\n       - rpaframework==28.6.3\n\nTo install all extra packages (including Playwright dependencies), you can use:\n\n.. code-block:: yaml\n\n   channels:\n     - conda-forge\n   dependencies:\n     - python=3.10.14\n     - tesseract=5.4.1\n     - nodejs=22.9.0\n     - pip=24.0\n     - pip:\n       - robotframework-browser==18.8.1\n       - rpaframework==28.6.3\n       - rpaframework-aws==5.3.3\n       - rpaframework-google==9.0.2\n       - rpaframework-recognition==5.2.5\n   rccPostInstall:\n     - rfbrowser init\n\nSeparate installation of AWS, PDF and Windows libraries without the main\n``rpaframework``:\n\n.. code-block:: yaml\n\n   channels:\n     - conda-forge\n   dependencies:\n     - python=3.10.14\n     - pip=24.0\n     - pip:\n       - rpaframework-aws==5.3.3  # included in the rpaframework as an extra\n       - rpaframework-pdf==7.3.3  # included in the rpaframework by default\n       - rpaframework-windows==7.5.2  # included in the rpaframework by default\n\nInstallation method with `pip` using Python `venv`_:\n\n.. code-block:: shell\n\n   python -m venv .venv\n   source .venv/bin/activate\n   pip install rpaframework\n\n\n.. note:: Python 3.8 or higher is required\n\nExample\n-------\n\nAfter installation the libraries can be directly imported inside\n`Robot Framework`_:\n\n.. code:: robotframework\n\n    *** Settings ***\n    Library    RPA.Browser.Selenium\n\n    *** Tasks ***\n    Login as user\n        Open available browser    https://example.com\n        Input text    id:user-name    ${USERNAME}\n        Input text    id:password     ${PASSWORD}\n\nThe libraries are also available inside Python_:\n\n.. code:: python\n\n    from RPA.Browser.Selenium import Selenium\n\n    lib = Selenium()\n\n    lib.open_available_browser(\"https://example.com\")\n    lib.input_text(\"id:user-name\", username)\n    lib.input_text(\"id:password\", password)\n\nSupport and contact\n-------------------\n\n- `rpaframework.org <https://rpaframework.org/>`_ for library documentation\n- `Robocorp Documentation`_ for guides and tutorials\n- **#rpaframework** channel in `Robot Framework Slack`_ if you\n  have open questions or want to contribute\n- Communicate with your fellow Software Robot Developers and Robocorp experts\n  at `Robocorp Developers Slack`_\n\n.. _Robot Framework Slack: https://robotframework-slack-invite.herokuapp.com/\n.. _Robocorp Developers Slack: https://robocorp-developers.slack.com\n\nContributing\n------------\n\nFound a bug? Missing a critical feature? Interested in contributing?\nHead over to the `Contribution guide <https://rpaframework.org/contributing/guide.html>`_\nto see where to get started.\n\nDevelopment\n-----------\n\nRepository development is `Python`_ based and requires at minimum\nPython version 3.8+ installed on the development machine. The default Python version used in the\nRobocorp Robot template is 3.10.14 so it is a good choice for the version to install. Not recommended\nversions are 3.7.6 and 3.8.1, because they have issues with some of the dependencies related to ``rpaframework``.\nAt the time the newer Python versions starting from 3.12 are also not recommended, because some of\nthe dependencies might cause issues.\n\nRepository development tooling is based on `poetry`_ and `invoke`_. Poetry is the\nunderlying tool used for compiling, building and running the package. Invoke is used\nfor scripting purposes, for example for linting, testing and publishing tasks.\n\nBefore writing any code, please read and acknowledge our extensive `Dev Guide`_.\n\n.. _Dev Guide: https://github.com/robocorp/rpaframework/blob/master/docs/source/contributing/development.md\n\nFirst steps to start developing:\n\n1. initial poetry configuration\n\n.. code:: shell\n\n   poetry config virtualenvs.path null\n   poetry config virtualenvs.in-project true\n   poetry config repositories.devpi \"https://devpi.robocorp.cloud/ci/test\"\n\n2. git clone the repository\n#. create a new Git branch or switch to correct branch or stay in master branch\n\n   - some branch naming conventions **feature/name-of-feature**, **hotfix/name-of-the-issue**, **release/number-of-release**\n\n#. ``poetry install`` which install package with its dependencies into the **.venv** directory of the package, for example **packages/main/.venv**\n#. if testing against Robocorp Robot which is using **devdata/env.json**\n\n   - set environment variables\n   - or ``poetry build`` and use resulting .whl file (in the **dist/** directory) in the Robot **conda.yaml**\n   - or ``poetry build`` and push resulting .whl file  (in the **dist/** directory) into a repository and use raw url\n     to include it in the Robot **conda.yaml**\n   - another possibility for Robocorp internal development is to use Robocorp **devpi** instance, by ``poetry publish --ci``\n     and point **conda.yaml** to use rpaframework version in devpi\n\n#. ``poetry run python -m robot <ROBOT_ARGS> <TARGET_ROBOT_FILE>``\n\n   - common *ROBOT_ARGS* from Robocorp Robot template: ``--report NONE --outputdir output --logtitle \"Task log\"``\n\n#. ``poetry run python <TARGET_PYTHON_FILE>``\n#. ``invoke lint`` to make sure that code formatting is according to **rpaframework** repository guidelines.\n   It is possible and likely that Github action will fail the if developer has not linted the code changes. Code\n   formatting is based on `black`_ and `flake8`_ and those are run with the ``invoke lint``.\n#. the library documentation can be created in the repository root (so called \"meta\" package level). The documentation is\n   built by the docgen tools using the locally installed version of the project, local changes for the main package\n   will be reflected each time you generate the docs, but if you want to see local changes for optional packages, you must\n   utilize ``invoke install-local --package <package_name>`` using the appropriate package name (e.g., ``rpaframework-aws``). This\n   will reinstall that package as a local editable version instead of from PyPI. Multiple such packages can be added by\n   repeating the use of the ``--package`` option. In order to reset this, use ``invoke install --reset``.\n\n   - ``poetry update`` and/or ``invoke install-local --package <package name>``\n   - ``make docs``\n   - open ``docs/build/html/index.html`` with the browser to view the changes or execute ``make local`` and navigate to\n     ``localhost:8000`` to view docs as a live local webpage.\n\n   .. code-block:: toml\n\n      # Before\n      [tool.poetry.dependencies]\n      python = \"^3.8\"\n      rpaframework = { path = \"packages/main\", extras = [\"cv\", \"playwright\", \"aws\"] }\n      rpaframework-google = \"^4.0.0\"\n      rpaframework-windows = \"^4.0.0\"\n\n      # After\n      [tool.poetry.dependencies]\n      python = \"^3.8\"\n      rpaframework = { path = \"packages/main\", extras = [\"cv\", \"playwright\"] }\n      rpaframework-aws = { path = \"packages/aws\" }\n      rpaframework-google = \"^4.0.0\"\n      rpaframework-windows = \"^4.0.0\"\n\n#. ``invoke test`` (this will run both Python unittests and robotframework tests defined in the packages **tests/ directory**)\n\n   - to run specific Python test: ``poetry run pytest path/to/test.py::test_function``\n   - to run specific Robotframework test: ``inv testrobot -r <robot_name> -t <task_name>``\n\n#. git commit changes\n#. git push changes to remote\n#. create pull request from the branch describing changes included in the description\n#. update **docs/source/releasenotes.rst** with changes (commit and push)\n\nPackaging and publishing are done after changes have been merged into master branch.\nAll the following steps should be done within master branch.\n\n#. git pull latest changes into master branch\n#. in the package directory containing changes execute ``invoke lint`` and ``invoke test``\n#. update **pyproject.toml** with new version according to semantic versioning\n#. update **docs/source/releasenotes.rst** with changes\n#. in the repository root (so called \"meta\" package level) run command ``poetry update``\n#. git commit changed **poetry.lock** files (on meta and target package level), **releasenotes.rst**\n   and **pyproject.toml** with message \"PACKAGE. version x.y.z\"\n#. git push\n#. ``invoke publish`` after Github action on master branch is all green\n\nSome recommended tools for development\n\n- `Visual Studio Code`_ as a code editor with following extensions:\n\n   - `Sema4.ai`_\n   - `Robot Framework Language Server`_\n   - `GitLens`_\n   - `Python extension`_\n\n- `GitHub Desktop`_ will make version management less prone to errors\n\n.. _poetry: https://python-poetry.org\n.. _invoke: https://www.pyinvoke.org\n.. _Visual Studio Code: https://code.visualstudio.com\n.. _GitHub Desktop: https://desktop.github.com\n.. _Sema4.ai: https://marketplace.visualstudio.com/items?itemName=sema4ai.sema4ai\n.. _Robot Framework Language Server: https://marketplace.visualstudio.com/items?itemName=robocorp.robotframework-lsp\n.. _GitLens: https://marketplace.visualstudio.com/items?itemName=eamodio.gitlens\n.. _Python extension: https://marketplace.visualstudio.com/items?itemName=ms-python.python\n.. _black: https://pypi.org/project/black/\n.. _flake8: https://pypi.org/project/flake8/\n.. _venv: https://docs.python.org/3/library/venv.html\n\nLicense\n-------\n\nThis project is open-source and licensed under the terms of the\n`Apache License 2.0 <http://apache.org/licenses/LICENSE-2.0>`_.\n",
    "bugtrack_url": null,
    "license": "Apache-2.0",
    "summary": "A collection of tools and libraries for RPA",
    "version": "29.0.0",
    "project_urls": {
        "Documentation": "https://rpaframework.org/",
        "Homepage": "https://rpaframework.org/",
        "Repository": "https://github.com/robocorp/rpaframework"
    },
    "split_keywords": [
        "robotframework",
        " rpa",
        " automation"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "d47e4775aa9312bb97503776de77693209a94d034a06abead28c44275d40547c",
                "md5": "e2c0ae1fe31f81f738956307890c2c73",
                "sha256": "40e2775b8d2e42c25476ed9213b0cfb0a26db9fd6a8ecfc87e499b68dae5a60d"
            },
            "downloads": -1,
            "filename": "rpaframework-29.0.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "e2c0ae1fe31f81f738956307890c2c73",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": "<4.0,>=3.9",
            "size": 698176,
            "upload_time": "2024-12-08T10:39:02",
            "upload_time_iso_8601": "2024-12-08T10:39:02.051671Z",
            "url": "https://files.pythonhosted.org/packages/d4/7e/4775aa9312bb97503776de77693209a94d034a06abead28c44275d40547c/rpaframework-29.0.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "2c0ae231d31410c607a34d4450dc23bf5e03d0cba1dcfa9db6f820e59a23d8a3",
                "md5": "bde498532c1f6e4040db4366cc732207",
                "sha256": "38fa30e8e56278e9bac9f087c1c9092e9e580766ee790bcae83a7c4867c7fa8e"
            },
            "downloads": -1,
            "filename": "rpaframework-29.0.0.tar.gz",
            "has_sig": false,
            "md5_digest": "bde498532c1f6e4040db4366cc732207",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": "<4.0,>=3.9",
            "size": 7926865,
            "upload_time": "2024-12-08T10:39:25",
            "upload_time_iso_8601": "2024-12-08T10:39:25.437764Z",
            "url": "https://files.pythonhosted.org/packages/2c/0a/e231d31410c607a34d4450dc23bf5e03d0cba1dcfa9db6f820e59a23d8a3/rpaframework-29.0.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-12-08 10:39:25",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "robocorp",
    "github_project": "rpaframework",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "rpaframework"
}
        
Elapsed time: 2.27830s