Metadata-Version: 2.1
Name: CheckSSLCert
Version: 0.1.1
Summary: CheckSSLCert is a Python library that allows you to check the SSL certificate status.
Home-page: https://github.com/Huntroid-India/CheckSSLCert
Author: Srimath
Author-email: srimath8@gmail.com
License: MIT
Project-URL: Bug Tracker, https://github.com/Huntroid-India/CheckSSLCert/issues
Classifier: Development Status :: 3 - Alpha
Classifier: Intended Audience :: Developers
Classifier: Programming Language :: Python :: 3
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Requires-Python: >=3.6
Description-Content-Type: text/markdown
License-File: LICENSE

# CheckSSLCert

[![Made with Python](https://img.shields.io/badge/Python->=3.6-blue?logo=python&logoColor=white)](https://python.org "Go to Python homepage")

[![Huntroid-India - SSLCheckerr](https://img.shields.io/static/v1?label=Huntroid-India&message=CheckSSLCert&color=blue&logo=github)](https://github.com/Huntroid-India/CheckSSLCert "Go to GitHub repo")
[![License](https://img.shields.io/badge/License-MIT-blue)](#license)
[![stars - SSLChecker](https://img.shields.io/github/stars/Huntroid-India/CheckSSLCert?style=social)](https://github.com/Huntroid-India/CheckSSLCert)
[![forks - SSLChecker](https://img.shields.io/github/forks/Huntroid-India/CheckSSLCert?style=social)](https://github.com/Huntroid-India/CheckSSLCert)
[![issues - SSLCheckerr](https://img.shields.io/github/issues/Huntroid-India/CheckSSLCert)](https://github.com/Huntroid-India/CheckSSLCert/issues)
<!-- [![GitHub release](https://img.shields.io/github/release/Huntroid-India/CheckSSLCert?include_prereleases=&sort=semver&color=blue)](https://github.com/Huntroid-India/CheckSSLCert/releases/)
-->


CheckSSLCert is a Python library that allows you to check the SSL certificate status for single or multiple domains. It
provides an easy way to determine if an SSL certificate is active, the number of days left until it expires, and
additional certificate information.

## Installation

You can install CheckSSLCert using pip:

```
pip install CheckSSLCert
```

## Usage

### SSL Validation (Single Domain)

To check the SSL certificate status for a single domain, you can use the ``from_link`` function from ``validate`` class.

_Here's a sample code demonstrating the usage:_

```
from CheckSSLCert import validate

# Create an from_link object for the domain
checker = validate.from_link("example.com")

# Check the SSL certificate status
status = checker.IsActive()
days_left = checker.getDayLeft()
info = checker.getInfo()

# Print the results
print("SSL Status:", status)
print("Days Left:", days_left)
print("Certificate Info:", info)

# Print the SSL certificate Report
print(checker)
```

## Bulk SSL Validation (Multiple Domains - CSV File)

To check the SSL certificate status for multiple domains, you can use the ``from_file`` function from ``validate``
class.

### Print the SSL certificate status report to the console

_Here's a sample code demonstrating the usage:_

```
from CheckSSLCert import validate

# Create a from_file object with the path to the domain list file (CSV format)
checker = validate.from_file("domain_list.csv")

# Print the SSL certificate status report to the console (Full Report)
checker.print_report()

# Print the SSL certificate status report to the console (Partial Report)
checker.print_report(IsAll=False)

```

**Note:**

+ If you want to print the complete report, set ``IsAll`` to ``True``. By default, the full report is printed.
+ If you want to print the report only for the domains with expired or expiring in 14 days, set ``IsAll`` to ``False``.

---

### Send the SSL certificate status report via email

_Here's a sample code demonstrating the usage:_

```
from CheckSSLCert import validate

# Create a from_file object with the path to the domain list file (CSV format)
checker = validate.from_file("domain_list.csv")

# Configure the Mail Server
mail_config = {'sender': "example@gmail.com",
               'password': "passward",
               'receiver': ["example2@gmail.com", "example3@gmail.com"],
               'subject': "SSL Checker Report",
               'smtp_server': "smtp.gmail.com",
               'port': 587}

# Send the SSL certificate status report to an email address (Full Report)
checker.send_report(mail_config, IsAll=True)

# Send the SSL certificate status report to an email address (Partial Report)
checker.send_report(mail_config, IsAll=False)

```

**Note:**

+ If you want to you a different mail server, set ``smtp_server`` to the SMTP server address in ``mail_config``.
+ If you want to use TLS, set ``port`` to ``587`` in ``mail_config``.
+ If you want to use SSL, set ``port`` to ``465`` in ``mail_config``.
+ If you want to send the complete report, set ``IsAll`` to ``True``. By default, the full report is sent.
+ If you want to send the report only for the domains with expired or expiring in 14 days, set ``IsAll`` to ``False``.

---

### Save the SSL certificate status report to a file

_Here's a sample code demonstrating the usage:_

```
from CheckSSLCert import validate

# Create a from_file object with the path to the domain list file (CSV format)
checker = validate.from_file("domain_list.csv")

# Save the SSL certificate status report to a file (HTML format)

# By default, the report is saved in HTML format
checker.save_report("C:\Users\YourUsername\Desktop") 

# Save the SSL certificate status report to a file (CSV format)
checker.save_report("C:\Users\YourUsername\Desktop", file_type="csv")
```

**Note:**

+ If you want to save the complete report, set ``IsAll`` to ``True``. By default, the full report is saved.
+ If you want to save the report only for the domains with expired or expiring in 14 days, set ``IsAll`` to ``False``.
+ By default, the report is saved in HTML format. If you want to save the report in CSV format, set ``file_type``
  to ``csv``.

## Domain List File Format

The domain list file should be in CSV format. The first row should contain the column names. Here's a sample domain list
file:

Click the Download button and Save it as ``domain_list.csv``.

[![CSV - Documentation](https://img.shields.io/badge/Download-CSV-blue?style=for-the-badge)](https://raw.githubusercontent.com/Huntroid-India/CheckSSLCert/main/domain_list.csv "Go to project documentation")

#### File Format

| S.No | Website_Name      | Website_URL        |
|------|-------------------|--------------------|
| 1 | Google            | https://google.com |
| 2 | Facebook - Mobile | https://m.facebook.com     |
| 3 | Twitter           | www.twitter.com    |

## Contribution

Contributions are welcome! If you have any suggestions, improvements, or bug fixes, please submit a pull request.

## License

Released under [MIT](/LICENSE) by [@Huntroid-India](https://github.com/Huntroid-India).


