sync: auto-sync from HOWARD-HOME at 2026-06-30 07:56:06

Author: Howard Enos
Machine: HOWARD-HOME
Timestamp: 2026-06-30 07:56:06
This commit is contained in:
2026-06-30 07:56:36 -07:00
parent 5c87b83556
commit 769f099f70
4 changed files with 0 additions and 2342 deletions

View File

@@ -1,43 +0,0 @@
Thelma Abainza t.abainza@cascadestucson.com True
Juan Andrade j.andrade@cascadestucson.com True
Ashli Atwood a.atwood@cascadestucson.com True
Karina Aziakpo k.aziakpo@cascadestucson.com True
Maia Baker m.baker@cascadestucson.com True
Patricia Camarena Doran p.doran@cascadestucson.com True
Sarah Carroll s.carroll@cascadestucson.com True
Niel Castro n.castro@cascadestucson.com False
Jahmeka Clarke j.clarke@cascadestucson.com True
Roseline Cooper r.cooper@cascadestucson.com True
Jinnelle Dittbenner j.dittbenner@cascadestucson.com True
Espe Esperance e.esperance@cascadestucson.com True
Diana Fierros d.fierros@cascadestucson.com True
Richard Flores r.flores@cascadestucson.com True
Kasey Flores k.flores@cascadestucson.com True
Luriz Fuster l.fuster@cascadestucson.com True
Jen Higdon j.higdon@cascadestucson.com True
Luke Hogan l.hogan@cascadestucson.com True
Zeke Huerta e.huerta@cascadestucson.com True
Cole Johnson c.johnson@cascadestucson.com True
Barb Johnson b.johnson@cascadestucson.com True
Mary Kariuki m.kariuki@cascadestucson.com True
1 Thelma Abainza t.abainza@cascadestucson.com True
2 Juan Andrade j.andrade@cascadestucson.com True
3 Ashli Atwood a.atwood@cascadestucson.com True
4 Karina Aziakpo k.aziakpo@cascadestucson.com True
5 Maia Baker m.baker@cascadestucson.com True
6 Patricia Camarena Doran p.doran@cascadestucson.com True
7 Sarah Carroll s.carroll@cascadestucson.com True
8 Niel Castro n.castro@cascadestucson.com False
9 Jahmeka Clarke j.clarke@cascadestucson.com True
10 Roseline Cooper r.cooper@cascadestucson.com True
11 Jinnelle Dittbenner j.dittbenner@cascadestucson.com True
12 Espe Esperance e.esperance@cascadestucson.com True
13 Diana Fierros d.fierros@cascadestucson.com True
14 Richard Flores r.flores@cascadestucson.com True
15 Kasey Flores k.flores@cascadestucson.com True
16 Luriz Fuster l.fuster@cascadestucson.com True
17 Jen Higdon j.higdon@cascadestucson.com True
18 Luke Hogan l.hogan@cascadestucson.com True
19 Zeke Huerta e.huerta@cascadestucson.com True
20 Cole Johnson c.johnson@cascadestucson.com True
21 Barb Johnson b.johnson@cascadestucson.com True
22 Mary Kariuki m.kariuki@cascadestucson.com True
23 Marie Kastner m.kastner@cascadestucson.com True
24 Celia Lassey c.lassey@cascadestucson.com True
25 Tele Sepopo Lassey Assiakoley t.lassey-assiakoley@cascadestucson.com True
26 Monique Lopez m.lopez@cascadestucson.com True
27 Agnes McFerren a.mcferren@cascadestucson.com True
28 Bella Mendoza b.mendoza@cascadestucson.com True
29 Rosa Morales r.morales@cascadestucson.com True
30 Shontiel Nunn s.nunn@cascadestucson.com True
31 Sandra Padilla s.padilla@cascadestucson.com True
32 Samuel Ramirez s.ramirez@cascadestucson.com True
33 Whisper Reed w.reed@cascadestucson.com True
34 Erica Sanchez e.sanchez@cascadestucson.com True
35 Patricia Sandoval-Beck p.sandoval-beck@cascadestucson.com True
36 Charity Sika b.sika@cascadestucson.com True
37 Corey Tate c.tate@cascadestucson.com True
38 Pilot Test pilot.test@cascadestucson.com True
39 Gina Williams g.williams@cascadestucson.com True
40 Gloria Williford g.williford@cascadestucson.com True
41 Katrina Wyzykowski k.wyzykowski@cascadestucson.com True
42 Ederick Yuzon e.yuzon@cascadestucson.com True

View File

