Skip to main content

Converts wmt schedule Views:My Schedule to .ics file

Project description

Wmt2Ics

Description

Using Web Schedules (wmtscheduler or wmt) Views: My Schedule as data, highlight and copy the pay period schedule. Once you start the script, enter the pay period number, the module will then automagically paste the copied data (you will not see anything on the terminal window). The information will then be parsed and converted into an Internet Calendar Sharing file (.ics) which can then be imported into Apple iCal, Google Calendar, etc.

Information

Built and tested in Python 3.8

This module takes advantage of python library icalendar which is a RFC5545 parser/generator for iCalendar files. It also uses pyperclip to paste the copied data.

Use Case 1

  1. Create a python file:
#!/usr/bin/env python3
from wmt2ics import Wmt2Ics as wmt

wmt() # Default run_method='desktop'
  1. Save the file and make it executable.
  2. Navigate to Web Scheduler, once logged in, select Views, then My Schedule.
  3. Copy the the pay period by highlighting and Ctrl+c to copy.
  4. Go to Terminal and run python3 yourfile.py
    • Enter the pay period number - This will be part of your saved .ics filename
  5. Once completed you should find "Pay_Period_XX.ics" on your desktop. If you are using a Mac, you can open your iCal program and import the file.
    • You can also import to Google Calendar
    • If you have a linux computer, or windows computer, but use an iPhone, I suggest Use Case #2

Use Case 2 (Sligtly more involved)

  1. Create a python file:
#!/usr/bin/env python3
from wmt2ics import Wmt2Ics as wmt
from wmt2ics.configemail import ConfigEmail as cfg

config = cfg() 

config.setup_config(smtp='smtp.gmail.com', port='587', send='sender@email.com', 'send_pwd='P@$$w0rd for sendemail accout', dest='receiver@email.com')

wmt(run_method='email') # will now send email with attachment

Special Note 1:

  • If you omit:
from wmt2ics.configemail import ConfigEmail as cfg
config = cfg()
config.setup_config(**kwargs)

and simply run

wmt(run_method='email')

the terminal interface will ask you for smtp,port,send,send_pwd,dest. However there are no checks and no history and no way to change what you entered in the terminal, so you will have to run

from wmt2ics.configemail import ConfigEmail as cfg
config = cfg()
config.setup_config(**kwargs)

to overwrite the file.

Special Note 2:

kwargs in setup_config have defaults set:

  • send='smtp.gmail.com'
  • port='587'
  • send_pwd = ''

If you do not include these in the setup_config(**kwargs) and only include

config.setup_config(send='', dest='')

The library will set send='smtp.gmail.com' and port='587' which are gmail settings If you leave send_pwd blank, the library will search for an env variable on your local system named GMAIL_APP_PWD. If you know how to set a persistant env variable on your local machine, this may save you some typing and be slightly more secure. Otherwise, worry not and set send_pwd = 'yourpassword'

'smtp.gmail.com' The SMTP server for the email account used to send the .ics file

'587' The port number for the SMTP server, here, i've placed the port for gmail's smtp

'sender@email.com' Here I use a gmail address to send the email, I created this email account specifically to use as a sender email for this script. You may use whatever you wish.

'password' Gmail supports "app passwords", this is where you will place the app password. if you would rather be slightly more secretive about this, if you leave it blank, the method will attempt to use an environment variable named 'GMAIL_APP_PWD' which you will have to set on your local machine. I set mine in /etc/environment, you'll have to research how to do so on Google for Windows and Mac.

'receiver@email.com' Where you want it to go!

So all that being said, you'll need to get an app password for an email account or use an account that allows using just your sign in password.

Once you run ConfigEmail().setup_config(**kwargs) once, you can comment it out, it will create a json file, if you ever need to change it, you can re-run this method

Test Web Page

a test webpage is available to download Web Test Page

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

Wmt2Ics-0.0.14.tar.gz (7.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

Wmt2Ics-0.0.14-py3-none-any.whl (8.2 kB view details)

Uploaded Python 3

File details

Details for the file Wmt2Ics-0.0.14.tar.gz.

File metadata

  • Download URL: Wmt2Ics-0.0.14.tar.gz
  • Upload date:
  • Size: 7.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.1 pkginfo/1.8.2 requests/2.25.0 requests-toolbelt/0.9.1 tqdm/4.54.1 CPython/3.8.10

File hashes

Hashes for Wmt2Ics-0.0.14.tar.gz
Algorithm Hash digest
SHA256 e688b1a65f6db394c974159f784bf2c0b527eb8aae665607b3eccd2fa0b4dd86
MD5 34b43439d5ad1e8ed621695f12e5134a
BLAKE2b-256 febd59dbc5ada8b02587687ea95298a320bf81e3d5db7727cd377483b93fcfd8

See more details on using hashes here.

File details

Details for the file Wmt2Ics-0.0.14-py3-none-any.whl.

File metadata

  • Download URL: Wmt2Ics-0.0.14-py3-none-any.whl
  • Upload date:
  • Size: 8.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.1 pkginfo/1.8.2 requests/2.25.0 requests-toolbelt/0.9.1 tqdm/4.54.1 CPython/3.8.10

File hashes

Hashes for Wmt2Ics-0.0.14-py3-none-any.whl
Algorithm Hash digest
SHA256 ab4246b8673ba9f79fa35d9597a4257dfedea710f10e593e8e39193377854ed5
MD5 2ea3ed2aafdadd004e3a353f6cffc9bc
BLAKE2b-256 d0e6420d64248eddcf1bb0d85b67f69f1bf9869ef338ec6386684ae5e04a115f

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page