vfs-appointment-bot


Namevfs-appointment-bot JSON
Version 1.1.1 PyPI version JSON
download
home_pageNone
SummaryVFS Appointment Bot - This script automates checking for appointments at VFS Global offices in a specified country.
upload_time2024-05-07 02:59:15
maintainerNone
docs_urlNone
authorRanjan Mohanty
requires_python<4.0,>=3.9
licenseMIT
keywords vfs vfs-bot vfs-appointment-bot visa-appointment-bot
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # VFS Appointment Bot

[![GitHub License](https://img.shields.io/github/license/ranjan-mohanty/vfs-appointment-bot)](https://github.com/ranjan-mohanty/vfs-appointment-bot/blob/main/LICENSE)
[![GitHub Release](https://img.shields.io/github/v/release/ranjan-mohanty/vfs-appointment-bot?logo=GitHub)](https://github.com/ranjan-mohanty/vfs-appointment-bot/releases)
[![PyPI - Version](https://img.shields.io/pypi/v/vfs-appointment-bot?logo=pypi)](https://pypi.org/project/vfs-appointment-bot)
[![Downloads](https://static.pepy.tech/badge/vfs-appointment-bot)](https://pepy.tech/project/vfs-appointment-bot)
[![Endpoint Badge](https://img.shields.io/endpoint?url=https%3A%2F%2Fhits.dwyl.com%2Franjan-mohanty%2Fvfs-appointment-bot.json&style=flat&logo=GitHub&label=views)](https://github.com/ranjan-mohanty/vfs-appointment-bot)
[![GitHub forks](https://img.shields.io/github/forks/ranjan-mohanty/vfs-appointment-bot)](https://github.com/ranjan-mohanty/vfs-appointment-bot/forks)
[![GitHub Repo stars](https://img.shields.io/github/stars/ranjan-mohanty/vfs-appointment-bot)](https://github.com/ranjan-mohanty/vfs-appointment-bot/stargazers)

[![GitHub Actions Workflow Status](https://img.shields.io/github/actions/workflow/status/ranjan-mohanty/vfs-appointment-bot/build.yml)](https://github.com/ranjan-mohanty/vfs-appointment-bot/actions/workflows/build.yml)
[![Codacy Badge](https://app.codacy.com/project/badge/Grade/21f1ecd428ec4342980020a6ef383439)](https://app.codacy.com/gh/ranjan-mohanty/vfs-appointment-bot/dashboard?utm_source=gh&utm_medium=referral&utm_content=&utm_campaign=Badge_grade)
[![OpenSSF Scorecard](https://api.securityscorecards.dev/projects/github.com/ranjan-mohanty/vfs-appointment-bot/badge)](https://securityscorecards.dev/viewer/?uri=github.com/ranjan-mohanty/vfs-appointment-bot)
[![GitHub Issues or Pull Requests](https://img.shields.io/github/issues/ranjan-mohanty/vfs-appointment-bot)](https://github.com/ranjan-mohanty/vfs-appointment-bot/issues)
![Libraries.io dependency status for GitHub repo](https://img.shields.io/librariesio/github/ranjan-mohanty/vfs-appointment-bot)
[![Twitter](https://img.shields.io/twitter/url?style=social&url=https%3A%2F%2Fgithub.com%2Franjan-mohanty%2Fvfs-appointment-bot)](https://twitter.com/intent/tweet?text=Check%20this%20out%20&url=https%3A%2F%2Fgithub.com%2Franjan-mohanty%2Fvfs-appointment-bot)

This Python script(**vfs-appointment-bot**) automates checking for appointments at VFS Global portal in a specified country.

## Installation

The `vfs-appointment-bot` script can be installed using two methods:

### 1. Using pip

It is the preferred method for installing `vfs-appointment-bot`. Here's how to do it:

1. **Create a virtual environment (Recommended):**

   ```bash
   python3 -m venv venv
   ```

   This creates a virtual environment named `venv` to isolate project dependencies from your system-wide Python installation (**recommended**).

2. **Activate the virtual environment:**

   **Linux/macOS:**

   ```bash
   source venv/bin/activate
   ```

   **Windows:**

   ```bash
   venv\Scripts\activate
   ```

3. **Install using pip:**

   ```bash
   pip install vfs-appointment-bot
   ```

   This will download and install the `vfs-appointment-bot` package and its dependencies into your Python environment.

### 2. Manual Installation

For an alternative installation method, clone the source code from the project repository and install it manually.

1. **Clone the repository:**

   ```bash
   git clone https://github.com/ranjan-mohanty/vfs-appointment-bot
   ```

2. **Navigate to the project directory:**

   ```bash
   cd vfs-appointment-bot
   ```

3. **Create a virtual environment (Recommended):**

   ```bash
   python3 -m venv venv
   ```

   This creates a virtual environment named `venv` to isolate project dependencies from your system-wide Python installation (**recommended**).

4. **Activate the virtual environment:**

   **Linux/macOS:**

   ```bash
   source venv/bin/activate
   ```

   **Windows:**

   ```bash
   venv\Scripts\activate
   ```

5. **Install dependencies:**

   ```bash
   pip install poetry
   poetry install
   ```

6. **Install playwright dependencies:**

   ```bash
   playwright install
   ```

## Configuration

1. Download the [`config/config.ini`](https://raw.githubusercontent.com/ranjan-mohanty/vfs-appointment-bot/main/config/config.ini) template.

   ```bash
   curl -L https://raw.githubusercontent.com/ranjan-mohanty/vfs-appointment-bot/main/config/config.ini -o config.ini
   ```

2. Update the vfs credentials and notification channel preferences. See the [Notification Channels](#notification-channels) section for details on configuring email, Twilio, and Telegram notifications.
3. Export the path of the config file to the environment variable `VFS_BOT_CONFIG_PATH`

   ```bash
   export VFS_BOT_CONFIG_PATH=<your-config-path>/config.ini
   ```

**If you installed the script by cloning the repository (manual installation)**, you can directly edit the values in `config/config.ini`.

## Usage

1. **Command-Line Argument:**

   The script requires the source and destination country code ([as per ISO 3166-1 alpha-2](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2#Officially_assigned_code_elements)) to be provided as a command-line argument using the `-sc` or `--source-country-code` and `-dc` or `--destination-country-code` option.

2. **Running the Script:**

   There are two ways to provide required appointment details:

   - **Responding to User Prompts (recommended):**

     ```bash
     vfs-appointment-bot -sc IN -dc DE
     ```

     The script will prompt you to enter the required apponitment parameters for the specified country.

   - **Using `-ap` or `--appointment-params`:**

     Specify appointment details in a comma-separated (**not space-separated**) key-value format:

     ```bash
     vfs-appointment-bot -sc IN -dc DE -ap visa_center=X,visa_category=Y,visa_sub_category=Z
     ```

   The script will then connect to the VFS Global website for the specified country, search for available appointments using the provided or entered parameters, and potentially send notifications (depending on your configuration).

## Notification Channels

It currently supports three notification channels to keep you informed about appointment availability:

- **Email:** Sends notifications via a Gmail account.
- **Twilio (SMS & Voice Call):** Enables alerts through text messages and phone calls using Twilio's services.
- **Telegram:** Sends notifications directly to your Telegram account through a bot.

**Configuring Notifications:**

**Email:**

1. **Email Account:** You'll need a **Gmail account** for sending notifications.
2. **App Password:** Generate an app password for your Gmail account instead of your regular password. Refer to Google's guide for generating app passwords: [https://support.google.com/accounts/answer/185833?hl=en](https://support.google.com/accounts/answer/185833?hl=en).
3. **Configuration File:** Update your application's configuration file (`config.ini`) with the following details:

   - **`email` (Required):** Your Gmail address.
   - **`password` (Required):** Your generated Gmail app password.

**Twilio:**

1. **Create a Twilio Account (if needed):** Sign up for a free Twilio account at [https://www.twilio.com/en-us](https://www.twilio.com/en-us) to obtain account credentials and phone numbers.
2. **Retrieve Credentials:** Locate your account SID, auth token, and phone numbers within your Twilio account dashboard.
3. **Configuration File:** Update your application's configuration file (`config.ini`) with:

   - `auth_token` (Required): Your Twilio auth token
   - `account_sid` (Required): Your Twilio account SID
   - `sms_enabled` (Optional): Enables SMS notifications (default: True)
   - `call_enabled` (Optional): Enables voice call notifications (default: False)
   - `url` (Optional): Twilio API URL (Only needed if call is enabled)
   - `to_num` (Required): Recipient phone number for notifications
   - `from_num` (Required): Twilio phone number you'll use for sending messages

**Telegram:**

1. **Create a Telegram Bot:** Visit [https://telegram.me/BotFather](https://telegram.me/BotFather) to create a Telegram bot. Follow the on-screen instructions to obtain your bot's token.
2. **Configuration File:** Update your application's configuration file (`config.ini`) with:

   - **`bot_token` (Required):** Your Telegram bot token obtained from BotFather.
   - **`chat_id` (Optional):** The specific Telegram chat ID where you want to receive notifications. If omitted, the bot will send notifications to the chat where it was messaged from. To find your chat ID, you can create a group chat with just yourself and then use the `/my_id` command within the bot.

## Supported Countries and Appointment Parameters

The following table lists currently supported countries and their corresponding appointment parameters:

| Country                    | Appointment Parameters                                      |
| -------------------------- | ----------------------------------------------------------- |
| India(IN) - Germany(DE)    | visa_category, visa_sub_category, visa_center               |
| Iraq(IQ) - Germany(DE)     | visa_category, visa_sub_category, visa_center               |
| Morocco(MA) - Italy(IT)    | visa_category, visa_sub_category, visa_center, payment_mode |
| Azerbaijan(AZ) - Italy(IT) | visa_category, visa_sub_category, visa_center               |

**Notes:**

- Appointment parameters might vary depending on the specific country and visa type. Always consult VFS Global's website for the latest information.

## Known Issues

**1. Login Failures After Frequent Requests:**  
If the bot makes login requests to the VFS website too frequently, the VFS system might temporarily block your access due to suspected automation. This can lead to login failures.

- **Workaround:**
  - **Reduce request frequency:** Consider increasing the delay between bot runs to avoid triggering VFS's blocking mechanisms. You can adjust the interval in the configuration or code.
  - **Retry after 2 hours:** If you encounter a login failure, wait for at least 2 hours before retrying. The VFS block should expire within this timeframe.

**2. Occasional Captcha Verification:**  
The VFS website requires a CAPTCHA verification step during login. Currently, the bot does not have a built-in CAPTCHA solver.

- **Workaround:**
  - **Wait and Retry:** Sometimes, CAPTCHAs appear due to temporary website issues. Wait for a while and try again later.
  - **Retry in another browser:** CAPTCHAs are often solved automatically in the Firefox browser. If it still fails, retry the login process in another browser by setting `browser_type` to `"chromium" or "webkit"` in your `config.ini` file.

**Note:** We are constantly working to improve the bot's functionality. Future updates might include integrated CAPTCHA solving capabilities.

## Extending Country Support

This script is currently designed to work with the VFS Global website for Germany. It might be possible to extend support for other countries by modifying the script to handle potential variations in website structure and parameter requirements across different VFS Global country pages.

## Contributing

We welcome contributions from the community to improve this project! Here's how you can get involved:

- **Report issues:** If you encounter any bugs or problems with the script, please create an issue on the project's repository.
- **Suggest improvements:** Do you have ideas for making the script more user-friendly or feature-rich? Feel free to create an issue or pull request on the repository.
- **Submit pull requests:** If you've made code changes that you think would benefit the project, create a pull request on the repository. Please follow any contribution guidelines outlined in a CONTRIBUTING.md file.

## Star History

[![Star History Chart](https://api.star-history.com/svg?repos=ranjan-mohanty/vfs-appointment-bot&type=Date)](https://star-history.com/#ranjan-mohanty/vfs-appointment-bot&Date)

## Disclaimer

This script is provided as-is and is not affiliated with VFS Global. It's your responsibility to ensure you're complying with VFS Global's terms and conditions when using this script. Be aware that website structures and appointment availability mechanisms might change over time.


            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "vfs-appointment-bot",
    "maintainer": null,
    "docs_url": null,
    "requires_python": "<4.0,>=3.9",
    "maintainer_email": null,
    "keywords": "vfs, vfs-bot, vfs-appointment-bot, visa-appointment-bot",
    "author": "Ranjan Mohanty",
    "author_email": "ranjan@duck.com",
    "download_url": "https://files.pythonhosted.org/packages/06/32/ae8d4c3f4785ea62f00afd6e8183cebd9e57ea664bd95306415325926a58/vfs_appointment_bot-1.1.1.tar.gz",
    "platform": null,
    "description": "# VFS Appointment Bot\n\n[![GitHub License](https://img.shields.io/github/license/ranjan-mohanty/vfs-appointment-bot)](https://github.com/ranjan-mohanty/vfs-appointment-bot/blob/main/LICENSE)\n[![GitHub Release](https://img.shields.io/github/v/release/ranjan-mohanty/vfs-appointment-bot?logo=GitHub)](https://github.com/ranjan-mohanty/vfs-appointment-bot/releases)\n[![PyPI - Version](https://img.shields.io/pypi/v/vfs-appointment-bot?logo=pypi)](https://pypi.org/project/vfs-appointment-bot)\n[![Downloads](https://static.pepy.tech/badge/vfs-appointment-bot)](https://pepy.tech/project/vfs-appointment-bot)\n[![Endpoint Badge](https://img.shields.io/endpoint?url=https%3A%2F%2Fhits.dwyl.com%2Franjan-mohanty%2Fvfs-appointment-bot.json&style=flat&logo=GitHub&label=views)](https://github.com/ranjan-mohanty/vfs-appointment-bot)\n[![GitHub forks](https://img.shields.io/github/forks/ranjan-mohanty/vfs-appointment-bot)](https://github.com/ranjan-mohanty/vfs-appointment-bot/forks)\n[![GitHub Repo stars](https://img.shields.io/github/stars/ranjan-mohanty/vfs-appointment-bot)](https://github.com/ranjan-mohanty/vfs-appointment-bot/stargazers)\n\n[![GitHub Actions Workflow Status](https://img.shields.io/github/actions/workflow/status/ranjan-mohanty/vfs-appointment-bot/build.yml)](https://github.com/ranjan-mohanty/vfs-appointment-bot/actions/workflows/build.yml)\n[![Codacy Badge](https://app.codacy.com/project/badge/Grade/21f1ecd428ec4342980020a6ef383439)](https://app.codacy.com/gh/ranjan-mohanty/vfs-appointment-bot/dashboard?utm_source=gh&utm_medium=referral&utm_content=&utm_campaign=Badge_grade)\n[![OpenSSF Scorecard](https://api.securityscorecards.dev/projects/github.com/ranjan-mohanty/vfs-appointment-bot/badge)](https://securityscorecards.dev/viewer/?uri=github.com/ranjan-mohanty/vfs-appointment-bot)\n[![GitHub Issues or Pull Requests](https://img.shields.io/github/issues/ranjan-mohanty/vfs-appointment-bot)](https://github.com/ranjan-mohanty/vfs-appointment-bot/issues)\n![Libraries.io dependency status for GitHub repo](https://img.shields.io/librariesio/github/ranjan-mohanty/vfs-appointment-bot)\n[![Twitter](https://img.shields.io/twitter/url?style=social&url=https%3A%2F%2Fgithub.com%2Franjan-mohanty%2Fvfs-appointment-bot)](https://twitter.com/intent/tweet?text=Check%20this%20out%20&url=https%3A%2F%2Fgithub.com%2Franjan-mohanty%2Fvfs-appointment-bot)\n\nThis Python script(**vfs-appointment-bot**) automates checking for appointments at VFS Global portal in a specified country.\n\n## Installation\n\nThe `vfs-appointment-bot` script can be installed using two methods:\n\n### 1. Using pip\n\nIt is the preferred method for installing `vfs-appointment-bot`. Here's how to do it:\n\n1. **Create a virtual environment (Recommended):**\n\n   ```bash\n   python3 -m venv venv\n   ```\n\n   This creates a virtual environment named `venv` to isolate project dependencies from your system-wide Python installation (**recommended**).\n\n2. **Activate the virtual environment:**\n\n   **Linux/macOS:**\n\n   ```bash\n   source venv/bin/activate\n   ```\n\n   **Windows:**\n\n   ```bash\n   venv\\Scripts\\activate\n   ```\n\n3. **Install using pip:**\n\n   ```bash\n   pip install vfs-appointment-bot\n   ```\n\n   This will download and install the `vfs-appointment-bot` package and its dependencies into your Python environment.\n\n### 2. Manual Installation\n\nFor an alternative installation method, clone the source code from the project repository and install it manually.\n\n1. **Clone the repository:**\n\n   ```bash\n   git clone https://github.com/ranjan-mohanty/vfs-appointment-bot\n   ```\n\n2. **Navigate to the project directory:**\n\n   ```bash\n   cd vfs-appointment-bot\n   ```\n\n3. **Create a virtual environment (Recommended):**\n\n   ```bash\n   python3 -m venv venv\n   ```\n\n   This creates a virtual environment named `venv` to isolate project dependencies from your system-wide Python installation (**recommended**).\n\n4. **Activate the virtual environment:**\n\n   **Linux/macOS:**\n\n   ```bash\n   source venv/bin/activate\n   ```\n\n   **Windows:**\n\n   ```bash\n   venv\\Scripts\\activate\n   ```\n\n5. **Install dependencies:**\n\n   ```bash\n   pip install poetry\n   poetry install\n   ```\n\n6. **Install playwright dependencies:**\n\n   ```bash\n   playwright install\n   ```\n\n## Configuration\n\n1. Download the [`config/config.ini`](https://raw.githubusercontent.com/ranjan-mohanty/vfs-appointment-bot/main/config/config.ini) template.\n\n   ```bash\n   curl -L https://raw.githubusercontent.com/ranjan-mohanty/vfs-appointment-bot/main/config/config.ini -o config.ini\n   ```\n\n2. Update the vfs credentials and notification channel preferences. See the [Notification Channels](#notification-channels) section for details on configuring email, Twilio, and Telegram notifications.\n3. Export the path of the config file to the environment variable `VFS_BOT_CONFIG_PATH`\n\n   ```bash\n   export VFS_BOT_CONFIG_PATH=<your-config-path>/config.ini\n   ```\n\n**If you installed the script by cloning the repository (manual installation)**, you can directly edit the values in `config/config.ini`.\n\n## Usage\n\n1. **Command-Line Argument:**\n\n   The script requires the source and destination country code ([as per ISO 3166-1 alpha-2](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2#Officially_assigned_code_elements)) to be provided as a command-line argument using the `-sc` or `--source-country-code` and `-dc` or `--destination-country-code` option.\n\n2. **Running the Script:**\n\n   There are two ways to provide required appointment details:\n\n   - **Responding to User Prompts (recommended):**\n\n     ```bash\n     vfs-appointment-bot -sc IN -dc DE\n     ```\n\n     The script will prompt you to enter the required apponitment parameters for the specified country.\n\n   - **Using `-ap` or `--appointment-params`:**\n\n     Specify appointment details in a comma-separated (**not space-separated**) key-value format:\n\n     ```bash\n     vfs-appointment-bot -sc IN -dc DE -ap visa_center=X,visa_category=Y,visa_sub_category=Z\n     ```\n\n   The script will then connect to the VFS Global website for the specified country, search for available appointments using the provided or entered parameters, and potentially send notifications (depending on your configuration).\n\n## Notification Channels\n\nIt currently supports three notification channels to keep you informed about appointment availability:\n\n- **Email:** Sends notifications via a Gmail account.\n- **Twilio (SMS & Voice Call):** Enables alerts through text messages and phone calls using Twilio's services.\n- **Telegram:** Sends notifications directly to your Telegram account through a bot.\n\n**Configuring Notifications:**\n\n**Email:**\n\n1. **Email Account:** You'll need a **Gmail account** for sending notifications.\n2. **App Password:** Generate an app password for your Gmail account instead of your regular password. Refer to Google's guide for generating app passwords: [https://support.google.com/accounts/answer/185833?hl=en](https://support.google.com/accounts/answer/185833?hl=en).\n3. **Configuration File:** Update your application's configuration file (`config.ini`) with the following details:\n\n   - **`email` (Required):** Your Gmail address.\n   - **`password` (Required):** Your generated Gmail app password.\n\n**Twilio:**\n\n1. **Create a Twilio Account (if needed):** Sign up for a free Twilio account at [https://www.twilio.com/en-us](https://www.twilio.com/en-us) to obtain account credentials and phone numbers.\n2. **Retrieve Credentials:** Locate your account SID, auth token, and phone numbers within your Twilio account dashboard.\n3. **Configuration File:** Update your application's configuration file (`config.ini`) with:\n\n   - `auth_token` (Required): Your Twilio auth token\n   - `account_sid` (Required): Your Twilio account SID\n   - `sms_enabled` (Optional): Enables SMS notifications (default: True)\n   - `call_enabled` (Optional): Enables voice call notifications (default: False)\n   - `url` (Optional): Twilio API URL (Only needed if call is enabled)\n   - `to_num` (Required): Recipient phone number for notifications\n   - `from_num` (Required): Twilio phone number you'll use for sending messages\n\n**Telegram:**\n\n1. **Create a Telegram Bot:** Visit [https://telegram.me/BotFather](https://telegram.me/BotFather) to create a Telegram bot. Follow the on-screen instructions to obtain your bot's token.\n2. **Configuration File:** Update your application's configuration file (`config.ini`) with:\n\n   - **`bot_token` (Required):** Your Telegram bot token obtained from BotFather.\n   - **`chat_id` (Optional):** The specific Telegram chat ID where you want to receive notifications. If omitted, the bot will send notifications to the chat where it was messaged from. To find your chat ID, you can create a group chat with just yourself and then use the `/my_id` command within the bot.\n\n## Supported Countries and Appointment Parameters\n\nThe following table lists currently supported countries and their corresponding appointment parameters:\n\n| Country                    | Appointment Parameters                                      |\n| -------------------------- | ----------------------------------------------------------- |\n| India(IN) - Germany(DE)    | visa_category, visa_sub_category, visa_center               |\n| Iraq(IQ) - Germany(DE)     | visa_category, visa_sub_category, visa_center               |\n| Morocco(MA) - Italy(IT)    | visa_category, visa_sub_category, visa_center, payment_mode |\n| Azerbaijan(AZ) - Italy(IT) | visa_category, visa_sub_category, visa_center               |\n\n**Notes:**\n\n- Appointment parameters might vary depending on the specific country and visa type. Always consult VFS Global's website for the latest information.\n\n## Known Issues\n\n**1. Login Failures After Frequent Requests:**  \nIf the bot makes login requests to the VFS website too frequently, the VFS system might temporarily block your access due to suspected automation. This can lead to login failures.\n\n- **Workaround:**\n  - **Reduce request frequency:** Consider increasing the delay between bot runs to avoid triggering VFS's blocking mechanisms. You can adjust the interval in the configuration or code.\n  - **Retry after 2 hours:** If you encounter a login failure, wait for at least 2 hours before retrying. The VFS block should expire within this timeframe.\n\n**2. Occasional Captcha Verification:**  \nThe VFS website requires a CAPTCHA verification step during login. Currently, the bot does not have a built-in CAPTCHA solver.\n\n- **Workaround:**\n  - **Wait and Retry:** Sometimes, CAPTCHAs appear due to temporary website issues. Wait for a while and try again later.\n  - **Retry in another browser:** CAPTCHAs are often solved automatically in the Firefox browser. If it still fails, retry the login process in another browser by setting `browser_type` to `\"chromium\" or \"webkit\"` in your `config.ini` file.\n\n**Note:** We are constantly working to improve the bot's functionality. Future updates might include integrated CAPTCHA solving capabilities.\n\n## Extending Country Support\n\nThis script is currently designed to work with the VFS Global website for Germany. It might be possible to extend support for other countries by modifying the script to handle potential variations in website structure and parameter requirements across different VFS Global country pages.\n\n## Contributing\n\nWe welcome contributions from the community to improve this project! Here's how you can get involved:\n\n- **Report issues:** If you encounter any bugs or problems with the script, please create an issue on the project's repository.\n- **Suggest improvements:** Do you have ideas for making the script more user-friendly or feature-rich? Feel free to create an issue or pull request on the repository.\n- **Submit pull requests:** If you've made code changes that you think would benefit the project, create a pull request on the repository. Please follow any contribution guidelines outlined in a CONTRIBUTING.md file.\n\n## Star History\n\n[![Star History Chart](https://api.star-history.com/svg?repos=ranjan-mohanty/vfs-appointment-bot&type=Date)](https://star-history.com/#ranjan-mohanty/vfs-appointment-bot&Date)\n\n## Disclaimer\n\nThis script is provided as-is and is not affiliated with VFS Global. It's your responsibility to ensure you're complying with VFS Global's terms and conditions when using this script. Be aware that website structures and appointment availability mechanisms might change over time.\n\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "VFS Appointment Bot - This script automates checking for appointments at VFS Global offices in a specified country.",
    "version": "1.1.1",
    "project_urls": {
        "homepage": "https://github.com/ranjan-mohanty/vfs-appointment-bot/blob/main",
        "repository": "https://github.com/ranjan-mohanty/vfs-appointment-bot/blob/main/README.md"
    },
    "split_keywords": [
        "vfs",
        " vfs-bot",
        " vfs-appointment-bot",
        " visa-appointment-bot"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "fa75f8e57bdfa43254c393b8325b62afed02f3398f1f283405eb0b5498d4e94f",
                "md5": "93982caab4b0227b94a58e4431c61933",
                "sha256": "02810b822ea9c52d422d3b7d565f9eb1edafddf92c07994cc1ca6a9bfb22d116"
            },
            "downloads": -1,
            "filename": "vfs_appointment_bot-1.1.1-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "93982caab4b0227b94a58e4431c61933",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": "<4.0,>=3.9",
            "size": 22259,
            "upload_time": "2024-05-07T02:59:13",
            "upload_time_iso_8601": "2024-05-07T02:59:13.919092Z",
            "url": "https://files.pythonhosted.org/packages/fa/75/f8e57bdfa43254c393b8325b62afed02f3398f1f283405eb0b5498d4e94f/vfs_appointment_bot-1.1.1-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "0632ae8d4c3f4785ea62f00afd6e8183cebd9e57ea664bd95306415325926a58",
                "md5": "4607303cb2504ef6449f9285cd669715",
                "sha256": "220d098920606ee69081559b6912762525dcd58ad8372f79ba72beb037ad5279"
            },
            "downloads": -1,
            "filename": "vfs_appointment_bot-1.1.1.tar.gz",
            "has_sig": false,
            "md5_digest": "4607303cb2504ef6449f9285cd669715",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": "<4.0,>=3.9",
            "size": 18806,
            "upload_time": "2024-05-07T02:59:15",
            "upload_time_iso_8601": "2024-05-07T02:59:15.689495Z",
            "url": "https://files.pythonhosted.org/packages/06/32/ae8d4c3f4785ea62f00afd6e8183cebd9e57ea664bd95306415325926a58/vfs_appointment_bot-1.1.1.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-05-07 02:59:15",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "ranjan-mohanty",
    "github_project": "vfs-appointment-bot",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "vfs-appointment-bot"
}
        
Elapsed time: 0.23972s