@@ -1,91 +0,0 @@
import json, re
def norm(s):
return re.sub(r'[^a-z]', '', (s or '').lower())
alis = json.load(open('.alis_staff.json'))
# ALIS staff: list of dicts
arecs = []
for s in alis:
arecs.append({
'first': s.get('firstName','') or '',
'last': s.get('lastName','') or '',
'nick': s.get('nickName','') or '',
'job': s.get('jobRole') or '(none)',
'status': s.get('status',''),
'email': s.get('primaryEmail') or '',
})
def is_cg(job):
return 'caregiver' in (job or '').lower()
# Load AD caregivers
ad = []
for line in open('.ad_cg.tsv'):
line=line.rstrip('\n')
if not line.strip(): continue
parts=line.split('\t')
if len(parts)<4: continue
gn,sn,upn,en=parts[0],parts[1],parts[2],parts[3]
ad.append({'gn':gn,'sn':sn,'upn':upn,'enabled':en})
def find_alis(gn, sn):
# match by last-name token overlap, then by first name / nickname
ad_last_tokens = set(t for t in norm(sn) and norm(sn).split() or []) # not used
ad_sn = norm(sn); ad_gn = norm(gn)
# try surname tokens
sn_tokens = [norm(t) for t in sn.split() if norm(t)]
cands=[]
for r in arecs:
a_sn = norm(r['last'])
a_sn_tokens=[norm(t) for t in r['last'].split() if norm(t)]
# surname match: any shared token or containment
shared = any(t in a_sn_tokens for t in sn_tokens) or ad_sn==a_sn or ad_sn in a_sn or a_sn in ad_sn
if shared:
cands.append(r)
# disambiguate by first name / nick if multiple
if len(cands)>1:
fn_match=[r for r in cands if norm(r['first'])==ad_gn or norm(r['nick'])==ad_gn or ad_gn in (norm(r['first'])+norm(r['nick'])) ]
if fn_match: return fn_match
return cands
print("=== AD caregiver -> ALIS match ===")
print(f"{'AD NAME':28} {'UPN':40} {'ALIS jobRole':34} {'ALIS status'}")
matched_alis_ids=set()
ad_only=[]; ad_other=[]; ad_cg=[]
for u in ad:
name=f"{u['gn']} {u['sn']}"
if u['upn'].startswith('pilot.test'):
continue
if u['enabled']=='False':
continue
cands=find_alis(u['gn'],u['sn'])
if not cands:
print(f"{name:28} {u['upn']:40} {'-- NOT FOUND IN ALIS (Hired) --':34}")
ad_only.append(name); continue
# pick a caregiver candidate if present else first
cg=[c for c in cands if is_cg(c['job'])]
pick = cg[0] if cg else cands[0]
tag = pick['job']
print(f"{name:28} {u['upn']:40} {tag:34} {pick['status']}")
if is_cg(pick['job']): ad_cg.append(name)
else: ad_other.append((name, pick['job']))
print()
print(f"AD caregivers that ARE ALIS caregivers: {len(ad_cg)}")
print(f"AD caregivers with OTHER ALIS title (ignore per Howard): {len(ad_other)}")
for n,j in ad_other: print(f" {n:28} -> {j}")
print(f"AD caregivers NOT FOUND in ALIS Hired: {len(ad_only)}")
for n in ad_only: print(f" {n}")
# ALIS caregivers with no AD caregiver account
print()
print("=== ALIS caregivers (jobRole~caregiver) with NO AD caregiver account ===")
ad_norm=set(norm(u['sn']).split()[-1] if u['sn'] else '' for u in ad)
ad_last=[norm(t) for u in ad for t in u['sn'].split()]
for r in arecs:
if not is_cg(r['job']): continue
a_tokens=[norm(t) for t in r['last'].split()]
if any(t in ad_last for t in a_tokens):
continue
print(f" {r['first']} {r['last']:22} job={r['job']:34} status={r['status']} email={r['email']}")

File diff suppressed because it is too large Load Diff

View File

@@ -1,11 +0,0 @@
import json, re
def norm(s): return re.sub(r'[^a-z]','',(s or '').lower())
alis=json.load(open('.alis_staff.json'))
none_group=["Atwood","Baker","Fierros","Flores","Hogan","Huerta","Kariuki","Lopez","Mendoza","Reed","Tate","Williford"]
firstmap={"Flores":"Kasey","Fierros":"Diana"} # disambiguate (Richard Flores is Med Tech)
for sn in none_group:
cands=[s for s in alis if norm(sn) in norm(s.get('lastName','')) or norm(s.get('lastName','')) in norm(sn)]
print(f"AD '{sn}':")
if not cands: print(" (no ALIS staff with this surname)")
for c in cands:
print(f" ALIS: {c.get('firstName','')} {c.get('lastName','')} | job={c.get('jobRole') or '(none)'} | status={c.get('status')}")