first push
This commit is contained in:
68
Working/iCal/ical.CAFAC.mpls.py
Normal file
68
Working/iCal/ical.CAFAC.mpls.py
Normal file
@@ -0,0 +1,68 @@
|
||||
import requests, os, sys
|
||||
from icalendar import Calendar as iCalendar, Event
|
||||
|
||||
from datetime import datetime
|
||||
from dateutil import relativedelta
|
||||
td = relativedelta.relativedelta(hours=5)
|
||||
|
||||
from pprint import pprint as ppr
|
||||
import pytz
|
||||
|
||||
import django
|
||||
sys.path.append('../../../../')
|
||||
os.environ['DJANGO_SETTINGS_MODULE'] = 'config.django.local'
|
||||
django.setup()
|
||||
|
||||
from events.models import Event as DSEvent, Organization, Scraper, Calendar
|
||||
import events.digitools as digitools
|
||||
|
||||
from dateutil import relativedelta
|
||||
td = relativedelta.relativedelta(hours=5)
|
||||
|
||||
venue, created = Organization.objects.get_or_create(
|
||||
name="Chicago Ave Fire Arts Center",
|
||||
city="Minneapolis",
|
||||
website="https://www.cafac.org/classes",
|
||||
)
|
||||
event_type = "Ed"
|
||||
|
||||
try:
|
||||
scraper, created = Scraper.objects.get_or_create(
|
||||
name="Chicago Ave Fire Arts Center",
|
||||
website="https://calendar.google.com/calendar/ical/9qj2426rukra3jv933nslsf3r8%40group.calendar.google.com/public/basic.ics",
|
||||
calendar = Calendar.objects.get(id=1),
|
||||
items = 0,
|
||||
new_items = 0,
|
||||
last_ran = datetime.now(),
|
||||
)
|
||||
except Exception as e:
|
||||
print(e)
|
||||
scraper = Scraper.objects.get(name=venue.name)
|
||||
|
||||
item_count_start = scraper.items
|
||||
|
||||
event_type = "Ed"
|
||||
|
||||
objIcalData = requests.get(scraper.website)
|
||||
gcal = iCalendar.from_ical(objIcalData.text)
|
||||
tz = pytz.timezone("US/Central")
|
||||
|
||||
events = digitools.getiCalEvents(gcal, scraper, venue, "Ed")
|
||||
|
||||
for event in events:
|
||||
# ppr(event)
|
||||
e = {}
|
||||
e['calendars'] = event['calendars']
|
||||
try:
|
||||
e['dateStamp'] = event['dateStart'][0]
|
||||
except:
|
||||
e['dateStamp'] = event['dateStart']
|
||||
e['title'] = event['strSummary']
|
||||
e['scraper'] = scraper
|
||||
e['link'] = venue.website
|
||||
try:
|
||||
digitools.createBasicEvent(e, 'Ed', venue)
|
||||
except Exception as e:
|
||||
print("Error: ", e)
|
||||
|
||||
digitools.updateScraper(scraper, item_count_start)
|
||||
146
Working/iCal/ical_ingles.py
Normal file
146
Working/iCal/ical_ingles.py
Normal file
@@ -0,0 +1,146 @@
|
||||
import requests, os, sys
|
||||
from icalendar import Calendar as iCalendar, Event
|
||||
|
||||
from datetime import datetime, timedelta
|
||||
from dateutil import relativedelta
|
||||
td = relativedelta.relativedelta(hours=5)
|
||||
|
||||
from pprint import pprint as ppr
|
||||
import pytz
|
||||
|
||||
import django
|
||||
|
||||
sys.path.append('../../../../')
|
||||
os.environ['DJANGO_SETTINGS_MODULE'] = 'config.django.local'
|
||||
django.setup()
|
||||
|
||||
from config.env import env
|
||||
|
||||
from events.models import Event as DSEvent, Organization, Scraper, Calendar
|
||||
import events.digitools as digitools
|
||||
|
||||
td = relativedelta.relativedelta(hours=5)
|
||||
|
||||
|
||||
venue, created = Organization.objects.get_or_create(
|
||||
name="idioki",
|
||||
city="Medellin",
|
||||
website="https://idioki.com/",
|
||||
)
|
||||
event_type = "Mu"
|
||||
|
||||
try:
|
||||
scraper, created = Scraper.objects.get_or_create(
|
||||
name="idioki",
|
||||
website="https://calendar.google.com/calendar/ical/46ae0446724b1b3ee83cbd7dbc0db6a235bf97509ad860ca91eada3c267b5e41%40group.calendar.google.com/public/basic.ics",
|
||||
calendar = Calendar.objects.get(shortcode='mde'),
|
||||
items = 0,
|
||||
new_items = 0,
|
||||
last_ran = datetime.now(),
|
||||
)
|
||||
except Exception as e:
|
||||
print(e)
|
||||
scraper = Scraper.objects.get(name=venue.name)
|
||||
|
||||
item_count_start = scraper.items
|
||||
objIcalData = requests.get(scraper.website)
|
||||
gcal = iCalendar.from_ical(objIcalData.text)
|
||||
tz = pytz.timezone("US/Central")
|
||||
|
||||
def createEvent(day, date, event, scraper, venue, event_type):
|
||||
ppr(event)
|
||||
print("NAME: ", venue.name)
|
||||
print('\n\n')
|
||||
|
||||
if venue.name == "DANCEFREE":
|
||||
venue.website = "https://www.instagram.com/dancefreeco"
|
||||
if venue.name == "Vintrash":
|
||||
venue.website = "https://www.instagram.com/vintrashbar"
|
||||
if venue.name == "The Wandering Paisa":
|
||||
venue.website = "https://wanderingpaisahostel.com"
|
||||
if venue.name == "Dulce Posion":
|
||||
venue.website = "https://www.instagram.com/dulceposionr"
|
||||
if venue.name == "Blood Dance Company":
|
||||
venue.website = "https://www.instagram.com/blooddancecompany"
|
||||
if venue.name == "OLSA Certified Spanish School":
|
||||
venue.website = "https://www.olsafoundation.org/"
|
||||
if event['strSummary'] == "Merli Rooftop Language Exchange":
|
||||
venue.website = "https://calendar.google.com/calendar/embed?src=46ae0446724b1b3ee83cbd7dbc0db6a235bf97509ad860ca91eada3c267b5e41%40group.calendar.google.com&ctz=America%2FBogota"
|
||||
if "Concious Warrior" in event['strSummary']:
|
||||
venue.website = "https://www.consciouscolombia.com/"
|
||||
# if venue.name == "":
|
||||
# venue.website = "https://www.consciouscolombia.com/"
|
||||
# if venue.name == "":
|
||||
# venue.website = "https://www.consciouscolombia.com/"
|
||||
# if venue.name == "":
|
||||
# venue.website = "https://www.consciouscolombia.com/"
|
||||
venue.save()
|
||||
|
||||
days = [day-1, day+6, day+13]
|
||||
for day in days:
|
||||
event['dateStamp'] = date + timedelta(days=day)
|
||||
event['dateStart'] = event['dateStamp']
|
||||
print("sending")
|
||||
digitools.createCleanIcalEvent(event, scraper, venue, event_type)
|
||||
return
|
||||
|
||||
def splitLocation(event):
|
||||
loc_split = event['strLocation'].split(',')
|
||||
venue_name = loc_split[0]
|
||||
venue, created = Organization.objects.get_or_create(
|
||||
name=venue_name,
|
||||
city="Medellin",
|
||||
)
|
||||
event['venue'] = venue
|
||||
return event
|
||||
|
||||
counter = 0
|
||||
|
||||
for component in gcal.walk():
|
||||
event = {}
|
||||
event['scraper'] = scraper
|
||||
event['calendars'] = [scraper.calendar]
|
||||
event['strSummary'] = f"{(component.get('SUMMARY'))}"
|
||||
event['strDesc'] = component.get('DESCRIPTION')
|
||||
event['strLocation'] = str(component.get('LOCATION'))
|
||||
# startDate = component.get('DTSTART')
|
||||
# startTime = startDate.time()
|
||||
event['dateStart'] = component.get('DTSTART')
|
||||
event['dateStamp'] = component.get('DTSTAMP')
|
||||
|
||||
if event['strSummary'] != 'None':
|
||||
event['details'] = {
|
||||
"description" : event['strDesc'],
|
||||
"Location" : event['strLocation'],
|
||||
}
|
||||
|
||||
if event['dateStamp'] != None:
|
||||
event['dateStart'] = event['dateStart'].dt
|
||||
event['dateStart'] = datetime.strptime(str(event['dateStart'])[:-6], '%Y-%m-%d %H:%M:%S')
|
||||
rules = component.get('RRule')
|
||||
try:
|
||||
if rules['FREQ'][0] == 'WEEKLY':
|
||||
if datetime.today().weekday() != 0:
|
||||
event = splitLocation(event)
|
||||
date = datetime.today().date() - timedelta(days=datetime.today().weekday())
|
||||
date = datetime.combine(date, event['dateStart'].time())
|
||||
days = ["SU", "MO", "TU", "WE", "TH", "FR", "SA"]
|
||||
for day in rules['BYDAY']:
|
||||
day = days.index(day)
|
||||
createEvent(day, date, event, scraper, event['venue'], "Ed")
|
||||
except Exception as e:
|
||||
print("Error: ", e, "\n\n\n\n")
|
||||
pass
|
||||
|
||||
digitools.updateScraper(scraper, item_count_start)
|
||||
|
||||
new_time = datetime.now() - timedelta(days=1)
|
||||
right_bound_time = datetime.now() + timedelta(days=45)
|
||||
events = DSEvent.objects.filter(show_date__lte=new_time)
|
||||
events1 = DSEvent.objects.filter(show_date__gte=right_bound_time)
|
||||
|
||||
for e in events:
|
||||
e.delete()
|
||||
|
||||
for e in events1:
|
||||
e.delete()
|
||||
118
Working/iCal/ical_online_events.py
Normal file
118
Working/iCal/ical_online_events.py
Normal file
@@ -0,0 +1,118 @@
|
||||
import requests, os, sys
|
||||
from icalendar import Calendar as iCalendar, Event
|
||||
|
||||
from datetime import datetime, timedelta
|
||||
from dateutil import relativedelta
|
||||
td = relativedelta.relativedelta(hours=5)
|
||||
|
||||
from pprint import pprint as ppr
|
||||
import pytz
|
||||
|
||||
import django
|
||||
|
||||
sys.path.append('../../../../')
|
||||
os.environ['DJANGO_SETTINGS_MODULE'] = 'config.django.local'
|
||||
django.setup()
|
||||
|
||||
from config.env import env
|
||||
|
||||
from events.models import Event as DSEvent, Organization, Scraper, Calendar
|
||||
import events.digitools as digitools
|
||||
|
||||
td = relativedelta.relativedelta(hours=5)
|
||||
|
||||
|
||||
venue, created = Organization.objects.get_or_create(
|
||||
name="Online Events",
|
||||
city="Online",
|
||||
website="https://dreamfreely.org/",
|
||||
)
|
||||
event_type = "Mu"
|
||||
|
||||
try:
|
||||
scraper, created = Scraper.objects.get_or_create(
|
||||
name="Online Events",
|
||||
website="https://calendar.google.com/calendar/ical/p1a4r9glkjpu4u6iv3fkmu8qtc%40group.calendar.google.com/public/basic.ics",
|
||||
calendar = Calendar.objects.get(shortcode='000'),
|
||||
items = 0,
|
||||
new_items = 0,
|
||||
last_ran = datetime.now(),
|
||||
)
|
||||
except Exception as e:
|
||||
print(e)
|
||||
scraper = Scraper.objects.get(name=venue.name)
|
||||
|
||||
item_count_start = scraper.items
|
||||
objIcalData = requests.get(scraper.website)
|
||||
gcal = iCalendar.from_ical(objIcalData.text)
|
||||
tz = pytz.timezone("US/Central")
|
||||
|
||||
def createEvent(day, date, event, scraper, venue, event_type):
|
||||
days = [day-1, day+6, day+13]
|
||||
for day in days:
|
||||
event['dateStamp'] = date + timedelta(days=day)
|
||||
event['dateStart'] = event['dateStamp']
|
||||
digitools.createCleanIcalEvent(event, scraper, venue, event_type)
|
||||
return
|
||||
|
||||
def splitLocation(event):
|
||||
loc_split = event['strLocation'].split(',')
|
||||
venue_name = loc_split[0]
|
||||
venue, created = Organization.objects.get_or_create(
|
||||
name=venue_name,
|
||||
)
|
||||
event['venue'] = venue
|
||||
return event
|
||||
|
||||
counter = 0
|
||||
|
||||
for component in gcal.walk():
|
||||
event = {}
|
||||
event['scraper'] = scraper
|
||||
event['calendars'] = [scraper.calendar]
|
||||
event['strSummary'] = f"{(component.get('SUMMARY'))}"
|
||||
event['strDesc'] = component.get('DESCRIPTION')
|
||||
event['strLocation'] = str(component.get('LOCATION'))
|
||||
# startDate = component.get('DTSTART')
|
||||
# startTime = startDate.time()
|
||||
event['dateStart'] = component.get('DTSTART')
|
||||
event['dateStamp'] = component.get('DTSTAMP')
|
||||
|
||||
if event['strSummary'] != 'None':
|
||||
event['details'] = {
|
||||
"description" : event['strDesc'],
|
||||
"Location" : event['strLocation'],
|
||||
}
|
||||
if 'Mikel' in event['strSummary']:
|
||||
print('JELLOO \n\n\n JELOOO')
|
||||
pass
|
||||
elif event['dateStamp'] != None:
|
||||
event['dateStart'] = event['dateStart'].dt
|
||||
event['dateStart'] = datetime.strptime(str(event['dateStart'])[:-6], '%Y-%m-%d %H:%M:%S')
|
||||
rules = component.get('RRule')
|
||||
try:
|
||||
if rules['FREQ'][0] == 'WEEKLY':
|
||||
if datetime.today().weekday() != 0:
|
||||
event = splitLocation(event)
|
||||
date = datetime.today().date() - timedelta(days=datetime.today().weekday())
|
||||
date = datetime.combine(date, event['dateStart'].time())
|
||||
days = ["SU", "MO", "TU", "WE", "TH", "FR", "SA"]
|
||||
for day in rules['BYDAY']:
|
||||
day = days.index(day)
|
||||
createEvent(day, date, event, scraper, event['venue'], "Ed")
|
||||
except Exception as e:
|
||||
print("Error (no repeat): ", e)
|
||||
pass
|
||||
|
||||
digitools.updateScraper(scraper, item_count_start)
|
||||
|
||||
new_time = datetime.now() - timedelta(days=1)
|
||||
right_bound_time = datetime.now() + timedelta(days=45)
|
||||
events = DSEvent.objects.filter(show_date__lte=new_time)
|
||||
events1 = DSEvent.objects.filter(show_date__gte=right_bound_time)
|
||||
|
||||
for e in events:
|
||||
e.delete()
|
||||
|
||||
for e in events1:
|
||||
e.delete()
|
||||
65
Working/iCal/ical_run.SocialableCider.mpls.py
Normal file
65
Working/iCal/ical_run.SocialableCider.mpls.py
Normal file
@@ -0,0 +1,65 @@
|
||||
import requests, os, sys
|
||||
from icalendar import Calendar as iCalendar, Event
|
||||
|
||||
from datetime import datetime
|
||||
from dateutil import relativedelta
|
||||
td = relativedelta.relativedelta(hours=5)
|
||||
|
||||
from pprint import pprint as ppr
|
||||
import pytz
|
||||
|
||||
import django
|
||||
sys.path.append('../../../../')
|
||||
os.environ['DJANGO_SETTINGS_MODULE'] = 'config.django.local'
|
||||
django.setup()
|
||||
|
||||
from events.models import Event as DSEvent, Organization, Scraper, Calendar
|
||||
import events.digitools as digitools
|
||||
from dateutil import relativedelta
|
||||
td = relativedelta.relativedelta(hours=5)
|
||||
|
||||
|
||||
venue, created = Organization.objects.get_or_create(
|
||||
name="Sociable Ciderwerks",
|
||||
city="Minneapolis",
|
||||
website="https://sociablecider.com/events",
|
||||
)
|
||||
event_type = "Mu"
|
||||
|
||||
try:
|
||||
scraper, created = Scraper.objects.get_or_create(
|
||||
name="Sociable Ciderwerks",
|
||||
website="https://calendar.google.com/calendar/ical/c_oa7uitvkn871o1ojl5e1os4ve8%40group.calendar.google.com/public/basic.ics",
|
||||
calendar = Calendar.objects.get(id=1),
|
||||
items = 0,
|
||||
new_items = 0,
|
||||
last_ran = datetime.now(),
|
||||
)
|
||||
except Exception as e:
|
||||
print(e)
|
||||
scraper = Scraper.objects.get(name=venue.name)
|
||||
|
||||
item_count_start = scraper.items
|
||||
|
||||
objIcalData = requests.get(scraper.website)
|
||||
gcal = iCalendar.from_ical(objIcalData.text)
|
||||
tz = pytz.timezone("US/Central")
|
||||
events = digitools.getiCalEvents(gcal, scraper, venue, "Ed")
|
||||
|
||||
for event in events:
|
||||
# ppr(event)
|
||||
e = {}
|
||||
e['calendars'] = event['calendars']
|
||||
try:
|
||||
e['dateStamp'] = event['dateStart'][0]
|
||||
except:
|
||||
e['dateStamp'] = event['dateStart']
|
||||
e['title'] = event['strSummary']
|
||||
e['scraper'] = scraper
|
||||
e['link'] = venue.website
|
||||
try:
|
||||
digitools.createBasicEvent(e, 'Mu', venue)
|
||||
except Exception as e:
|
||||
print("Error: ", e)
|
||||
|
||||
digitools.updateScraper(scraper, item_count_start)
|
||||
66
Working/iCal/ical_run.bunkers.py
Normal file
66
Working/iCal/ical_run.bunkers.py
Normal file
@@ -0,0 +1,66 @@
|
||||
import requests, os, sys
|
||||
from icalendar import Calendar as iCalendar, Event
|
||||
|
||||
from pprint import pprint as ppr
|
||||
import pytz
|
||||
|
||||
import django
|
||||
sys.path.append('../../../../')
|
||||
os.environ['DJANGO_SETTINGS_MODULE'] = 'config.django.local'
|
||||
django.setup()
|
||||
|
||||
from events.models import Event as DSEvent, Organization, Scraper, Calendar
|
||||
|
||||
import events.digitools as digitools
|
||||
|
||||
from datetime import datetime
|
||||
from dateutil import relativedelta
|
||||
td = relativedelta.relativedelta(hours=5)
|
||||
|
||||
venue, created = Organization.objects.get_or_create(
|
||||
name="Bunkers",
|
||||
city="Minneapolis",
|
||||
website="https://bunkersmusic.com/calendar/",
|
||||
is_venue = True
|
||||
)
|
||||
|
||||
try:
|
||||
scraper, created = Scraper.objects.get_or_create(
|
||||
name="Bunkers",
|
||||
website="https://calendar.google.com/calendar/ical/js94epu90r2et31aopons1ifm8%40group.calendar.google.com/public/basic.ics",
|
||||
calendar = Calendar.objects.get(id=1),
|
||||
items = 0,
|
||||
new_items = 0,
|
||||
last_ran = datetime.now(),
|
||||
)
|
||||
except Exception as e:
|
||||
print(e)
|
||||
scraper = Scraper.objects.get(name=venue.name)
|
||||
|
||||
item_count_start = scraper.items
|
||||
|
||||
event_type = "Mu"
|
||||
|
||||
objIcalData = requests.get(scraper.website)
|
||||
gcal = iCalendar.from_ical(objIcalData.text)
|
||||
tz = pytz.timezone("US/Central")
|
||||
events = digitools.getiCalEvents(gcal, scraper, venue, "Mu")
|
||||
|
||||
for event in events:
|
||||
# ppr(event)
|
||||
e = {}
|
||||
e['calendars'] = event['calendars']
|
||||
try:
|
||||
e['dateStamp'] = event['dateStart'][0]
|
||||
except:
|
||||
e['dateStamp'] = event['dateStart']
|
||||
e['title'] = event['strSummary']
|
||||
e['scraper'] = scraper
|
||||
e['link'] = venue.website
|
||||
try:
|
||||
digitools.createBasicEvent(e, 'Mu', venue)
|
||||
except Exception as e:
|
||||
print("Error: ", e)
|
||||
|
||||
# digitools.returniCalEvents(gcal, scraper, venue, "Mu")
|
||||
digitools.updateScraper(scraper, item_count_start)
|
||||
93
Working/iCal/ical_run.cfpa.py
Normal file
93
Working/iCal/ical_run.cfpa.py
Normal file
@@ -0,0 +1,93 @@
|
||||
import requests, os, sys
|
||||
from icalendar import Calendar as iCalendar, Event
|
||||
|
||||
from datetime import datetime
|
||||
from dateutil import relativedelta
|
||||
|
||||
from pprint import pprint as ppr
|
||||
import pytz
|
||||
|
||||
import django
|
||||
sys.path.append('../../../../')
|
||||
os.environ['DJANGO_SETTINGS_MODULE'] = 'config.django.local'
|
||||
django.setup()
|
||||
|
||||
from events.models import Event as DSEvent, Organization, Scraper, Calendar
|
||||
import events.digitools as digitools
|
||||
|
||||
tz = pytz.timezone("US/Central")
|
||||
td = relativedelta.relativedelta(hours=5)
|
||||
|
||||
venue, created = Organization.objects.get_or_create(
|
||||
name="Center for Performing Arts",
|
||||
city="Minneapolis",
|
||||
website="https://www.cfpampls.com/events",
|
||||
)
|
||||
|
||||
try:
|
||||
scraper, created = Scraper.objects.get_or_create(
|
||||
name="Center for Performing Arts",
|
||||
website="https://calendar.google.com/calendar/ical/6rpooudjg01vc8bjek1snu2ro0%40group.calendar.google.com/public/basic.ics",
|
||||
calendar = Calendar.objects.get(id=1),
|
||||
items = 0,
|
||||
new_items = 0,
|
||||
last_ran = datetime.now(),
|
||||
)
|
||||
except Exception as e:
|
||||
print(e)
|
||||
scraper = Scraper.objects.get(name=venue.name)
|
||||
|
||||
item_count_start = scraper.items
|
||||
|
||||
event_type = "Ed"
|
||||
|
||||
objIcalData = requests.get(scraper.website)
|
||||
gcal = iCalendar.from_ical(objIcalData.text)
|
||||
tz = pytz.timezone("US/Central")
|
||||
|
||||
events = digitools.getiCalEvents(gcal, scraper, venue, "Ed")
|
||||
|
||||
for event in events:
|
||||
ppr(event)
|
||||
e = {}
|
||||
e['calendars'] = event['calendars']
|
||||
try:
|
||||
e['dateStamp'] = event['dateStart'][0]
|
||||
except:
|
||||
e['dateStamp'] = event['dateStart']
|
||||
e['title'] = event['strSummary']
|
||||
e['scraper'] = scraper
|
||||
e['link'] = venue.website
|
||||
try:
|
||||
digitools.createBasicEvent(e, 'Ed', venue)
|
||||
except Exception as e:
|
||||
print("Error: ", e)
|
||||
|
||||
|
||||
# now_now = datetime.today().date()
|
||||
# try:
|
||||
# print("1Event: ", event['dateStart'])
|
||||
# if event['dateStart'] > now_now:
|
||||
# print("Check Check: ", event['dateStart'])
|
||||
# ppr(event)
|
||||
# # createIcalEvent(event, scraper, venue, event_type)
|
||||
# else:
|
||||
# print("WHAT?")
|
||||
# ppr(event)
|
||||
# except Exception as e:
|
||||
# try:
|
||||
# event['dateStart'] = event['dateStart'].date()
|
||||
# print("2Event: ", event['dateStart'])
|
||||
# if event['dateStart'] > now_now:
|
||||
# print("Check Check: ", event['dateStart'])
|
||||
# ppr(event)
|
||||
# # createIcalEvent(event, scraper, venue, event_type)
|
||||
# else:
|
||||
# print("WHAT?")
|
||||
# ppr(event)
|
||||
# except Exception as e:
|
||||
# print("The Error: ", e)
|
||||
# pass
|
||||
|
||||
|
||||
digitools.updateScraper(scraper, item_count_start)
|
||||
63
Working/iCal/ical_run.eagles.py
Normal file
63
Working/iCal/ical_run.eagles.py
Normal file
@@ -0,0 +1,63 @@
|
||||
import requests, os, sys
|
||||
from icalendar import Calendar as iCalendar, Event
|
||||
from datetime import datetime
|
||||
|
||||
from pprint import pprint as ppr
|
||||
import pytz
|
||||
|
||||
import django
|
||||
sys.path.append('../../../../')
|
||||
os.environ['DJANGO_SETTINGS_MODULE'] = 'config.django.local'
|
||||
django.setup()
|
||||
|
||||
from events.models import Event as DSEvent, Organization, Scraper, Calendar
|
||||
import events.digitools as digitools
|
||||
|
||||
from dateutil import relativedelta
|
||||
td = relativedelta.relativedelta(hours=5)
|
||||
|
||||
venue, created = Organization.objects.get_or_create(
|
||||
name="Eagles #34",
|
||||
city="Minneapolis",
|
||||
website="https://www.minneapoliseagles34.org/events-entertainment.html",
|
||||
)
|
||||
|
||||
try:
|
||||
scraper, created = Scraper.objects.get_or_create(
|
||||
name="Eagles #34",
|
||||
website="https://calendar.google.com/calendar/ical/teflgutelllvla7r6vfcmjdjjo%40group.calendar.google.com/public/basic.ics",
|
||||
calendar = Calendar.objects.get(id=1),
|
||||
items = 0,
|
||||
new_items = 0,
|
||||
last_ran = datetime.now(),
|
||||
)
|
||||
except Exception as e:
|
||||
print(e)
|
||||
scraper = Scraper.objects.get(name=venue.name)
|
||||
|
||||
item_count_start = scraper.items
|
||||
|
||||
event_type = "Mu"
|
||||
|
||||
objIcalData = requests.get(scraper.website)
|
||||
gcal = iCalendar.from_ical(objIcalData.text)
|
||||
tz = pytz.timezone("US/Central")
|
||||
events = digitools.getiCalEvents(gcal, scraper, venue, "Ed")
|
||||
|
||||
for event in events:
|
||||
ppr(event)
|
||||
e = {}
|
||||
e['calendars'] = event['calendars']
|
||||
try:
|
||||
e['dateStamp'] = event['dateStart'][0]
|
||||
except:
|
||||
e['dateStamp'] = event['dateStart']
|
||||
e['title'] = event['strSummary']
|
||||
e['scraper'] = scraper
|
||||
e['link'] = venue.website
|
||||
try:
|
||||
digitools.createBasicEvent(e, 'Mu', venue)
|
||||
except Exception as e:
|
||||
print("Error: ", e)
|
||||
|
||||
digitools.updateScraper(scraper, item_count_start)
|
||||
67
Working/iCal/ical_run.terminalbar-mpls.py
Normal file
67
Working/iCal/ical_run.terminalbar-mpls.py
Normal file
@@ -0,0 +1,67 @@
|
||||
import requests, os, sys
|
||||
from icalendar import Calendar as iCalendar, Event
|
||||
from datetime import datetime
|
||||
from dateutil import relativedelta
|
||||
td = relativedelta.relativedelta(hours=5)
|
||||
|
||||
from pprint import pprint as ppr
|
||||
import pytz
|
||||
|
||||
import django
|
||||
sys.path.append('../../../../')
|
||||
os.environ['DJANGO_SETTINGS_MODULE'] = 'config.django.local'
|
||||
django.setup()
|
||||
|
||||
from events.models import Event as DSEvent, Organization, Scraper, Calendar
|
||||
|
||||
import events.digitools as digitools
|
||||
|
||||
td = relativedelta.relativedelta(hours=5)
|
||||
odt = datetime.now() + td
|
||||
|
||||
venue, created = Organization.objects.get_or_create(
|
||||
name="Terminal Bar",
|
||||
city="Minneapolis",
|
||||
website="https://terminalbarmn.com",
|
||||
)
|
||||
event_type = "Mu"
|
||||
|
||||
try:
|
||||
scraper, created = Scraper.objects.get_or_create(
|
||||
name="Terminal Bar",
|
||||
website="https://calendar.google.com/calendar/ical/terminalbar32%40gmail.com/public/basic.ics",
|
||||
calendar = Calendar.objects.get(id=1),
|
||||
items = 0,
|
||||
new_items = 0,
|
||||
last_ran = datetime.now(),
|
||||
)
|
||||
except Exception as e:
|
||||
print(e)
|
||||
scraper = Scraper.objects.get(name=venue.name)
|
||||
|
||||
item_count_start = scraper.items
|
||||
|
||||
event_type = "Mu"
|
||||
|
||||
objIcalData = requests.get(scraper.website)
|
||||
gcal = iCalendar.from_ical(objIcalData.text)
|
||||
tz = pytz.timezone("US/Central")
|
||||
events = digitools.getiCalEvents(gcal, scraper, venue, "Ed")
|
||||
|
||||
for event in events:
|
||||
# ppr(event)
|
||||
e = {}
|
||||
e['calendars'] = event['calendars']
|
||||
try:
|
||||
e['dateStamp'] = event['dateStart'][0]
|
||||
except:
|
||||
e['dateStamp'] = event['dateStart']
|
||||
e['title'] = event['strSummary']
|
||||
e['scraper'] = scraper
|
||||
e['link'] = venue.website
|
||||
try:
|
||||
digitools.createBasicEvent(e, 'Mu', venue)
|
||||
except Exception as e:
|
||||
print("Error: ", e)
|
||||
|
||||
digitools.updateScraper(scraper, item_count_start)
|
||||
69
Working/iCal/ical_run.whitesquirrel.py
Normal file
69
Working/iCal/ical_run.whitesquirrel.py
Normal file
@@ -0,0 +1,69 @@
|
||||
import requests, os, sys
|
||||
# from icalendar import Calendar as iCalendar, Event
|
||||
from icalendar import Calendar as iCalendar
|
||||
from datetime import datetime
|
||||
from dateutil import relativedelta
|
||||
td = relativedelta.relativedelta(hours=5)
|
||||
|
||||
from pprint import pprint as ppr
|
||||
import pytz
|
||||
|
||||
import django
|
||||
sys.path.append('../../../../')
|
||||
os.environ['DJANGO_SETTINGS_MODULE'] = 'config.django.local'
|
||||
django.setup()
|
||||
|
||||
from events.models import Event as DSEvent, Organization, Scraper, Calendar
|
||||
import events.digitools as digitools
|
||||
|
||||
from dateutil import relativedelta
|
||||
td = relativedelta.relativedelta(hours=5)
|
||||
|
||||
tz = pytz.timezone("US/Central")
|
||||
DATETIME_FORMAT = '%Y-%m-%d %I:%M %p'
|
||||
|
||||
venue, created = Organization.objects.get_or_create(
|
||||
name="White Squirrel",
|
||||
city="St. Paul",
|
||||
website="https://whitesquirrelbar.com",
|
||||
is_venue = True
|
||||
)
|
||||
|
||||
try:
|
||||
scraper, created = Scraper.objects.get_or_create(
|
||||
name="White Squirrel",
|
||||
website="https://calendar.google.com/calendar/ical/vh5sr9h59nmrs2op5lmptu2fsa344cig%40import.calendar.google.com/public/basic.ics",
|
||||
calendar = Calendar.objects.get(shortcode='msp'),
|
||||
items = 0,
|
||||
new_items = 0,
|
||||
last_ran = datetime.now(),
|
||||
)
|
||||
except Exception as e:
|
||||
print(e)
|
||||
scraper = Scraper.objects.get(name=venue.name)
|
||||
|
||||
item_count_start = scraper.items
|
||||
event_type = "Mu"
|
||||
|
||||
objIcalData = requests.get(scraper.website)
|
||||
gcal = iCalendar.from_ical(objIcalData.content)
|
||||
tz = pytz.timezone("US/Central")
|
||||
events = digitools.getiCalEvents(gcal, scraper, venue, event_type)
|
||||
|
||||
for event in events:
|
||||
ppr(event)
|
||||
e = {}
|
||||
e['calendars'] = event['calendars']
|
||||
try:
|
||||
e['dateStamp'] = event['dateStart'][0]
|
||||
except:
|
||||
e['dateStamp'] = event['dateStart']
|
||||
e['title'] = event['strSummary']
|
||||
e['scraper'] = scraper
|
||||
e['link'] = venue.website
|
||||
try:
|
||||
digitools.createBasicEvent(e, event_type, venue)
|
||||
except Exception as e:
|
||||
print("Error: ", e)
|
||||
|
||||
digitools.updateScraper(scraper, item_count_start)
|
||||
388
Working/iCal/index.html
Normal file
388
Working/iCal/index.html
Normal file
File diff suppressed because one or more lines are too long
498
Working/iCal/ws.ics
Normal file
498
Working/iCal/ws.ics
Normal file
@@ -0,0 +1,498 @@
|
||||
BEGIN:VCALENDAR
|
||||
PRODID:-//Google Inc//Google Calendar 70.9054//EN
|
||||
VERSION:2.0
|
||||
CALSCALE:GREGORIAN
|
||||
METHOD:PUBLISH
|
||||
X-WR-CALNAME:The White Squirrel Bar
|
||||
X-WR-TIMEZONE:UTC
|
||||
X-WR-CALDESC:Events for The White Squirrel Bar
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251118T030000Z
|
||||
DTEND:20251118T060000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:10806-1763413200-1763424000@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/the-deeper-kind-w-23-watts/
|
||||
CREATED:20251104T233617Z
|
||||
LAST-MODIFIED:20251105T053618Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:The Deeper Kind w. 23 Watts
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251129T000000Z
|
||||
DTEND:20251129T020000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:10852-1764352800-1764360000@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/the-mary-cutrufello-band-3/
|
||||
CREATED:20251115T173617Z
|
||||
DESCRIPTION:A rock and roll band! Killer harmonies\, rippin’ solos\, cool s
|
||||
ongs\, funny\nshit in between. \nHailed as a country guitarist\, Mary Cutru
|
||||
fello grew up on East Coast\nclassic rock. (Yes\, think Springsteen!) This
|
||||
tight\, taut trio explores\nher songs old and new with the fearless guitars
|
||||
\, stories\, and\nbetween-song banter she’s known for.
|
||||
LAST-MODIFIED:20251115T233617Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:The Mary Cutrufello Band
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251117T030000Z
|
||||
DTEND:20251117T060000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:10802-1763326800-1763337600@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/karaoke-with-ally/
|
||||
CREATED:20251103T163617Z
|
||||
LAST-MODIFIED:20251103T223619Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:Karaoke With Ally!
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251127T000000Z
|
||||
DTEND:20251127T020000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:10846-1764180000-1764187200@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/family-dinner-w-doug-sarah-4/
|
||||
CREATED:20251115T013617Z
|
||||
LAST-MODIFIED:20251115T073617Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:Family Dinner w. Doug & Sarah
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251116T190000Z
|
||||
DTEND:20251116T220000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:10147-1763298000-1763308800@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/the-friend-ship/
|
||||
CREATED:20251103T003616Z
|
||||
DESCRIPTION:These popular singer/songwriters first got together to perform
|
||||
on Joel Sax’s debut\nalbum\, ‘Billions of Stars.’ They had so much fun and
|
||||
got such a great response at their\nsold-out release show that they have jo
|
||||
ined together to form a new band\, The Friend\nShip! They will bring their
|
||||
best songs\, sweetest harmonies\, and funniest stories to the\nWhite Squirr
|
||||
el for a night of beautiful music. \nNikki Lemire is an incredibly in deman
|
||||
d artist\, having earned accolades from fans and critics\nalike. Natalia To
|
||||
ledo\, from The Current describes ‘Mend’ It as “a dreamy\, simple\, and\nbe
|
||||
autiful song led by the sounds of her harp.”\nJoel Sax writes heartfelt son
|
||||
gs about love\, regret\, and hope for a bigger\, brighter future.\nHis debu
|
||||
t album title track\, Billions of Stars\, is “… a wonderful mix for a conte
|
||||
mporary\nfolk song” – Minnesota Sound and ‘A Lovely New Album\,’ by Mostly
|
||||
Minnesota\nMusic. \nMarc Severin has been a mainstay of the music scene for
|
||||
many years. His music is\ntrue Americana and his storytelling is midwester
|
||||
n country at its best. The Friend Ship\nwill be previewing songs from his w
|
||||
ell anticipated new album coming out this Winter. \nDave Mehling is a highl
|
||||
y sought-after musician\, producer and songwriter. He has\nproduced albums
|
||||
for many artists\, including Sarah Morris\, Haley E Rydell\, Joel Sax and\n
|
||||
Emily Haavik. “You are drawn in with his lyrics. They speak of very univers
|
||||
al issues of\nlove which we all have\, but few of us have the talent to giv
|
||||
e them a voice. Dave Mehling\npossesses this rare gift.” – Becca Martin
|
||||
LAST-MODIFIED:20251103T063617Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:The Friend Ship
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251123T000000Z
|
||||
DTEND:20251123T020000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:10827-1763834400-1763841600@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/giant-valley-string-band/
|
||||
CREATED:20251109T183617Z
|
||||
DESCRIPTION:Giant Valley String Band is a Twin Cities acoustic group playin
|
||||
g an\neclectic mix of covers and originals in Bluegrass and Americana. The\
|
||||
nband members are Noelle Haland on guitar\, Ted Haland on dobro and\nbass\,
|
||||
Nate Hess on fiddle and guitar\, Erika Janik on banjo\, Matt\nJensen on ma
|
||||
ndolin\, and Debra Pflipsen on guitar\, harmonica\,\naccordion\, and bass.
|
||||
More info at giantvalleystringband.com. \n\n\n\n\nBlue Groove is a multiple
|
||||
award-winning bluegrass band based in the\nTwin Cities that plays both con
|
||||
temporary and classic bluegrass tunes\nwith a creative approach that drives
|
||||
while still maintaining a sense\nof laid-back\, Midwestern chill. That’s w
|
||||
hat they mean by “groove”. The\nbands inviting sound combined with their op
|
||||
enness warmth on and\noff-stage have made them crowd favorites at festivals
|
||||
and concert\nvenues all around Minnesota and the Upper Midwest. \nThe band
|
||||
covers a number of past and current contemporary bluegrass\nartists. A Blu
|
||||
e Groove show may feature songs from Alison Krauss or\nRhonda Vincent as we
|
||||
ll as traditional bluegrass (Bill Monroe\, Flatt &\nScruggs) with all of it
|
||||
s drive\, improvisation and harmony singing!\nBlue Groove also likes to put
|
||||
a bluegrass spin on more\ncontemporary/pop artists such as U2\, Passenger\
|
||||
, and the Doobie\nBrothers! \nMembers of Blue Groove bluegrass band include
|
||||
Adelle Hyrkas\, lead\nvocals and rhythm guitar\; David Smith\, banjo and v
|
||||
ocals\; Bob Doe\, lead\nguitar\, dobro\, and vocals\; Pete Mathison bass an
|
||||
d vocals\, Tom\nWadzinski mandolin and vocals. Ocassionally we may have a g
|
||||
uest\nfiddler- past guests have included fiddlers Richard Kriehn\, Michael\
|
||||
nPrewitt\, and AJ Srubas. \nYou can find out more about Blue Groove at www.
|
||||
bluegroovebluegrass.com
|
||||
LAST-MODIFIED:20251110T003617Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:Giant Valley String Band w. Blue Groove
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251121T220000Z
|
||||
DTEND:20251122T040000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:11255-1763740800-1763762400@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/the-angry-line-cook-4/
|
||||
CREATED:20251114T133616Z
|
||||
DESCRIPTION:The Best Smash Burgers in town!
|
||||
LAST-MODIFIED:20251114T193617Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:The Angry Line Cook
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251127T030000Z
|
||||
DTEND:20251127T060000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:10848-1764190800-1764201600@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/nights-with-tim-2/
|
||||
CREATED:20251115T013617Z
|
||||
DESCRIPTION:Dig into the deeper\, progressive side of disco\, funk\, and R&
|
||||
B from the ’70s and ’80s\, with the occasional turn into house and left-fie
|
||||
ld gems. An all vinyl night courtesy of local selector Tim. He knows how to
|
||||
keep the vibes at White Squirrel curious and moving.
|
||||
LAST-MODIFIED:20251115T073617Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:Nights with Tim
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251122T190000Z
|
||||
DTEND:20251122T220000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:10825-1763816400-1763827200@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/caitlin-robertson/
|
||||
CREATED:20251109T023617Z
|
||||
LAST-MODIFIED:20251109T083618Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:Caitlin Robertson
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251128T220000Z
|
||||
DTEND:20251129T040000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:11257-1764345600-1764367200@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/the-angry-line-cook-5/
|
||||
CREATED:20251115T013617Z
|
||||
DESCRIPTION:The Best Smash Burgers in town!
|
||||
LAST-MODIFIED:20251115T073617Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:The Angry Line Cook
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251122T000000Z
|
||||
DTEND:20251122T020000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:10821-1763748000-1763755200@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/chris-holm-friends-2/
|
||||
CREATED:20251108T203618Z
|
||||
LAST-MODIFIED:20251109T023619Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:Chris Holm & Friends
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251123T030000Z
|
||||
DTEND:20251123T060000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:10829-1763845200-1763856000@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/13-howell/
|
||||
CREATED:20251110T003617Z
|
||||
LAST-MODIFIED:20251110T063617Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:13 Howell w. Steph Was & The Secret Izz\, TH3
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251120T000000Z
|
||||
DTEND:20251120T020000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:10813-1763575200-1763582400@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/st-paul-mudsteppers-4/
|
||||
CREATED:20251107T033617Z
|
||||
LAST-MODIFIED:20251107T093617Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:St Paul Mudsteppers
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251116T000000Z
|
||||
DTEND:20251116T020000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:10819-1763229600-1763236800@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/in-circles-sunny-day-real-estate-tri
|
||||
bute-w-120-minutes/
|
||||
CREATED:20251102T013616Z
|
||||
DESCRIPTION:It’s the 30th anniversary of Sunny Day Real Estates LP2 record!
|
||||
In Circles with be performing the album in its entirety. \n
|
||||
LAST-MODIFIED:20251102T063617Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:In Circles (Sunny Day Real Estate Tribute) w. 120 Minutes
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251124T000000Z
|
||||
DTEND:20251124T020000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:10833-1763920800-1763928000@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/the-jeff-becker-band/
|
||||
CREATED:20251110T223617Z
|
||||
LAST-MODIFIED:20251111T043617Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:The Jeff Becker Band
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251122T030000Z
|
||||
DTEND:20251122T060000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:10823-1763758800-1763769600@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/ancient-waves-2/
|
||||
CREATED:20251108T203618Z
|
||||
LAST-MODIFIED:20251109T023619Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:Ancient Waves w. Muun Batos & Jarad Miles
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251121T000000Z
|
||||
DTEND:20251121T020000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:10815-1763661600-1763668800@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/devaney-friends-2/
|
||||
CREATED:20251107T223617Z
|
||||
LAST-MODIFIED:20251108T043617Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:Devaney & Friends w. Aaron James
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251121T030000Z
|
||||
DTEND:20251121T060000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:10817-1763672400-1763683200@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/country-oke-3/
|
||||
CREATED:20251108T043618Z
|
||||
LAST-MODIFIED:20251108T103619Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:Country-oke
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251124T030000Z
|
||||
DTEND:20251124T060000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:10835-1763931600-1763942400@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/bryan-the-haggards/
|
||||
CREATED:20251111T043617Z
|
||||
LAST-MODIFIED:20251111T103617Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:Bryan & The Haggards w. Jump Loop\, The American Songbook
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251125T030000Z
|
||||
DTEND:20251125T060000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:10839-1764018000-1764028800@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/seven-seasons/
|
||||
CREATED:20251112T013616Z
|
||||
LAST-MODIFIED:20251112T073617Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:Slasher Film
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251126T030000Z
|
||||
DTEND:20251126T060000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:10841-1764104400-1764115200@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/third-date-tuesday-night-residency-2
|
||||
/
|
||||
CREATED:20251113T053616Z
|
||||
LAST-MODIFIED:20251113T113617Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:Third Date Tuesday Night Residency
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251117T000000Z
|
||||
DTEND:20251117T020000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:10800-1763316000-1763323200@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/bingo-with-pete-3/
|
||||
CREATED:20251103T003616Z
|
||||
LAST-MODIFIED:20251103T063617Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:Bingo With Pete!
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251125T000000Z
|
||||
DTEND:20251125T020000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:10837-1764007200-1764014400@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/devil-dodger/
|
||||
CREATED:20251111T203617Z
|
||||
LAST-MODIFIED:20251112T023617Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:Devil Dodger
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251126T000000Z
|
||||
DTEND:20251126T020000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:10843-1764093600-1764100800@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/ali-grays-country-jamboree-2/
|
||||
CREATED:20251112T233616Z
|
||||
DESCRIPTION:Come on out for a tribute to the Darlings of Country music\, fe
|
||||
aturing Ali Gray’s Country Jamboree! Hear songs from the catalogs of Lorett
|
||||
a Lynn\, Tammy Wynette\, Tanya Tucker\, Dolly Parton\, Linda Ronstadt\, Pam
|
||||
Tillis\, Patty Loveless and many more. We won’t leave out the Kings of Cou
|
||||
ntry\, sung by guitar legend Dan Neale and drummer extraordinaire Scott Wen
|
||||
um\, including favorites like Roger Miller\, Hank Williams\, Johnny Cash\,
|
||||
Buck Owens\, Waylon Jennings and more! Also featuring Dan Lowinger on bass
|
||||
! 6-8.
|
||||
LAST-MODIFIED:20251113T053616Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:Ali Gray's Country Jamboree
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251116T030000Z
|
||||
DTEND:20251116T060000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:10798-1763240400-1763251200@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/lost-island-society-w-woolly-mack-po
|
||||
ison-ivy-the-people/
|
||||
CREATED:20251102T183617Z
|
||||
LAST-MODIFIED:20251103T003617Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:Lost Island Society w. Woolly Mack\, Poison Ivy & The People
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251123T190000Z
|
||||
DTEND:20251123T220000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:10831-1763902800-1763913600@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/the-stress-of-her-regard/
|
||||
CREATED:20251110T003617Z
|
||||
LAST-MODIFIED:20251110T063617Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:The Stress Of Her Regard
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251119T030000Z
|
||||
DTEND:20251119T060000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:10811-1763499600-1763510400@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/third-date-tuesday-night-residency/
|
||||
CREATED:20251106T213618Z
|
||||
LAST-MODIFIED:20251107T033618Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:Third Date Tuesday Night Residency
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251119T000000Z
|
||||
DTEND:20251119T020000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:10809-1763488800-1763496000@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/the-new-havoline-supremes/
|
||||
CREATED:20251105T053616Z
|
||||
DESCRIPTION:The New Havoline Supremes are a Twin Cities based band\, featu
|
||||
ring the legendary Mary Cutrufello on guitar and vocals\, and Dan Lowinger
|
||||
on guitar. Formed in October of 2023\, the band plays a mix of classic cou
|
||||
ntry and Mary’s original tunes\, and features Greg Schutte (Ryan Bingham\,
|
||||
Mickey Hart\, Chasity Brown) on drums\, and Erik Lillestol (Cafe Accordion)
|
||||
on bass.\n\nMary Cutrufello\n\nWith 30 years of experience in the music bu
|
||||
siness\, Mary Cutrufello is everything from Texas honky-tonk heroine and fi
|
||||
ery Midwestern roots-rocker to a powerhouse acoustic performer. Connecticut
|
||||
-raised and Yale-educated\, Mary’s musical journey has taken her from the E
|
||||
ast Coast to Houston and now to Minnesota. Career highlights include: the
|
||||
major label release of ”When the Night is Through\,” on Mercury Records
|
||||
in 1998\, appearances on national tv shows such as Tonight Show with Jay Le
|
||||
no\, appearances at major festivals including Farm Aid\, and tours with Jim
|
||||
mie Dale Gilmore and Tish Hinojosa. Mary has seven self-released albums\,
|
||||
and has played guitar locally for Annie Mack\, Michael Perry and the Long B
|
||||
eds\, and many others.\n\n\n\nDan Lowinger\, a transplant from Portland\, O
|
||||
R\, is a guitarist steeped in the tradition of Western swing and classic co
|
||||
untry. Since moving to the Twin Cities in 2017\, Dan has become a fixture i
|
||||
n the local country and Americana scene\, playing on a regular basis with a
|
||||
ll star Western swing band Honky Tonk Jump\, and country rockers Cole Diamo
|
||||
nd\, while also sharing the stage with local greats\, Martin Zellar (Gear D
|
||||
addies)\, Tony Andreason (The Trashmen)\, Pat Donohue (Prairie Home Compani
|
||||
on) and many others! He has performed regionally and toured nationally with
|
||||
many different country and swing bands from the Pacific Northwest includin
|
||||
g: The Barn Door Slammers\, Ralph Carney’s Pepper Grinders\, Vince Mira\, a
|
||||
nd Western Centuries.
|
||||
LAST-MODIFIED:20251105T113617Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:The New Havoline Supremes
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251120T030000Z
|
||||
DTEND:20251120T060000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:10782-1763586000-1763596800@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/venturer-w-peeler-mild-manner/
|
||||
CREATED:20251107T223617Z
|
||||
DESCRIPTION:Venturer is a rock based band with many other genre influences
|
||||
such as funk\, folk\, prog\, punk\, and jazz. Venturer has played around th
|
||||
e United States\, mainly in Milwaukee\, Madison\, Chicago\, and Minneapolis
|
||||
\, but also on the East Coast and greater Midwest.
|
||||
LAST-MODIFIED:20251108T043617Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:Venturer w. Peeler & Mild Manner
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
BEGIN:VEVENT
|
||||
DTSTART:20251118T000000Z
|
||||
DTEND:20251118T020000Z
|
||||
DTSTAMP:20251116T033816Z
|
||||
UID:10804-1763402400-1763409600@whitesquirrelbar.com
|
||||
URL:https://whitesquirrelbar.com/event/clovers-daughter/
|
||||
CREATED:20251103T223616Z
|
||||
LAST-MODIFIED:20251104T043617Z
|
||||
SEQUENCE:0
|
||||
STATUS:CONFIRMED
|
||||
SUMMARY:Clovers Daughter
|
||||
TRANSP:OPAQUE
|
||||
END:VEVENT
|
||||
END:VCALENDAR
|
||||
Reference in New Issue
Block a user