Metadata-Version: 2.0
Name: fsubot
Version: 0.4.0
Summary: Base bot for developing FSU bots.
Home-page: https://github.com/seanpianka/fsubot
Author: Sean Pianka
Author-email: pianka@eml.cc
License: MIT
Download-URL: https://github.com/seanpianka/FSUBot/tarball/0.4.0
Keywords: florida,state,university,fsu,bot
Platform: UNKNOWN
Classifier: Development Status :: 5 - Production/Stable
Classifier: Operating System :: Unix
Classifier: Operating System :: MacOS
Classifier: Intended Audience :: Developers
Classifier: Natural Language :: English
Classifier: License :: OSI Approved :: Apache Software License
Classifier: Topic :: Education
Classifier: Topic :: Utilities
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.3
Classifier: Programming Language :: Python :: 3.4
Classifier: Programming Language :: Python :: 3.5
Classifier: Programming Language :: Python :: 3.6
Requires-Dist: argparse
Requires-Dist: lxml (==3.7.2)
Requires-Dist: selenium (==3.0.2)

FSUBot
======

A bot which serves as the foundation for other bots for use on the
Florida State University website. It is useful for automating tasks that
are otherwise very menial and tedious.

This project serves as a framework for creating bots which are designed
for Florida State University websites. It handles logging into MyFSU
automatically, and setting up ubiquitous attributes and functionality
such as:

#. Standard argument parsing
#. Logging into MyFSU
#. Web browser driver handling.

Where to Begin
--------------

Package Installation
~~~~~~~~~~~~~~~~~~~~

Install the ``FSUBot`` package using ``pip``.

.. code:: bash

    $ pip install fsubot

If you receive a error 13 and/or a permission error, prefer:

.. code:: bash

    $ pip install fsubot --user

rather than:

.. code:: bash

    sudo pip install fsubot

Driver Installation
~~~~~~~~~~~~~~~~~~~

Download and install any driver from the following (I prefer
``chromedriver``):

-  Chrome: `chromedriver`_
-  Firefox: `geckodriver`_

   -  There has not been extensive testing using ``geckodriver``,
      proceed with caution.

Ensure that the driver executable is located within your environment’s
``PATH`` variable. There are many readily available guides on Google for
how to do this.

Bot Instantiation
~~~~~~~~~~~~~~~~~

If you instantiate your bot with the following:

.. code:: python

    fsu_dr = FSUBot(use_cli=True)

Then, you can pass in arguments like so:

.. code:: bash

    $ python fsubot/bot.py --fsu-id abc13 --fsu-pw hunter2 --browser chrome --executable-path drivers/chromedriver

Examples
~~~~~~~~

-  `Vindicta`_, my personal bot which automatically enrolls for desired
   courses.
-  `EasyGradeBot`_, my personal bot which traverses through a list of
   BlackBoard Smart View pages and downloads all submitted assignment’s
   most recently submitted attempts.

Page Navigation Information
~~~~~~~~~~~~~~~~~~~~~~~~~~~

After instantiating your bot, named ``bot``, there are a few methods you
can use for traversing the DOM and navigating to different pages.

Method 1
^^^^^^^^

Use ``bot.dr``, the accessible ``selenium.webdriver`` instance, and the
`well-documented Selenium API`_.

Method 2
^^^^^^^^

.. code:: json

    {
        "pages": [
            {
                "title": "",
                "iframe": false,
                "xpath": "",
                "css_selector": ""
            },

            {
                "title": "",
                "iframe": false,
                "xpath": "",
                "css_selector": ""
            },

            {
                "title": "",
                "iframe": false,
                "xpath": "",
                "css_selector": ""
            },

            {
                "title": "",
                "iframe": false,
                "xpath": "",
                "css_selector": ""
            },

            {
                "title": "",
                "iframe": false,
                "xpath": "",
                "css_selector": ""
            },

            {
                "title": "",
                "iframe": false,
                "xpath": "",
                "css_selector": ""
            }
        ]
    }

The elements will be sequentially passed to ``bot._click`` and clicked
as if a real user was clicking them.

-  ``title`` is used for logging purposes, to indicate when clicking an
   element has succeeded.
-  ``iframe`` is used to specify if the following ``css_selector`` or
   ``xpath`` will resolve to an iframe, which should thusly be focused
   on (review Selenium’s API for focusing on an iframe).
-  ``xpath`` is used to specify the xpath for resolving an element to be
   clicked.
-  ``css_selector`` is used to specify the CSS selector for resolving an
   element to be clicked.


.. _chromedriver: https://sites.google.com/a/chromium.org/chromedriver/downloads
.. _geckodriver: https://github.com/mozilla/geckodriver/releases
.. _Vindicta: https://github.com/seanpianka/Vindicta
.. _EasyGradeBot: https://github.com/seanpianka/EasyGradeBot
.. _well-documented Selenium API: https://seleniumhq.github.io/selenium/docs/api/py/api.html


