System

Change Log

Audit trail of every save, delete, import, and workflow update across the backend.

Total Changes1,029
Today0
Latest 2026-05-09 20:12
Reset

1,029 results · Page 16 of 21

cust_email · send_email
2026-04-21 13:13:35 · anonymous
review_request #4
Context
[]
Before
[]
Changed Data
{"customer_id":200481,"visit_id":34954,"email":"aodonahoe@gmail.com","status":"sent","delivery_result":"Sent via SMTP (PHPMailer)"}
cust_email · mark_sent
2026-04-21 13:13:23 · anonymous
review_request #3
Context
[]
Before
[]
Changed Data
{"customer_id":148003,"visit_id":22301,"email":"kimberlymatt2017@gmail.com","status":"sent"}
live_table_manager · update
2026-04-20 16:37:23 · anonymous
customer_payment_transactions #6112
Context
[]
Before
{"customer_payment_transaction_id":"6112","payment_id":"64091","order_id":"104165","visit_id":"129412","customer_id":"148006","customer_name":"Alison Belletete","transaction_date":"2026-04-20 00:00:00","payment_method":"Cash","payment_type":"Deposit","bucket":"cash","amount":"100.00","tip_amount":"0.00","is_new_customer":"0","source":"payments","created_at":"2026-04-20 16:35:33","updated_at":"2026-04-20 16:35:33"}
Changed Data
{"customer_payment_transaction_id":"6112","payment_id":"64091","order_id":"104165","visit_id":"129412","customer_id":"148006","customer_name":"Alison Belletete","transaction_date":"2026-04-20 00:00:00","payment_method":"Cash","payment_type":"Payment","bucket":"cash","amount":"270.00","tip_amount":"0.00","is_new_customer":"0","source":"payments","created_at":"2026-04-20 16:35:00","updated_at":"2026-04-20 16:35:00"}
live_table_manager · delete
2026-04-20 16:36:50 · anonymous
customer_payment_transactions #6113
Context
[]
Before
{"customer_payment_transaction_id":"6113","payment_id":"64092","order_id":"104165","visit_id":"129412","customer_id":"148006","customer_name":"Alison Belletete","transaction_date":"2026-04-20 00:00:00","payment_method":"Cash","payment_type":"Balance","bucket":"cash","amount":"270.00","tip_amount":"0.00","is_new_customer":"0","source":"payments","created_at":"2026-04-20 16:35:33","updated_at":"2026-04-20 16:35:33"}
Changed Data
{"deleted":true}
live_table_manager · delete
2026-04-20 16:36:44 · anonymous
customer_payment_transactions #6114
Context
[]
Before
{"customer_payment_transaction_id":"6114","payment_id":"64093","order_id":"104165","visit_id":"129412","customer_id":"148006","customer_name":"Alison Belletete","transaction_date":"2026-04-20 00:00:00","payment_method":"Cash","payment_type":"Tip","bucket":"tip","amount":"69.20","tip_amount":"69.20","is_new_customer":"0","source":"payments","created_at":"2026-04-20 16:35:33","updated_at":"2026-04-20 16:35:33"}
Changed Data
{"deleted":true}
live_table_manager · update
2026-04-20 16:36:35 · anonymous
customer_payment_transactions #6115
Context
[]
Before
{"customer_payment_transaction_id":"6115","payment_id":"64094","order_id":"104165","visit_id":"129412","customer_id":"148006","customer_name":"Alison Belletete","transaction_date":"2026-04-20 00:00:00","payment_method":"Cash","payment_type":"Deposit","bucket":"cash","amount":"170.00","tip_amount":"0.00","is_new_customer":"0","source":"payments","created_at":"2026-04-20 16:35:33","updated_at":"2026-04-20 16:35:33"}
Changed Data
{"customer_payment_transaction_id":"6115","payment_id":"64094","order_id":"104165","visit_id":"129412","customer_id":"148006","customer_name":"Alison Belletete","transaction_date":"2026-04-20 00:00:00","payment_method":"Cash","payment_type":"Deposit","bucket":"cash","amount":"100.00","tip_amount":"0.00","is_new_customer":"0","source":"payments","created_at":"2026-04-20 16:35:00","updated_at":"2026-04-20 16:35:00"}
documents · upload
2026-04-20 14:36:27 · anonymous
backend_document #23
Context
{"file_name":"ESSENTIAL_FILES_ANALYSIS.md","mime_type":"application/octet-stream"}
Before
[]
Changed Data
{"backend_document_id":"23","document_type":"upload","title":"All Essential Files for Customer DB","slug":"all-essential-files-for-customer-db","summary_text":"All Essential Files for Customer DB","content_markdown":null,"content_html":null,"file_name":"ESSENTIAL_FILES_ANALYSIS.md","stored_name":"20260420-183627-ab045aa6.md","mime_type":"application/octet-stream","file_size_bytes":"9785","storage_path":"/mnt/drive1/customerdb/backend/documents_storage/20260420-183627-ab045aa6.md","is_deleted":"0","created_at":"2026-04-20 14:36:27","updated_at":"2026-04-20 14:36:27","editor_content":"# Essential Files Analysis - C:\\code\\customerdb\n\n**Generated:** April 17, 2026\n\n---\n\n## Summary\n\nThis document identifies which files are essential to keep vs which can be safely removed to reduce disk usage and simplify the codebase.\n\n**Estimated Space Savings:** ~200+ MB\n\n---\n\n## KEEP - Essential Files\n\n### Core Application\n\n```\nC:\\code\\customerdb\\backend\\           # Main PHP backend (98 files)\nC:\\code\\customerdb\\frontend\\          # Front Desk app (15 HTML pages)\nC:\\code\\customerdb\\frontend\\api\\       # Frontend API endpoints\nC:\\code\\customerdb\\scripts\\           # Import/sync scripts\nC:\\code\\customerdb\\migrations\\         # SQL migrations\nC:\\code\\customerdb\\csv\\               # Active CSV data\nC:\\code\\customerdb\\docs\\             # Documentation\nC:\\code\\customerdb\\backups\\           # Database backups (prune old)\nC:\\code\\customerdb\\mariadb_core_schema.sql\nC:\\code\\customerdb\\backup.sh\n```\n\n### Backend - Essential Files (98 PHP files)\n\n| File | Purpose |\n|------|---------|\n| `bootstrap.php` | Core bootstrap |\n| `customer_service.php` | Customer management |\n| `customer.php` | Customer API |\n| `visit_service.php` | Visit records |\n| `visit.php` | Visit API |\n| `customer_totals_service.php` | Daily totals |\n| `report_service.php` | Reporting (80KB) |\n| `schedule.php` | Appointment scheduling |\n| `setmore_service.php` | Setmore integration |\n| `email_service.php` | Email handling |\n| `bank_service.php` | Banking |\n| `gold_silver_service.php` | Precious metals |\n| `duke_service.php` | Energy tracking |\n| `payroll_service.php` | Payroll |\n| `stocks_crypto_service.php` | Investments |\n| `medication_service.php` | Medication tracking |\n| `backup_database_service.php` | Database backup |\n| `cron_manager.php` | Cron management |\n| `nightly_reports_service.php` | Nightly reports |\n| `morning_jobs_service.php` | Morning batch jobs |\n| `square_terminal_service.php` | Square POS |\n| `live_table_manager_service.php` | Live data tables |\n| `notifications_service.php` | Notifications |\n\n**API Endpoints:** 58 files in `/backend/api/` - all active REST endpoints\n\n### Frontend - HTML Pages (15 files)\n\n| File | Purpose |\n|------|---------|\n| `visit.html` | Visit management (254KB) |\n| `customer.html` | Customer records |\n| `index.html` | Main dashboard |\n| `reports.html` | Reports viewer |\n| `schedule.html` | Schedule view |\n| `work_order.html` | Work orders |\n| `workload.html` | Workload view |\n| `receipt.html` | Receipt printing |\n| `login.html` | Authentication |\n| `upcoming.html` | Upcoming appointments |\n| `square_customer.html` | Square integration |\n| `item_types.html` | Item types |\n| `todo.html` | Todo lists |\n| `customer_display.html` | Customer display |\n\n### Scripts - Essential (7 files)\n\n| Script | Purpose |\n|--------|---------|\n| `import_csv_v2.py` | CSV import |\n| `import_access_v2.py` | Access DB import |\n| `access_to_mariadb_parser.py` | Access parser |\n| `import_legacy_totals_from_excel.ps1` | Excel import |\n| `sync_backend_mirror.ps1` | Mirror sync |\n| `check_backend_mirror.ps1` | Mirror check |\n| `signature_blob_loader.py` | Signature loader |\n\n### Migrations - Essential (3 files)\n\n| File | Purpose |\n|------|---------|\n| `20260407_add_conversion_job.sql` | Conversion job table |\n| `20260411_order_items_item_type_name_no_fk.sql` | Item type changes |\n| `20260416_blog_prompt_templates.sql` | Blog prompts |\n\n### CSV Data - Essential\n\n| File | Purpose |\n|------|---------|\n| `CustomerTable.csv` | Customer records |\n| `CustomerVisits.csv` | Visit records |\n| `CustomerTotals.csv` | Daily totals |\n| `AlterationItems.csv` | Alteration items |\n\n---\n\n## REMOVE - Redundant/Unused Files\n\n### Priority 1 - Safe to Delete (Complete Directories)\n\n| Directory | Size | Action |\n|-----------|------|--------|\n| `notused\\` | ~85 MB | DELETE ENTIRE |\n| `venv\\` | ~100 MB | DELETE ENTIRE |\n| `OldFiles\\` | ~1 MB | DELETE ENTIRE |\n| `.vs\\` | ~1 MB | DELETE ENTIRE |\n| `.vscode\\` | small | DELETE |\n\n#### notused/ Contents (DELETE ALL)\n```\nnotused\\access_to_mariadb_parser (1).py   # duplicates\nnotused\\access_to_mariadb_parser (2).py   # duplicates\nnotused\\customerdb_v2_staging_schema.sql  # duplicate\nnotused\\mariadb_core_schema.sql          # duplicate\nnotused\\mariadb-12.2.2-winx64.msi        # MariaDB installer (89MB!)\nnotused\\Backend\\                         # old PHP code\nnotused\\backups\\                         # old backups\nnotused\\csv\\                           # old CSVs\nnotused\\docs\\                          # old docs\nnotused\\schema\\                        # old schemas\nnotused\\scripts\\                      # old scripts\nnotused\\webui\\                        # old webui\n```\n\n### Priority 2 - Duplicate WebUI (Check First)\n\n| Directory | Purpose |\n|-----------|---------|\n| `webui\\` | ~15 MB - mirrors backend/frontend |\n\nThis directory appears to mirror the main `backend/` and `frontend/` directories. If `webui` is NOT served as a separate application, DELETE ENTIRE:\n\n```\nwebui\\backend\\         # 89 files - duplicate of ../backend/\nwebui\\frontend\\       # mirrors ../frontend/\nwebui\\api\\           # similar to ../frontend/api/\n```\n\n### Priority 3 - Temporary Files\n\nDelete all files matching patterns:\n```\ntmp_*.php     (~30 files)  # temp PHP scripts\ntmp_*.sql     (~30 files)  # temp SQL queries\ntmp_*.sh      (1 file)    # temp shell scripts\ntmp_*.csv     (1 file)    # temp CSV files\n```\n\nExamples:\n- `tmp_check_129411.sql`\n- `tmp_nightly_preview.php`\n- `tmp_compare_sheet_customer_totals.sql`\n- `tmp_mirror_drive.sh`\n- `tmp_customertotalsaccess.csv`\n\n### Priority 4 - Check Before Delete\n\n| Directory | Purpose | Action |\n|-----------|---------|--------|\n| `blog\\` | Blog module | Verify if used, else DELETE |\n| `Topaz\\` | Signature pad drivers | Verify if needed, else DELETE |\n| `wordpress-plugin\\` | WP integration | Verify if used, else DELETE |\n| `schedule\\` | Laravel scheduling app | Verify if integrated, else DELETE |\n| `csv\\back\\` | 8 backup CSVs | Likely duplicate, verify then DELETE |\n\n### Priority 5 - Backup Files\n\n| File Pattern | Action |\n|-------------|--------|\n| `*.bak_*` | DELETE |\n| `*.bak` | DELETE |\n| `*.backup` | DELETE |\n| `*~` | DELETE |\n\n### Priority 6 - Root Level Large Unused Files\n\n| File | Size | Action |\n|------|------|--------|\n| `Items To Test or Comlete.odt` | 26KB | Move to docs or DELETE |\n\n---\n\n## Directory Structure After Cleanup\n\n```\ncustomerdb/\n├── backend/                    # KEEP - Main PHP backend\n│   ├── api/                    # KEEP - API endpoints\n│   ├── jobs/                   # KEEP - Cron jobs\n│   └── bin/                    # KEEP - Binaries\n├── frontend/                   # KEEP - Front Desk app\n│   ├── api/                   # KEEP - API calls\n│   └── reports/               # KEEP - PDF reports\n├── scripts/                   # KEEP - Import scripts\n├── migrations/                 # KEEP - DB migrations\n├── csv/                       # KEEP - Active data\n│   └── back/                 # DELETE - backup copies\n├── docs/                      # KEEP - Documentation\n├── backups/                   # KEEP - Keep latest, prune old\n├── schema/                   # KEEP or DELETE (empty)\n├── mariadb_core_schema.sql        # KEEP - Core schema\n├── migrate_add_visit_type.sql   # KEEP - Migration\n├── backup.sh                # KEEP - Backup script\n├── .gitignore              # KEEP\n│\n├── notused/                 # DELETE ENTIRE (~85 MB)\n├── OldFiles/               # DELETE ENTIRE (~1 MB)\n├── .vs/                    # DELETE (~1 MB)\n├── .vscode/                # DELETE\n├── venv/                   # DELETE (~100 MB)\n├── webui/                  # DELETE OR VERIFY FIRST\n├── blog/                   # VERIFY - then delete\n├── Topaz/                  # VERIFY - then delete\n├── wordpress-plugin/        # VERIFY - then delete\n├── schedule/               # VERIFY - then delete\n└── tmp_*.*                 # DELETE ALL (~2 MB)\n```\n\n---\n\n## Space Savings Summary\n\n| Category | Savings |\n|----------|----------|\n| `notused/` directory | ~85 MB |\n| `venv/` directory | ~100 MB |\n| `tmp_*` files | ~2 MB |\n| `OldFiles/` | ~1 MB |\n| `.vs`, `.vscode` | ~1 MB |\n| `webui/` (if duplicate) | ~15 MB |\n| `csv/back/` | ~2 MB |\n| **TOTAL** | **~200+ MB** |\n\n---\n\n## Commands to Remove Files\n\n### PowerShell - Delete Priority 1 (Safe to Delete)\n\n```powershell\n# Delete notused directory\nRemove-Item -Recurse -Force \"C:\\code\\customerdb\\notused\"\n\n# Delete OldFiles directory\nRemove-Item -Recurse -Force \"C:\\code\\customerdb\\OldFiles\"\n\n# Delete .vs directory\nRemove-Item -Recurse -Force \"C:\\code\\customerdb\\.vs\"\n\n# Delete .vscode directory\nRemove-Item -Recurse -Force \"C:\\code\\customerdb\\.vscode\"\n\n# Delete venv directory\nRemove-Item -Recurse -Force \"C:\\code\\customerdb\\venv\"\n```\n\n### PowerShell - Delete Temporary Files\n\n```powershell\n# Delete all tmp_* files in root\nGet-ChildItem \"C:\\code\\customerdb\" -Filter \"tmp_*\" | Remove-Item -Force\n\n# Delete backup files\nGet-ChildItem \"C:\\code\\customerdb\" -Filter \"*.bak*\" | Remove-Item -Force\n```\n\n### PowerShell - Delete Duplicate WebUI (After Verification)\n\n```powershell\n# Only run if webui is NOT served separately\nRemove-Item -Recurse -Force \"C:\\code\\customerdb\\webui\"\n```\n\n---\n\n## Verification Checklist Before Delete\n\n- [ ] **webui/** - Is port 8894 served from this directory? If yes, KEEP. If served from `backend/`, DELETE.\n- [ ] **blog/** - Is blog feature actively used in the application?\n- [ ] **Topaz/** - Is the Topaz signature pad still in use?\n- [ ] **wordpress-plugin/** - Is WordPress integration still active?\n- [ ] **schedule/** - Is the Laravel scheduling app still integrated?\n\n---\n\n*End of Analysis*","is_text_editable":1,"can_edit_inline":1}
schedule · create
2026-04-20 13:54:03 · admin@ellasalterations.com
appointment_workflow #0
Context
{"workflow_status":"no_show","visit_id":129358,"order_id":104111}
Before
[]
Changed Data
{"workflow_id":"9","source":"visit","source_key":"129358","appointment_date":"2026-04-20","customer_id":"489071","visit_id":"129358","order_id":null,"workflow_status":"no_show","payment_state":null,"payment_method":null,"payment_amount":"0.00","paid_in_advance":"0","report_required":"0","report_attached":"0","report_checked_at":"2026-04-20 13:54:02","provider_notes_text":null,"operator_notes":null,"no_show_email_key":"none","created_at":"2026-04-20 13:54:02","updated_at":"2026-04-20 13:54:02"}
customer_totals · create
2026-04-20 10:56:45 · anonymous
customer_totals #20323
Context
[]
Before
[]
Changed Data
{"customer_date":"2026-04-20 14:55:00","customer_name":"Edwards","dopu_can":"Edwards","edwards":100,"edwards_type":"mileage","update_flag":"47"}
schedule · create
2026-04-19 15:46:07 · admin@ellasalterations.com
appointment_workflow #0
Context
{"workflow_status":"no_show","visit_id":129401,"order_id":104154}
Before
[]
Changed Data
{"workflow_id":"8","source":"visit","source_key":"129401","appointment_date":"2026-04-19","customer_id":"3478","visit_id":"129401","order_id":null,"workflow_status":"no_show","payment_state":null,"payment_method":null,"payment_amount":"0.00","paid_in_advance":"0","report_required":"0","report_attached":"0","report_checked_at":"2026-04-19 15:46:07","provider_notes_text":null,"operator_notes":"Status: 3/23/2026 Drop Off","no_show_email_key":"none","created_at":"2026-04-19 15:46:07","updated_at":"2026-04-19 15:46:07"}
live_table_manager · delete
2026-04-19 13:19:54 · anonymous
customer_payment_transactions #5982
Context
[]
Before
{"customer_payment_transaction_id":"5982","payment_id":"63997","order_id":"104085","visit_id":"129332","customer_id":"489019","customer_name":"Chevy Stern","transaction_date":"2026-04-12 00:00:00","payment_method":"Square","payment_type":"Deposit","bucket":"credit","amount":"45.60","tip_amount":"0.00","is_new_customer":"0","source":"payments","created_at":"2026-04-19 13:15:17","updated_at":"2026-04-19 13:15:17"}
Changed Data
{"deleted":true}
live_table_manager · delete
2026-04-19 13:19:49 · anonymous
customer_payment_transactions #5983
Context
[]
Before
{"customer_payment_transaction_id":"5983","payment_id":"63998","order_id":"104085","visit_id":"129332","customer_id":"489019","customer_name":"Chevy Stern","transaction_date":"2026-04-12 00:00:00","payment_method":"Square","payment_type":"Deposit","bucket":"credit","amount":"40.00","tip_amount":"0.00","is_new_customer":"0","source":"payments","created_at":"2026-04-19 13:15:17","updated_at":"2026-04-19 13:15:17"}
Changed Data
{"deleted":true}
live_table_manager · delete
2026-04-19 13:18:05 · anonymous
customer_payment_transactions #5984
Context
[]
Before
{"customer_payment_transaction_id":"5984","payment_id":"63999","order_id":"104085","visit_id":"129332","customer_id":"489019","customer_name":"Chevy Stern","transaction_date":"2026-04-12 00:00:00","payment_method":"Square","payment_type":"Balance","bucket":"credit","amount":"40.00","tip_amount":"0.00","is_new_customer":"0","source":"payments","created_at":"2026-04-19 13:15:17","updated_at":"2026-04-19 13:15:17"}
Changed Data
{"deleted":true}
live_table_manager · delete
2026-04-19 13:17:53 · anonymous
customer_payment_transactions #5985
Context
[]
Before
{"customer_payment_transaction_id":"5985","payment_id":"64000","order_id":"104085","visit_id":"129332","customer_id":"489019","customer_name":"Chevy Stern","transaction_date":"2026-04-12 00:00:00","payment_method":"Square","payment_type":"Tip","bucket":"tip","amount":"0.00","tip_amount":"0.00","is_new_customer":"0","source":"payments","created_at":"2026-04-19 13:15:17","updated_at":"2026-04-19 13:15:17"}
Changed Data
{"deleted":true}
schedule · create
2026-04-18 17:02:58 · admin@ellasalterations.com
appointment_workflow #0
Context
{"workflow_status":"no_show","visit_id":129391,"order_id":104144}
Before
[]
Changed Data
{"workflow_id":"7","source":"visit","source_key":"129391","appointment_date":"2026-04-18","customer_id":"3503","visit_id":"129391","order_id":null,"workflow_status":"no_show","payment_state":null,"payment_method":null,"payment_amount":"0.00","paid_in_advance":"0","report_required":"0","report_attached":"0","report_checked_at":"2026-04-18 17:02:58","provider_notes_text":null,"operator_notes":"App CreatedApp CreatedApp CreatedPayment Type:Credit Paid Date:  3/30/2026 3:30:00 PMPayment Type: Credit Paid Amount: $707.00Payment: 3/30/2026   707","no_show_email_key":"none","created_at":"2026-04-18 17:02:58","updated_at":"2026-04-18 17:02:58"}
schedule · create
2026-04-18 16:34:20 · admin@ellasalterations.com
appointment_workflow #0
Context
{"workflow_status":"no_show","visit_id":129386,"order_id":104139}
Before
[]
Changed Data
{"workflow_id":"6","source":"visit","source_key":"129386","appointment_date":"2026-04-18","customer_id":"3501","visit_id":"129386","order_id":null,"workflow_status":"no_show","payment_state":null,"payment_method":null,"payment_amount":"0.00","paid_in_advance":"0","report_required":"0","report_attached":"0","report_checked_at":"2026-04-18 16:34:20","provider_notes_text":null,"operator_notes":"Project Details 2 silk pants need hem and 1 pair jeansWhen Needed? couple weeksBooked from Custom Booking PageProject Details 2 silk pants need hem and 1 pair jeansWhen Needed? couple weeksBooked from Custom Booking PageProject Details 2 silk pants need hem and 1 pair jeansWhen Needed? couple weeksBooked from Custom Booking PagePayment Type:None Paid Date:  3/20/2026 2:30:00 PMDeposit Amount: $60.00Deposit Date:  3/6/2026","no_show_email_key":"none","created_at":"2026-04-18 16:34:20","updated_at":"2026-04-18 16:34:20"}
documents · upload
2026-04-17 15:19:31 · anonymous
backend_document #22
Context
{"file_name":"2026-04-17-implementation-report.md","mime_type":"application/octet-stream"}
Before
[]
Changed Data
{"backend_document_id":"22","document_type":"upload","title":"Codex  Updates 04-17-2026","slug":"codex-updates-04-17-2026","summary_text":"Codex  Updates 04-17-2026","content_markdown":null,"content_html":null,"file_name":"2026-04-17-implementation-report.md","stored_name":"20260417-191931-4b36a7df.md","mime_type":"application/octet-stream","file_size_bytes":"8180","storage_path":"/mnt/drive1/customerdb/backend/documents_storage/20260417-191931-4b36a7df.md","is_deleted":"0","created_at":"2026-04-17 15:19:31","updated_at":"2026-04-17 15:19:31","editor_content":"# Implementation Report - April 17, 2026\n\n## Scope\nThis document summarizes all completed work from this support/maintenance session, including:\n- Issues found\n- Root causes\n- Fixes implemented\n- Files changed\n- Live deployment actions\n- Verification results\n- Remaining follow-up items\n\nDate: 2026-04-17\n\n---\n\n## 1) Cron Email Failures (421 Downstream server error)\n\n### Reported issue\nCron jobs were failing email delivery from:\n- `/mnt/drive1/customerdb/backend/jobs/run_cron_job.php 7`\n\nBounce details showed:\n- Relay path through `relay.mailchannels.net`\n- Recipient looked like an SMTP host mailbox (`kefa@de-fra-smtpout7.hostinger.io`)\n- Error: `421 Downstream server error`\n\n### Root causes identified\n1. Mis-targeted recipient (SMTP server domain used as mailbox address).\n2. Mail path could fall back to `mail()` when SMTP config was missing/unavailable, which routed through MailChannels.\n\n### Fixes completed\n#### Code hardening\nUpdated `backend/mail_service.php`:\n- Added recipient and sender email validation (`FILTER_VALIDATE_EMAIL`).\n- Improved SMTP security mode handling (`ssl`, `tls`, `none`).\n- SMTP auth now enabled only when username exists.\n- Disabled `mail()` fallback for CLI jobs (cron path), so cron fails explicitly instead of silently routing via MailChannels.\n\n#### Live SMTP configuration\nOn live host (`192.168.7.202`), app settings were updated to Hostinger SMTP:\n- `smtp_host = smtp.hostinger.com`\n- `smtp_port = 465`\n- `smtp_secure = ssl`\n- `smtp_user = admin@ellasalterations.com`\n- `smtp_pass = [updated in DB]`\n- `smtp_from_email = admin@ellasalterations.com`\n- `smtp_from_name = Ella's Alterations`\n- `cron_notify_email = admin@ellasalterations.com`\n- `nightly_report_to_email = admin@ellasalterations.com`\n\n### Validation\n- `app_send_mail()` test on live host returned success via PHPMailer.\n- Cron job re-run succeeded:\n  - `php8.3 /mnt/drive1/customerdb/backend/jobs/run_cron_job.php 7`\n  - Returned `\"ok\": true`\n\n### Follow-up\n- Recommended mailbox password rotation after credentials were shared in chat.\n\n---\n\n## 2) Receipt Disclosure Requirements\n\n### Requested behavior\nEnsure the following actions include required disclosures at the end:\n- Print Receipt\n- Email Receipt\n- Save Receipt (PDF)\n\n### Fixes completed\nUpdated disclosure handling across all receipt generation paths:\n\n#### `frontend/visit.html`\n- Added canonical `REQUIRED_RECEIPT_DISCLOSURES` constant.\n- Added `buildReceiptDisclosureHtml()` to render disclosure blocks.\n- `sendEmailReceipt()` path now appends required disclosures in generated email HTML.\n- `generateVisitReport()` now sends `report_disclaimer_override` to backend PDF generator so saved PDFs use same required text.\n\n#### `frontend/api/visit_report_generate.php`\n- Added support for request payload key: `report_disclaimer_override`.\n- Enhanced disclaimer parser to handle uppercase heading lines with colon format (e.g., `DEPOSIT POLICY:`).\n- Uses override text when provided, otherwise settings fallback.\n\n#### `frontend/receipt.html`\n- Added required disclosure constant and merge logic.\n- Replaced old extra notice injection with required disclosure merge.\n- Terms rendering updated to preserve heading/body format.\n\n### Validation\n- PHP syntax check passed on `frontend/api/visit_report_generate.php`.\n- Confirmed references to new disclosure constants/functions in all required paths.\n\n---\n\n## 3) Dashboard Today Totals Incorrect (5/5 vs expected 8/8)\n\n### Reported issue\nDashboard showed:\n- `Today Customers: 5`\n- `Today New: 5`\nExpected:\n- `8` and `8`\n\n### Root causes identified\nIn `frontend/api/totals_snapshot_live.php`:\n1. Logic prioritized `customer_totals` and only checked `visits` if count was zero.\n   - If `customer_totals` lagged, dashboard stayed low.\n2. A `Walk In` drop-off row needed exclusion for this specific metric.\n\n### Fixes completed\nUpdated `ts_today_payment_totals_live()` in `frontend/api/totals_snapshot_live.php`:\n- Compute drop-off counts from both sources (`customer_totals`, `visits`).\n- Use max of the two counts instead of one-way fallback.\n- Exclude `booking_source = 'walk in'` when visits table has that column.\n\n### Deployment and validation\n- Deployed updated API file to live host.\n- Live endpoint check returned:\n  - `\"today_totals\":{\"total_customers\":8,\"new_customers\":8,...}`\n\n---\n\n## 4) Morning Import Visit Reuse Rules\n\n### Requested rules\nFor morning Setmore import:\n1. If customer has visit type `drop off` or `rescheduled` or `no show`: reuse visit and add Setmore notes.\n2. If customer has visit type `pick up`: create a new visit and add Setmore notes.\n3. If customer has no visit record: create a new visit and add Setmore notes.\n\n### Fixes completed\nUpdated `backend/setmore_service.php`:\n\n#### Rule enforcement\n- `app_setmore_reusable_dropoff_visit()` now inspects latest customer visit and allows reuse only for copy-source statuses (`dropoff`, `rescheduled`, `noshow`).\n- If latest status is pickup, reuse is not selected, so a new visit is created.\n- If no prior visit exists, new visit creation continues as normal.\n\n#### Notes behavior\n- Added `app_setmore_merge_notes()`.\n- Reused visit updates now merge/append Setmore notes instead of replacing existing operator notes.\n\n#### Safety improvement\n- On reused visits, preserve existing `source_key_value` if it belongs to another appointment key.\n\n### Deployment and validation\n- Deployed to live host.\n- Lint with `php8.3 -l` passed.\n- Morning smoke test passed:\n  - `php8.3 /mnt/drive1/customerdb/backend/jobs/smoke_morning_jobs.php`\n\nNote:\n- Default `php -l` binary on host showed parse issue due different PHP binary path; `php8.3` (actual cron/runtime binary) is clean.\n\n---\n\n## 5) Nightly Summary Section Order Drift\n\n### Reported issue\nNightly summary sections had moved around.\n\n### Required order\n1. Daily Detail Report\n2. Daily Summary Report\n3. Month To Date Report\n4. Yearly Summary Report\n5. Daily Imported People List\n6. Alterations Next 7 Days\n\n### Fix completed\nReordered report block assembly in `backend/nightly_reports_service.php` to match exact required sequence.\n\n### Deployment and validation\n- Deployed to live host.\n- `php8.3 -l /mnt/drive1/customerdb/backend/nightly_reports_service.php` passed.\n\n---\n\n## 6) PDF Files Saving with Raw HTML Text\n\n### Reported issue\nSome saved PDFs looked wrong (HTML source printed in the PDF instead of rendered receipt layout).\n\n### Investigation findings\n- Sample file `Hannah-Goncalves-448248-04032026.pdf` is a valid PDF container but includes raw HTML source text (`<!DOCTYPE html>`, tags visible in extracted text).\n- Bulk scan found 4 affected files, all in `04032026` batch:\n  - `Hannah-Goncalves-448248-04032026.pdf`\n  - `Emiliano-Delgado-3226-04032026.pdf`\n  - `Laura-Coyne-488970-04032026.pdf`\n  - `Jamie-Miller-488977-04032026.pdf`\n- Newer reports were rendering normally.\n\n### Fix completed (preventive)\nUpdated `frontend/api/visit_report_generate.php`:\n- Added `vrg_pdf_looks_like_html_source()` quality gate.\n- If generated PDF appears to contain HTML source text, generation now fails fast and does not save corrupt output.\n\n### Deployment and validation\n- Deployed to live host.\n- `php8.3 -l` passed.\n\n### Follow-up required\n- Re-generate the 4 historical affected files from UI (`Save Receipt PDF`) to replace bad copies.\n\n---\n\n## Files Changed In This Session (Core)\n\n### Backend\n- `backend/mail_service.php`\n- `backend/setmore_service.php`\n- `backend/nightly_reports_service.php`\n\n### Frontend\n- `frontend/visit.html`\n- `frontend/receipt.html`\n- `frontend/api/visit_report_generate.php`\n- `frontend/api/totals_snapshot_live.php`\n\n---\n\n## Operational Notes\n\n- Multiple live updates were deployed directly to host `192.168.7.202`.\n- Runtime checks were executed with `php8.3` to match cron/runtime behavior.\n- Temporary maintenance scripts used during diagnosis were deleted from local and remote `/tmp`.\n\n---\n\n## Remaining Action Items\n\n1. Rotate SMTP mailbox password (credential was provided in conversation text).\n2. Re-generate the 4 known bad PDFs from `04032026` batch.\n3. Optional: Add an admin audit endpoint to list historically malformed PDFs using the same detection method, for one-time cleanup.\r\n","is_text_editable":1,"can_edit_inline":1}
documents · upload
2026-04-17 15:18:50 · anonymous
backend_document #21
Context
{"file_name":"SESSION_COMPLETION_2026-04-17.md","mime_type":"application/octet-stream"}
Before
[]
Changed Data
{"backend_document_id":"21","document_type":"upload","title":"Curser Updates 04-17-2026","slug":"curser-updates-04-17-2026","summary_text":"Curser Updates 04-17-2026","content_markdown":null,"content_html":null,"file_name":"SESSION_COMPLETION_2026-04-17.md","stored_name":"20260417-191850-3b41b6c5.md","mime_type":"application/octet-stream","file_size_bytes":"11631","storage_path":"/mnt/drive1/customerdb/backend/documents_storage/20260417-191850-3b41b6c5.md","is_deleted":"0","created_at":"2026-04-17 15:18:50","updated_at":"2026-04-17 15:18:50","editor_content":"# Session completion summary — 2026-04-17\n\nThis document records work completed across multiple backend/UI areas: problems observed, root causes, fixes applied, and new or changed behavior. Paths are relative to the repository root (`customerdb`).\n\n---\n\n## 1. Reminders (`backend/reminders.php`)\n\n### Requested behavior\n- Embedded reminders iframe should use more of the layout; later, remove the reminder queue panel entirely and enlarge the embed.\n\n### Changes\n1. **Two-column layout (1/4 + 3/4)**  \n   - Replaced shared `grid cols-2` (~50/50) with a local class `reminders-embed-grid` using `grid-template-columns: 1fr 3fr`, with a `920px` breakpoint stacking to one column (aligned with `page_helpers.php`).\n\n2. **Queue removed; full-width tall iframe**  \n   - Removed the “Reminder Queue” article (stats + table) and all related PHP (`reminder_service.php` queries, `$summary`, `$rows`).\n   - Single `article.panel` with the iframe only.\n   - CSS: `min-height: 720px`, `height: calc(100vh - 200px)` and `calc(100dvh - 200px)` for viewport-relative height (with `vh` fallback).\n   - Removed nested duplicate `.shell` if it had been introduced earlier in this file (payroll had a similar issue; reminders stayed within header shell only).\n\n### Notes\n- `webui/backend/reminders.php` remains a thin loader to `backend/reminders.php`.\n\n---\n\n## 2. Umami analytics (`backend/umami.php`)\n\n### Issues\n- Iframe pointed at a non-existent path (`/backend/umami-embed/login`) → “not found” in the frame.\n- After switching to `https://umami.myexperttailor.com/...`, browsers showed **refused to connect** / embedding failures (CSP / `frame-ancestors`, or network).\n\n### Fixes\n- Set public dashboard URL to the provided Umami website URL.\n- **Embedding:** iframe now targets the **LAN Umami** instance `http://192.168.7.206:3006` with the same `/websites/{uuid}` path so framing is not blocked like the public HTTPS host often is.\n- Copy updated to explain LAN vs public; **Open Public Umami** still opens HTTPS in a new tab.\n\n### Notes\n- True fix for embedding the public host requires server-side headers or a reverse proxy; documented in repo history (`documents_storage`, session logs).\n\n---\n\n## 3. Issue tracker (`backend/issue_tracker.php`)\n\n### Requested behavior\n- Square corners on “boxes,” not rounded.\n\n### Implementation\n- Wrapper class `issue-tracker-square` with overrides for `.panel`, `.card`, `.stat`, `.notice`, inputs, selects, textareas, and `.btn` → `border-radius: 0`.\n- `.done-pill` / `.open-pill` set to `border-radius: 0` for consistency.\n- Scoped so global backend chrome outside the wrapper is unchanged.\n\n---\n\n## 4. Medications (`backend/medication.php`)\n\n### Requested behavior\n- No rounded corners on medication page “boxes.”\n- **Update Medication** as a pill (rounded control); row action aligned with that wording.\n\n### Implementation\n- Wrapper `medication-page-square` with overrides (panels, notices, inputs, buttons square).\n- Exception class **`med-update-pill`** → `border-radius: 999px !important` on:\n  - Submit button in **edit** mode (“Update Medication”).\n  - Table row link (label **Update Medication**, was “Edit”).\n- Local components (`med-calc-row`, `filter-tab`, `badge`, `person-chip`) set to square radii.\n\n### Follow-on (reports)\n- See **§10 Medication reports** (`medication_report.php`).\n\n---\n\n## 5. Medication reports — printable Excel-style (`backend/medication_report.php`)\n\n### Issues\n- `@media print` hid **`.panel:not(.print-keep)`**, which hid almost all report content; “Print” flow was broken for real output.\n- “Due soon” was card layout, not spreadsheet-like.\n\n### Fixes / features\n- **`mrep-excel`** tables: `border-collapse`, full cell borders, gray header row, zebra rows.\n- **Due in next 5 days** converted from flex cards to a **single table** with columns including an on-screen Edit column; **`.mrep-no-print`** hides action column in print.\n- Overdue, by-person inner tables, inactive list → **`mrep-excel`**.\n- Print CSS: hide summary dash, hero actions, buttons; tighten typography; `print-color-adjust: exact` where helpful.\n- Header action: **Print Report** with stable **`id=\"mrep-print-btn\"`**; `page_helpers.php` extended so **anchor** actions can carry **`id`** (same as buttons).\n\n---\n\n## 6. Payroll — stats & theme (`backend/payroll.php`)\n\n### Issues\n- Stat numbers appeared “all black” / not aligned with **settings / theme** CSS variables.\n- Extra **nested `<div class=\"shell\">`** duplicated `app_backend_render_header()`’s shell.\n\n### Fixes\n- **`.pay-stat`**: `var(--backend-box-bg)`, `--backend-line`, `--backend-box-text`, labels `--backend-muted`.\n- **`.worker-yana` / `.worker-lola`**: `var(--teal)` and `var(--accent)` instead of hard-coded hex.\n- All six stats (including **Yana/Lola total rows**) use worker color classes.\n- Tabs / table / paste area hints aligned with backend variables where touched.\n- Unpaid tab badge uses `var(--accent)` + `var(--button-text)`.\n- **Removed inner `.shell` wrapper.**\n\n---\n\n## 7. Payroll — paste import & Excel dates (`backend/payroll_service.php` + `payroll.php`)\n\n### Bugs / issues\n1. **Header row detection** compared normalized Excel headers to a list of **non-normalized** variants (e.g. `amount paid` vs `amount_paid`) → header row often misclassified → wrong column map → skips / zero imports (especially **Yana**-style sheets).\n2. **Excel date serials** and US dates not parsed by `DateTimeImmutable` alone.\n3. **UTF-8 BOM** and **NBSP** breaking header matching.\n4. On paste **exception**, POST resubmit UX; success notice used POST worker string vs canonical.\n\n### Fixes\n- Strip **BOM**; normalize **NBSP** to space in paste text.\n- Build **`$knownHeaderVariants`** using the same **`$norm()`** as header cells.\n- **`$toDate`**: serial range **20000–119999** via **25569** Excel→Unix conversion; explicit `createFromFormat` attempts (`n/j/Y`, `m/d/Y`, etc.) with `DateTimeImmutable::getLastErrors()` guard; fallback parse.\n- Expanded **column aliases** (`customerdatetime`, `custdate`, `client`, etc.).\n- Return array includes **`worker`** (canonical); notice uses it.\n- **Redirect** `?tab=paste&error=...` on paste import exception.\n- **`payroll.php`**: hint text mentions serials and BOM.\n\n---\n\n## 8. Payroll — printable Excel-style (`backend/payroll.php`)\n\n### Features\n- Wrapper **`pay-print-root`**; tables use **`pay-excel`** (grid borders, header strip, zebra).\n- **`@media print`**: hide stats, tabs, mark-paid toolbar, check-all links, inputs/forms inside data tables; compact borders/fonts.\n- **Print** button in hero (`id=\"pay-print-btn\"`) + JS `window.print()`.\n\n---\n\n## 9. Payroll — mark multiple paid (`backend/payroll.php`)\n\n### Bug\n- **Nested `<form>`** for row delete inside the **mark paid** `<form>`. HTML forbids nested forms; the browser **closes the outer form** at the inner `<form>`, so most **`entry_ids[]`** checkboxes were **outside** the mark-paid form → only **one** (or erratic) ID posted.\n\n### Fix\n- Delete control: **`<button type=\"submit\" form=\"payroll-del-{id}\">`**.\n- **Hidden `<form id=\"payroll-del-…\">`** per row, emitted **after** `</form>` of mark-paid (merged Yana + Lola unpaid rows).\n- Main form **`id=\"payroll-mark-paid\"`**.\n\n---\n\n## 10. Stocks & crypto — average cost precision (`backend/stocks_crypto.php`, `backend/stocks_crypto_service.php`)\n\n### Issue\n- **`avg_cost DECIMAL(14,6)`** and form **`step=\"0.000001\"`** / six-decimal display capped precision (problematic for crypto).\n\n### Fixes\n- Schema: **`DECIMAL(24,12)`**; `ALTER` to widen existing DBs (try/catch).\n- Save: pass **numeric string** into SQL (comma stripped, escaped) instead of float stringification for INSERT/UPDATE.\n- Form: **`step=\"any\"`**; edit value from **`trim((string)$editAsset['avg_cost'])`** (DB string).\n- Portfolio avg column: display **string** from DB to avoid float truncation.\n- Chart: **`hist_asset`** path uses JSON-encoded string → **`Number()`** in JS for the avg line.\n\n---\n\n## 11. Stocks & crypto — duplicate ticker / lots (`backend/stocks_crypto_service.php`, `backend/stocks_crypto.php`, `backend/api/stocks_summary.php`)\n\n### Issue\n- **`UNIQUE KEY uq_ticker (ticker)`** prevented a second **BTC** row even when notes differed.\n\n### Fixes\n- New installs: **`KEY ix_stocks_asset_ticker (ticker)`** (non-unique) instead of `uq_ticker`.\n- Existing DBs: **`ALTER TABLE stocks_asset DROP INDEX uq_ticker`** (try/catch); **`ADD KEY ix_stocks_asset_ticker`** if missing (try/catch).\n- **Portfolio / chart links:** `hist={ticker}&hist_asset={stocks_asset_id}` (+ optional `type=` filter) so **avg cost** matches the correct lot when tickers repeat.\n- **Prices tab:** inputs **`name=\"price_a_{stocks_asset_id}\"`**; **`save_prices`** resolves asset id → ticker (duplicate tickers no longer overwrite the same POST key).\n- **`app_stocks_fetch_all_live`:** fetch **once per distinct ticker** (dedupe).\n- **`stocks_summary` API:** each asset includes **`id`** (`stocks_asset_id`).\n\n### Related: `backend/page_helpers.php`\n- **`id`** attribute supported on **link**-type header actions (used by medication report print link).\n\n---\n\n## Files touched (summary)\n\n| File | Nature of change |\n|------|------------------|\n| `backend/reminders.php` | Layout + iframe-only page |\n| `backend/umami.php` | Embed URL, copy, LAN vs public |\n| `backend/issue_tracker.php` | Square-corner scoped CSS |\n| `backend/medication.php` | Square UI + pill update control + row link label |\n| `backend/medication_report.php` | Excel tables + print CSS + print button id on links |\n| `backend/page_helpers.php` | `id` on `<a>` action items |\n| `backend/payroll.php` | Theme vars, no nested shell, Excel/print, paste UX, mark-paid/delete forms |\n| `backend/payroll_service.php` | Paste import robustness, dates, headers, worker in return |\n| `backend/stocks_crypto.php` | avg_cost UI, `hist_asset`, portfolio URLs, `price_a_*` |\n| `backend/stocks_crypto_service.php` | Schema avg_cost, drop uq_ticker, index, save avg string, live fetch dedupe |\n| `backend/api/stocks_summary.php` | `id` on each asset in JSON |\n\nThin loaders under `webui/backend/` were unchanged where they only `require` canonical `backend/*.php`.\n\n---\n\n## Testing suggestions (manual)\n\n1. **Reminders:** load `/backend/reminders.php` — iframe fills width and height sensibly.\n2. **Umami:** confirm LAN iframe loads; public link in new tab.\n3. **Issue tracker / medication:** visual check square corners and pill(s) on medication update path.\n4. **Medication report:** Print preview — tables have grid lines; no empty printout.\n5. **Payroll:** paste Yana/Lola sheets with BOM, serial dates, varied headers; mark **multiple** unpaid rows paid in one submit.\n6. **Payroll print:** Print preview hides chrome; tables print.\n7. **Stocks:** add two **BTC** lots with different notes; set high-precision avg cost; prices tab saves both rows; chart `hist_asset` matches correct avg line; API returns distinct `id` per row.\n\n---\n\n## Known limitations / follow-ups\n\n- **Umami public host** embedding still depends on remote CSP / network; LAN proxy is the reliable approach.\n- **PHP `float`** still limits extreme precision in some JS chart paths; DB stores **12** fractional digits for `avg_cost`.\n- **Payroll paste** very large pastes may hit `max_input_vars` / post size limits (server config), not addressed in code.\n- **Medication** “Update Medication” row link text is long in narrow tables; acceptable per product request.\n\n---\n\n*Generated from implementation session work; adjust dates or add ticket IDs if you track work in an external system.*\n","is_text_editable":1,"can_edit_inline":1}
speed_dial · create
2026-04-17 15:05:43 · anonymous
backend_speed_dial #38
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"38","link_name":"MUV","link_url":"https://muvfl.com/locations/zephyrhills","sort_order":"0","is_active":"1","created_at":"2026-04-17 15:05:43","updated_at":"2026-04-17 15:05:43"}
speed_dial · create
2026-04-17 15:05:27 · anonymous
backend_speed_dial #37
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"37","link_name":"Target","link_url":"https://www.target.com/","sort_order":"0","is_active":"1","created_at":"2026-04-17 15:05:27","updated_at":"2026-04-17 15:05:27"}
speed_dial · create
2026-04-17 15:05:13 · anonymous
backend_speed_dial #36
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"36","link_name":"Video Compress","link_url":"https://freecompress.com/reduce-video","sort_order":"0","is_active":"1","created_at":"2026-04-17 15:05:13","updated_at":"2026-04-17 15:05:13"}
speed_dial · create
2026-04-17 15:04:58 · anonymous
backend_speed_dial #35
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"35","link_name":"Duke Energy","link_url":"https://www.duke-energy.com/home","sort_order":"0","is_active":"1","created_at":"2026-04-17 15:04:58","updated_at":"2026-04-17 15:04:58"}
speed_dial · create
2026-04-17 15:04:34 · anonymous
backend_speed_dial #34
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"34","link_name":"Monument Metals","link_url":"https://monumentmetals.com/","sort_order":"0","is_active":"1","created_at":"2026-04-17 15:04:34","updated_at":"2026-04-17 15:04:34"}
speed_dial · create
2026-04-17 15:04:16 · anonymous
backend_speed_dial #33
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"33","link_name":"Johnson &amp; Johnson Insurance","link_url":"https://www.jjins.com/","sort_order":"0","is_active":"1","created_at":"2026-04-17 15:04:16","updated_at":"2026-04-17 15:04:16"}
speed_dial · create
2026-04-17 15:03:51 · anonymous
backend_speed_dial #32
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"32","link_name":"Blue Sky","link_url":"https://bsky.app/","sort_order":"0","is_active":"1","created_at":"2026-04-17 15:03:51","updated_at":"2026-04-17 15:03:51"}
speed_dial · create
2026-04-17 15:03:32 · anonymous
backend_speed_dial #31
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"31","link_name":"Civitai","link_url":"https://civitai.com/","sort_order":"0","is_active":"1","created_at":"2026-04-17 15:03:32","updated_at":"2026-04-17 15:03:32"}
speed_dial · create
2026-04-17 15:03:18 · anonymous
backend_speed_dial #30
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"30","link_name":"Ambient Weather","link_url":"https://ambientweather.net/","sort_order":"0","is_active":"1","created_at":"2026-04-17 15:03:18","updated_at":"2026-04-17 15:03:18"}
speed_dial · create
2026-04-17 15:02:52 · anonymous
backend_speed_dial #29
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"29","link_name":"Threads","link_url":"https://www.threads.net/","sort_order":"0","is_active":"1","created_at":"2026-04-17 15:02:52","updated_at":"2026-04-17 15:02:52"}
speed_dial · create
2026-04-17 15:02:41 · anonymous
backend_speed_dial #28
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"28","link_name":"Mastodon","link_url":"https://mastodon.social/deck/getting-started","sort_order":"0","is_active":"1","created_at":"2026-04-17 15:02:41","updated_at":"2026-04-17 15:02:41"}
speed_dial · create
2026-04-17 15:02:24 · anonymous
backend_speed_dial #27
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"27","link_name":"Truth Social","link_url":"https://truthsocial.com/","sort_order":"0","is_active":"1","created_at":"2026-04-17 15:02:24","updated_at":"2026-04-17 15:02:24"}
speed_dial · create
2026-04-17 15:02:16 · anonymous
backend_speed_dial #26
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"26","link_name":"Rumble","link_url":"https://rumble.com/","sort_order":"0","is_active":"1","created_at":"2026-04-17 15:02:16","updated_at":"2026-04-17 15:02:16"}
speed_dial · create
2026-04-17 15:01:32 · anonymous
backend_speed_dial #25
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"25","link_name":"Tiktok","link_url":"https://www.tiktok.com/","sort_order":"0","is_active":"1","created_at":"2026-04-17 15:01:32","updated_at":"2026-04-17 15:01:32"}
speed_dial · create
2026-04-17 15:01:18 · anonymous
backend_speed_dial #24
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"24","link_name":"Suno","link_url":"http://suno.com/","sort_order":"0","is_active":"1","created_at":"2026-04-17 15:01:18","updated_at":"2026-04-17 15:01:18"}
speed_dial · create
2026-04-17 15:01:02 · anonymous
backend_speed_dial #23
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"23","link_name":"Youtube","link_url":"https://www.youtube.com/","sort_order":"0","is_active":"1","created_at":"2026-04-17 15:01:02","updated_at":"2026-04-17 15:01:02"}
speed_dial · create
2026-04-17 15:00:50 · anonymous
backend_speed_dial #22
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"22","link_name":"Instagram","link_url":"https://www.instagram.com/","sort_order":"0","is_active":"1","created_at":"2026-04-17 15:00:50","updated_at":"2026-04-17 15:00:50"}
speed_dial · create
2026-04-17 15:00:38 · anonymous
backend_speed_dial #21
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"21","link_name":"Twitter","link_url":"https://x.com/","sort_order":"0","is_active":"1","created_at":"2026-04-17 15:00:38","updated_at":"2026-04-17 15:00:38"}
speed_dial · create
2026-04-17 15:00:24 · anonymous
backend_speed_dial #20
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"20","link_name":"Pinterest","link_url":"https://www.pinterest.com/","sort_order":"0","is_active":"1","created_at":"2026-04-17 15:00:24","updated_at":"2026-04-17 15:00:24"}
speed_dial · create
2026-04-17 15:00:08 · anonymous
backend_speed_dial #19
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"19","link_name":"Linkedin","link_url":"https://www.linkedin.com/","sort_order":"0","is_active":"1","created_at":"2026-04-17 15:00:08","updated_at":"2026-04-17 15:00:08"}
speed_dial · create
2026-04-17 14:59:53 · anonymous
backend_speed_dial #18
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"18","link_name":"Meta Business","link_url":"https://business.facebook.com/latest/?asset_id=1990498817659573&business_id=766530631594591&nav_ref=profile_plus_admin_tool","sort_order":"0","is_active":"1","created_at":"2026-04-17 14:59:53","updated_at":"2026-04-17 14:59:53"}
speed_dial · create
2026-04-17 14:58:55 · anonymous
backend_speed_dial #17
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"17","link_name":"Facebook","link_url":"https://www.facebook.com/","sort_order":"0","is_active":"1","created_at":"2026-04-17 14:58:55","updated_at":"2026-04-17 14:58:55"}
speed_dial · create
2026-04-17 14:58:42 · anonymous
backend_speed_dial #16
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"16","link_name":"Lowes","link_url":"https://lowes.com/","sort_order":"0","is_active":"1","created_at":"2026-04-17 14:58:42","updated_at":"2026-04-17 14:58:42"}
speed_dial · create
2026-04-17 14:58:31 · anonymous
backend_speed_dial #15
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"15","link_name":"MidFlorida","link_url":"https://www.midflorida.com/","sort_order":"0","is_active":"1","created_at":"2026-04-17 14:58:31","updated_at":"2026-04-17 14:58:31"}
speed_dial · create
2026-04-17 14:58:17 · anonymous
backend_speed_dial #14
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"14","link_name":"USAA","link_url":"https://www.usaa.com/","sort_order":"0","is_active":"1","created_at":"2026-04-17 14:58:17","updated_at":"2026-04-17 14:58:17"}
speed_dial · create
2026-04-17 14:58:03 · anonymous
backend_speed_dial #13
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"13","link_name":"CapitalOne","link_url":"https://www.capitalone.com/","sort_order":"0","is_active":"1","created_at":"2026-04-17 14:58:03","updated_at":"2026-04-17 14:58:03"}
speed_dial · create
2026-04-17 14:57:42 · anonymous
backend_speed_dial #12
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"12","link_name":"Centennial Bank","link_url":"https://www.my100bank.com/","sort_order":"0","is_active":"1","created_at":"2026-04-17 14:57:42","updated_at":"2026-04-17 14:57:42"}
speed_dial · create
2026-04-17 14:57:16 · anonymous
backend_speed_dial #11
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"11","link_name":"Synchrony","link_url":"https://www.synchrony.com/accounts/","sort_order":"0","is_active":"1","created_at":"2026-04-17 14:57:16","updated_at":"2026-04-17 14:57:16"}
speed_dial · create
2026-04-17 14:56:58 · anonymous
backend_speed_dial #10
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"10","link_name":"MMJ Florida","link_url":"https://mmuregistry.flhealth.gov/","sort_order":"0","is_active":"1","created_at":"2026-04-17 14:56:58","updated_at":"2026-04-17 14:56:58"}
speed_dial · create
2026-04-17 14:56:35 · anonymous
backend_speed_dial #9
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"9","link_name":"Ella's Alterations Wordpress Admin","link_url":"https://www.ellasalterations.com/wp-admin/index.php","sort_order":"0","is_active":"1","created_at":"2026-04-17 14:56:35","updated_at":"2026-04-17 14:56:35"}
speed_dial · create
2026-04-17 14:55:42 · anonymous
backend_speed_dial #8
Context
[]
Before
[]
Changed Data
{"backend_speed_dial_id":"8","link_name":"Fox 13 Weather","link_url":"https://www.fox13news.com/weather","sort_order":"0","is_active":"1","created_at":"2026-04-17 14:55:42","updated_at":"2026-04-17 14:55:42"}
documents · save
2026-04-17 14:50:34 · anonymous
backend_document #20
Context
{"document_type":"upload"}
Before
{"backend_document_id":"20","document_type":"upload","title":"Complete Documentation up to date 04-17-2026","slug":"complete-documentation-up-to-date","summary_text":"Complete Documentation up to date 04-17-2026","content_markdown":"# Ella's Alterations - Comprehensive System Documentation\r\n\r\n**Generated:** April 17, 2026\r\n**Location:** C:\\code\\customerdb\r\n\r\n---\r\n\r\n## Table of Contents\r\n\r\n1. [System Overview](#1-system-overview)\r\n2. [Directory Structure](#2-directory-structure)\r\n3. [Database Schema](#3-database-schema)\r\n4. [API Endpoints](#4-api-endpoints)\r\n5. [External Integrations](#5-external-integrations)\r\n6. [Scheduled Jobs / Cron](#6-scheduled-jobs--cron)\r\n7. [Web Applications](#7-web-applications)\r\n8. [Settings & Configuration](#8-settings--configuration)\r\n9. [Migration Notes](#9-migration-notes)\r\n10. [Scripts & Tools](#10-scripts--tools)\r\n\r\n---\r\n\r\n## 1. System Overview\r\n\r\n### Purpose\r\nElla's Alterations is a comprehensive customer relationship management (CRM) andAlteration tracking system for a tailor shop. It manages customers, visits/alteration orders, appointments, payments, and provides integration with external services.\r\n\r\n### Server Information\r\n- **Primary Server:** kefa@192.168.7.202\r\n- **Mirror Drive:** /mnt/drive2 (mirrors /mnt/drive1)\r\n- **Database:** MariaDB - database `ellas_alterations`, user `kefa_admin`\r\n- **Web Server:** Apache 2.4 with mod-php\r\n- **PHP Version:** 8.3\r\n\r\n### Three Web Applications\r\n\r\n| App | Local URL | Public URL | Purpose |\r\n|-----|-----------|------------|---------|\r\n| Front Desk | http://192.168.7.202:8895 | https://ella.floridaalterations.com | Customer-facing operations |\r\n| Management | http://192.168.7.202:8894 | (LAN only) | Reports, admin, settings |\r\n| Scheduler | http://192.168.7.202:8897 | https://schedule.floridaalterations.com | Easy!Appointments booking |\r\n\r\n---\r\n\r\n## 2. Directory Structure\r\n\r\n```\r\ncustomerdb/\r\n├── backend/                    # Main PHP backend API and services\r\n│   ├── api/                    # REST API endpoints (~57 files)\r\n│   ├── bin/                    # Binary/executable scripts\r\n│   ├── backup/                # Backup versions of services\r\n│   └── jobs/                  # Background job scripts\r\n├── frontend/                   # Front Desk app (port 8895)\r\n│   ├── *.html                 # HTML pages\r\n│   ├── api/                   # PHP API endpoints\r\n│   └── reports/               # PDF reports (MMDDYYYY/filename.pdf)\r\n├── webui/                      # Management app (port 8894)\r\n│   ├── *.html                 # HTML pages\r\n│   ├── api/                  # PHP API endpoints\r\n│   ├── backend/               # Backend API copy\r\n│   └── email/                # Email templates\r\n├── schedule/                   # Easy!Appointments installation\r\n├── schema/                    # Database schema files\r\n├── migrations/               # SQL migrations\r\n├── scripts/                   # PowerShell/Python import scripts\r\n├── docs/                     # Documentation\r\n├── blog/                     # Blog system and reengineering\r\n├── csv/                      # CSV data files\r\n├── backups/                  # Backup archives\r\n├── Topaz/                    # Topaz signature pad configs\r\n├── webui/                    # Second web interface\r\n│   ├── api/\r\n│   ├── backend/\r\n│   └── frontend/\r\n├── notused/                  # Deprecated/unused files\r\n└── wordpress-plugin/          # WordPress integration\r\n```\r\n\r\n---\r\n\r\n## 3. Database Schema\r\n\r\n### Core Tables (from mariadb_core_schema.sql)\r\n\r\n#### customers\r\nMain customer registry.\r\n\r\n| Column | Type | Notes |\r\n|--------|------|-------|\r\n| customer_id | INT UNSIGNED PK | Auto-increment |\r\n| legacy_customer_id | INT NULL | Original Access DB ID |\r\n| created_at | DATETIME | Record creation time |\r\n| full_name | VARCHAR(200) | Customer full name |\r\n| phone | VARCHAR(30) | Formatted (XXX) XXX-XXXX |\r\n| email | VARCHAR(255) | Email address |\r\n| pickup_due_at | DATETIME | Next pickup date (synced from EA) |\r\n| description | TEXT | Description |\r\n| notes | TEXT | Internal notes |\r\n| is_new_customer | TINYINT(1) | 1 if flagged as new |\r\n\r\n#### visits\r\nOne row per alteration job/order.\r\n\r\n| Column | Type | Notes |\r\n|--------|------|-------|\r\n| visit_id | INT UNSIGNED PK | |\r\n| legacy_visit_id | INT NULL | Original Access DB ID |\r\n| customer_id | INT UNSIGNED FK | → customers |\r\n| visit_date | DATETIME | Drop-off date |\r\n| pickup_date | DATETIME | Expected pickup |\r\n| notes | TEXT | General visit notes |\r\n| customer_name_snapshot | VARCHAR(200) | |\r\n| phone_snapshot | VARCHAR(30) | |\r\n| email_snapshot | VARCHAR(255) | |\r\n| color | VARCHAR(100) | Garment color |\r\n| alterations_needed | TEXT | |\r\n| alterations_notes | TEXT | Detailed alteration instructions |\r\n| alterations_price | DECIMAL(10,2) | Manual price field |\r\n| total_alteration_price | DECIMAL(10,2) | Calculated from items |\r\n| expedited_fee | DECIMAL(10,2) | |\r\n| paid_date | DATETIME | When paid |\r\n| signature_text | TEXT | Text signature (legacy) |\r\n| signature_date | DATETIME | |\r\n| paid_flag | TINYINT(1) | 1 = paid |\r\n| source_key_value | VARCHAR(100) | |\r\n\r\n#### visit_signatures\r\nFull resolution signature images per visit.\r\n\r\n| Column | Type | Notes |\r\n|--------|------|-------|\r\n| signature_id | BIGINT UNSIGNED PK | |\r\n| visit_id | INT UNIQUE | One signature per visit |\r\n| signature_date | DATETIME | |\r\n| image_format | VARCHAR(50) | Default 'image/png' |\r\n| original_filename | VARCHAR(255) | |\r\n| original_extension | VARCHAR(20) | |\r\n| file_size_bytes | BIGINT | |\r\n| sha256_hash | CHAR(64) | Hash for verification |\r\n| signature_image | LONGBLOB | Raw PNG binary |\r\n| created_at | DATETIME | |\r\n\r\n#### item_types\r\nMaster list of alteration types (e.g., Hem, Zipper, Taper).\r\n\r\n| Column | Type | Notes |\r\n|--------|------|-------|\r\n| item_type_id | INT UNSIGNED PK | |\r\n| type_name | VARCHAR(100) UNIQUE | Display name |\r\n\r\n#### orders\r\nOrders per visit.\r\n\r\n| Column | Type | Notes |\r\n|--------|------|-------|\r\n| order_id | BIGINT UNSIGNED PK | |\r\n| visit_id | INT UNSIGNED FK | → visits |\r\n| customer_id | INT UNSIGNED FK | → customers |\r\n| created_at | DATETIME | |\r\n| no_tax | TINYINT(1) | Tax exempt |\r\n| picked_up | TINYINT(1) | |\r\n| source_table | VARCHAR(50) | |\r\n\r\n#### order_items\r\nLine items for each alteration within a visit.\r\n\r\n| Column | Type | Notes |\r\n|--------|------|-------|\r\n| order_item_id | BIGINT UNSIGNED PK | |\r\n| order_id | BIGINT UNSIGNED FK | → orders |\r\n| legacy_alteration_id | INT NULL | |\r\n| item_type_id | INT FK | → item_types |\r\n| item_type_name | VARCHAR(100) | |\r\n| description | TEXT | |\r\n| quantity | INT | Default 1 |\r\n| unit_price | DECIMAL(10,2) | |\r\n| total_price | DECIMAL(10,2) | |\r\n| notes | TEXT | Per-item notes |\r\n| color | VARCHAR(100) | Garment color |\r\n| no_tax | TINYINT(1) | Tax exempt |\r\n| is_range_price | TINYINT(1) | |\r\n| range_price_label | VARCHAR(100) | |\r\n| paid_flag | TINYINT(1) | |\r\n| paid_type | VARCHAR(100) | |\r\n| picked_up | TINYINT(1) | |\r\n| created_at | DATETIME | |\r\n\r\n#### order_item_type_links\r\nMany-to-many links between order items and item types.\r\n\r\n| Column | Type | Notes |\r\n|--------|------|-------|\r\n| order_item_type_link_id | BIGINT UNSIGNED PK | |\r\n| order_item_id | BIGINT UNSIGNED FK | → order_items |\r\n| item_type_id | INT UNSIGNED FK | → item_types |\r\n| slot_number | TINYINT UNSIGNED | |\r\n\r\n#### payments\r\nPayment records per order.\r\n\r\n| Column | Type | Notes |\r\n|--------|------|-------|\r\n| payment_id | BIGINT UNSIGNED PK | |\r\n| order_id | BIGINT UNSIGNED FK | → orders |\r\n| payment_date | DATETIME | |\r\n| payment_type | VARCHAR(100) | |\r\n| payment_method | VARCHAR(100) | |\r\n| amount | DECIMAL(10,2) | |\r\n| notes | TEXT | |\r\n\r\n#### tax_payments\r\nTax payment records.\r\n\r\n| Column | Type | Notes |\r\n|--------|------|-------|\r\n| tax_payment_id | INT UNSIGNED PK | |\r\n| legacy_tax_payment_id | INT NULL | |\r\n| payment_date | DATETIME | |\r\n| payment_type | VARCHAR(100) | |\r\n| payment_method | VARCHAR(100) | |\r\n| amount | DECIMAL(10,2) | |\r\n| notes | TEXT | |\r\n| receipt_blob | LONGBLOB | |\r\n\r\n#### change_log\r\nAudit log for changes.\r\n\r\n| Column | Type | Notes |\r\n|--------|------|-------|\r\n| log_id | BIGINT UNSIGNED PK | |\r\n| legacy_log_id | INT NULL | |\r\n| table_name | VARCHAR(100) | |\r\n| record_id | BIGINT | |\r\n| visit_id | INT | |\r\n| field_name | VARCHAR(100) | |\r\n| old_value | TEXT | |\r\n| new_value | TEXT | |\r\n| changed_at | DATETIME | |\r\n| changed_by | VARCHAR(100) | |\r\n\r\n#### ads\r\nAdvertising/articles.\r\n\r\n| Column | Type | Notes |\r\n|--------|------|-------|\r\n| ad_id | INT UNSIGNED PK | |\r\n| legacy_ad_id | INT NULL | |\r\n| article_text | TEXT | |\r\n| article_picture | LONGBLOB | |\r\n| site_submitted | VARCHAR(255) | |\r\n| views | INT | Default 0 |\r\n| date_posted | DATETIME | |\r\n\r\n#### staging_* tables\r\nStaging tables for data migration.\r\n\r\n| Table Name | Purpose |\r\n|------------|---------|\r\n| staging_customer_table_raw | Staging for legacy customer data |\r\n| staging_customer_visits_raw | Staging for legacy visits |\r\n| staging_alteration_items_raw | Staging for items |\r\n\r\n### Additional Backend Tables\r\n\r\n| Table Name | Purpose |\r\n|------------|---------|\r\n| setmore_appointments | Synced from Setmore |\r\n| backend_conversion_job | Document conversion jobs |\r\n| backend_job_runs | Background job execution log |\r\n| customer_totals | Daily customer totals |\r\n| daily_customer_totals | Daily summary totals |\r\n| customer_payment_transactions | Payment ledger |\r\n| legacy_customer_totals_monthly | Monthly totals (legacy) |\r\n| legacy_customer_totals_irs_monthly | IRS monthly reports |\r\n| backend_appointment_workflow | Appointment state machine |\r\n| backend_no_show_log | No-show tracking |\r\n| backend_error_log | Error logging |\r\n| backend_change_log | Change audit log |\r\n| backend_document | Document storage |\r\n| backend_document_version | Document version history |\r\n| backend_speed_dial | Quick links |\r\n| backend_square_terminal_code | Square terminal pairing codes |\r\n| backend_square_terminal_device | Square device registry |\r\n| cron_job | Scheduled job definitions |\r\n| cron_job_run | Cron execution history |\r\n| app_settings | Global configuration |\r\n| app_users | Login accounts |\r\n| remember_tokens | \"Remember Me\" tokens |\r\n| customer_reports | PDF report index |\r\n\r\n---\r\n\r\n## 4. API Endpoints\r\n\r\n### 4.1 Frontend API (port 8895 /api/)\r\n\r\n| Endpoint File | Purpose |\r\n|---------------|---------|\r\n| **customer_get.php** | Get customer by ID |\r\n| **customer_save.php** | Create or update customer |\r\n| **customer_detail.php** | Customer + visits summary |\r\n| **customer_delete.php** | Delete customer |\r\n| **customer_list_hide.php** | Hide customer from list |\r\n| **search_customers.php** | Search by name/phone |\r\n| **visit_get.php** | Get visit + items |\r\n| **visit_save.php** | Create/update visit + items |\r\n| **visit_delete.php** | Delete visit |\r\n| **visit_report_generate.php** | Generate visit report |\r\n| **item_types.php** | List all alteration types |\r\n| **item_type_add.php** | Add new item type |\r\n| **item_type_update.php** | Update item type |\r\n| **item_type_delete.php** | Delete item type |\r\n| **pickups_today.php** | Orders due today |\r\n| **ready.php** | Orders ready for pickup |\r\n| **overdue.php** | Overdue orders |\r\n| **upcoming.php** | Orders due in next N days |\r\n| **workload_7days.php** | 7-day workload |\r\n| **save_signature.php** | Save canvas signature |\r\n| **reports_list.php** | Reports for customer |\r\n| **attach_reports.php** | Index all PDFs to DB |\r\n| **save_signature.php** | Save signature image |\r\n| **today_appointments_list.php** | Today's appointments |\r\n| **settings_get.php** | Get app settings |\r\n| **settings_save.php** | Save app settings |\r\n| **settings_css.php** | Live theme CSS |\r\n| **send_email.php** | Send email via SMTP |\r\n| **send_sms.php** | Send SMS via Twilio |\r\n| **send_reminders.php** | Send appointment reminders |\r\n| **ea_appointments.php** | EasyAppointments REST API |\r\n| **ea_webhook.php** | Receives EA webhook events |\r\n| **setmore.php** | Setmore API proxy |\r\n| **setmore_to_ea_import.php** | Import customers to EA |\r\n| **square_config.php** | Square public config |\r\n| **square_process.php** | Process Square payment |\r\n| **square_customer_log.php** | Customer Square log |\r\n| **square_terminal.php** | Square terminal |\r\n| **login.php** | Authenticate |\r\n| **logout.php** | Clear session |\r\n| **session_check.php** | Check if logged in |\r\n| **auth.php** | Session authentication |\r\n| **config.php** | App config constants |\r\n| **db.php** | Database connection |\r\n| **log_error.php** | Log client-side error |\r\n| **todo_list.php** | Todo list management |\r\n| **send_telegram.php** | Send Telegram messages |\r\n\r\n### 4.2 Management API (port 8894 /api/)\r\n\r\n| Endpoint File | Purpose |\r\n|---------------|---------|\r\n| **login.php** | Authenticate |\r\n| **logout.php** | Clear session |\r\n| **session_check.php** | Check if logged in |\r\n| **customer_detail.php** | Customer + visits |\r\n| **search_customers.php** | Search customers |\r\n| **update_customer.php** | Update customer |\r\n| **users_list.php** | List all users |\r\n| **user_save.php** | Create/update user |\r\n| **list_report_dirs.php** | Date folders |\r\n| **list_report_files.php** | PDFs in folder |\r\n| **report_file.php** | Access report file |\r\n| **pickups_today.php** | Today's pickups |\r\n| **ready.php** | Ready for pickup |\r\n| **overdue.php** | Overdue |\r\n| **settings_get.php** | Get settings |\r\n| **settings_save.php** | Save settings |\r\n| **settings_css.php** | Live CSS theme |\r\n| **imap_list.php** | List IMAP folders |\r\n| **imap_fetch.php** | Fetch emails |\r\n| **imap_send.php** | Send email via IMAP |\r\n| **imap_action.php** | IMAP actions |\r\n| **sms_send_helper.php** | SMS sending helper |\r\n| **sms_webhook_receive.php** | Receive SMS webhooks |\r\n| **sms_inbox_api.php** | SMS inbox API |\r\n| **slideshow_list.php** | Slideshow images |\r\n| **slideshow_upload.php** | Upload slideshow |\r\n| **slideshow_delete.php** | Delete slideshow |\r\n| **users_list.php** | User management |\r\n| **report_list.php** | Report list |\r\n| **debug_filters.php** | Debug filters |\r\n| **sysadmin.php** | System admin |\r\n| **test.php** | Testing endpoint |\r\n\r\n### 4.3 Backend API (C:\\code\\customerdb\\backend\\api\\)\r\n\r\n| Endpoint File | Purpose |\r\n|---------------|---------|\r\n| **customer.php** | Get customer details |\r\n| **customers.php** | List/search customers |\r\n| **customer_save.php** | Save/update customer |\r\n| **visit.php** | Get visit details |\r\n| **visit_delete.php** | Delete visit |\r\n| **appointments.php** | Unified appointments |\r\n| **appointments_summary.php** | Appointment statistics |\r\n| **setmore_appointments.php** | Setmore appointments |\r\n| **setmore_import.php** | Import from Setmore |\r\n| **module_*.php** | Module loaders |\r\n| **alteration_items.php** | Alteration management |\r\n| **alteration_items_summary.php** | Alteration statistics |\r\n| **gold_silver_*.php** | Gold/silver prices |\r\n| **bank_*.php** | Bank transactions |\r\n| **stocks_summary.php** | Stock data |\r\n| **medication_*.php** | Medication tracking |\r\n| **payroll_import.php** | Payroll import |\r\n| **car_maintenance_*.php** | Vehicle maintenance |\r\n| **duke_*.php** | Duke integration |\r\n| **reports_*.php** | Report generation |\r\n| **totals_import.php** | Customer totals import |\r\n| **documents.php** | Document management |\r\n| **document_upload.php** | File uploads |\r\n| **cust_email_*.php** | Email data |\r\n| **mail_*.php** | Email sending |\r\n| **reminders_create.php** | Create reminders |\r\n| **nightly_reports.php** | Nightly reports |\r\n| **morning_jobs.php** | Morning jobs |\r\n| **appointment_workflow.php** | Workflow management |\r\n| **sysadmin.php** | System admin |\r\n| **reporting_module.php** | Reporting |\r\n| **job_runs.php** | Job tracking |\r\n| **health.php** | Health check |\r\n| **overview.php** | Dashboard data |\r\n\r\n---\r\n\r\n## 5. External Integrations\r\n\r\n### 5.1 Square (Payment Processing)\r\n- **Purpose:** Point-of-sale payments, receipts, terminal management\r\n- **Features:**\r\n  - Square Terminal device pairing/management\r\n  - Payment processing with tips\r\n  - Customer payment logging\r\n  - Sandbox and live environments\r\n- **Tables:** `backend_square_terminal_code`, `backend_square_terminal_device`, `square_customer_log`\r\n\r\n### 5.2 Twilio (SMS)\r\n- **Purpose:** SMS notifications and reminders\r\n- **Features:**\r\n  - Send SMS to customers\r\n  - Appointment reminders\r\n  - SMS consent tracking\r\n- **Settings:** `twilio_sid`, `twilio_token`, `twilio_from`\r\n\r\n### 5.3 Setmore (Appointment Booking)\r\n- **Purpose:** Appointment synchronization\r\n- **Features:**\r\n  - Pull appointments from Setmore API\r\n  - Link to customers/visits\r\n- **Table:** `setmore_appointments`\r\n- **Settings:** `setmore_refresh_token`, `setmore_staff_key`\r\n\r\n### 5.4 EasyAppointments (Alternative Booking)\r\n- **Purpose:** Full appointment booking platform\r\n- **Location:** C:\\code\\customerdb\\schedule\\\r\n- **Features:**\r\n  - Customer/provider management\r\n  - Web-based booking widget\r\n  - REST API\r\n\r\n### 5.5 Telegram (Notifications)\r\n- **Purpose:** Bot-based notifications\r\n- **Features:**\r\n  - Send notifications to channels\r\n  - Visit alerts\r\n  - Cron job status\r\n- **Settings:** `telegram_bot_token`, `telegram_chat_id`\r\n\r\n### 5.6 Ollama (AI - Optional)\r\n- **Purpose:** Local AI for email generation\r\n- **Settings:** `ollama_url`, `ollama_default_model`\r\n\r\n---\r\n\r\n## 6. Scheduled Jobs / Cron\r\n\r\n### Configured Cron Jobs\r\n\r\n| Job Label | Schedule | Purpose |\r\n|----------|----------|---------|\r\n| **Next-Day Customer Emails** | `0 20 * * *` (8 PM) | Pickup reminder emails |\r\n| **Morning Import** | `0 6 * * *` (6 AM) | Morning data import |\r\n| **Morning Jobs** | `0 9 * * *` (9 AM) | Appointment sync, workflow |\r\n| **Nightly Reports** | `0 20 * * *` (8 PM) | Generate nightly summaries |\r\n| **Database Backup** | `0 2 * * *` (2 AM) | Full MariaDB backup |\r\n| **Daily Cleanup** | `0 4 * * *` (4 AM) | Temp files, old logs |\r\n| **Auto Delete** | `15 4 * * *` (4:15 AM) | Clean placeholder records |\r\n\r\n### Background Job Scripts (backend/jobs/)\r\n\r\n| Script | Purpose |\r\n|--------|---------|\r\n| **run_morning_jobs.php** | Main morning job runner |\r\n| **smoke_morning_jobs.php** | Smoke test |\r\n| **send_nightly_reports.php** | Nightly report emailer |\r\n| **send_nextday_customer_emails.php** | Next-day reminders |\r\n| **delete_add_name_records.php** | Cleanup job |\r\n| **rebuild_customer_totals.php** | Rebuild totals |\r\n| **rebuild_daily_customer_totals.php** | Rebuild daily totals |\r\n| **rebuild_payment_ledger.php** | Rebuild payment ledger |\r\n| **import_customer_totals_csv.php** | CSV import |\r\n| **backfill_square_customer_log.php** | Square log backfill |\r\n| **run_cron_job.php** | Generic cron runner |\r\n\r\n---\r\n\r\n## 7. Web Applications\r\n\r\n### 7.1 Front Desk App (port 8895)\r\n\r\n| Page | Purpose |\r\n|------|---------|\r\n| **index.html** | Main dashboard, search, stats |\r\n| **customer.html** | Customer detail + visit history |\r\n| **visit.html** | Create/edit alteration order |\r\n| **customer_display.html** | Second monitor display |\r\n| **receipt.html** | Printable receipt |\r\n| **reports.html** | Order list by status |\r\n| **upcoming.html** | Next 7 days pickups |\r\n| **schedule.html** | Appointments calendar |\r\n| **login.html** | Login page |\r\n| **item_types.html** | Item type management |\r\n\r\n### 7.2 Management App (port 8894)\r\n\r\n| Page | Purpose |\r\n|------|---------|\r\n| **index.html** | Login page |\r\n| **webui.html** | Dashboard |\r\n| **customer.html** | Customer detail view |\r\n| **admin.html** | Reports browser |\r\n| **settings.html** | App settings editor |\r\n| **users.html** | User management |\r\n| **reports.html** | Order reports |\r\n\r\n---\r\n\r\n## 8. Settings & Configuration\r\n\r\n### app_settings Keys\r\n\r\n| Key | Purpose |\r\n|-----|---------|\r\n| theme_bg | Page background color |\r\n| theme_panel | Card/panel color |\r\n| theme_text | Text color |\r\n| theme_accent | Accent/button color |\r\n| theme_accent_deep | Darker accent |\r\n| theme_teal | Teal color |\r\n| theme_font | Font family |\r\n| smtp_host | Email server hostname |\r\n| smtp_port | Email server port |\r\n| smtp_secure | tls or ssl |\r\n| smtp_user | Email login |\r\n| smtp_pass | Email password |\r\n| smtp_from_email | From address |\r\n| smtp_from_name | From display name |\r\n| twilio_sid | Twilio Account SID |\r\n| twilio_token | Twilio Auth Token |\r\n| twilio_from | Twilio phone number |\r\n| imap_host | Incoming email server |\r\n| imap_port | IMAP port |\r\n| imap_ssl | SSL enable |\r\n| imap_user | IMAP login |\r\n| imap_pass | IMAP password |\r\n| square_token | Square API token |\r\n| square_location | Square location ID |\r\n| setmore_staff_key | Setmore API key |\r\n| setmore_refresh | Setmore refresh token |\r\n| require_report | PDF required |\r\n| require_signature | Signature required |\r\n| reports_base_path | Reports disk path |\r\n| reports_base_url | Reports URL |\r\n| ollama_url | Ollama AI URL |\r\n| ollama_default_model | Ollama model |\r\n| telegram_bot_token | Telegram bot token |\r\n| telegram_chat_id | Telegram chat ID |\r\n\r\n---\r\n\r\n## 9. Migration Notes\r\n\r\n### Access to MariaDB Workflow\r\n\r\n1. **Export source data from Access**\r\n   - Export ordinary tables to CSV\r\n   - Export attachment fields with VBA or DAO Recordset2 logic\r\n   - Keep original IDs during migration\r\n\r\n2. **Load into MariaDB staging**\r\n   - Use `LOAD DATA LOCAL INFILE` for CSV files\r\n   - Load signatures separately into `visit_signatures`\r\n\r\n3. **Normalize**\r\n   - `CustomerTable` → `customers`\r\n   - `CustomerVisits` → `visits`\r\n   - `AlterationItems` → `orders`, `order_items`, `order_item_type_links`\r\n   - `2024TaxPayments` → `tax_payments`\r\n   - `AlterationItemsChangeLog` → `change_log`\r\n\r\n4. **Signature BLOB path**\r\n   - Export Access attachment to temp file\r\n   - Convert BMP to PNG\r\n   - Insert PNG bytes into `visit_signatures.signature_image`\r\n\r\n5. **Validation**\r\n   - Compare source row counts vs target\r\n   - Compare distinct legacy IDs\r\n   - Compare sample signatures by SHA256\r\n\r\n---\r\n\r\n## 10. Scripts & Tools\r\n\r\n### PowerShell Scripts (scripts/)\r\n\r\n| Script | Purpose |\r\n|--------|---------|\r\n| **import_legacy_totals_from_excel.ps1** | Import totals from Excel |\r\n| **sync_backend_mirror.ps1** | Sync backend mirror |\r\n| **check_backend_mirror.ps1** | Check mirror status |\r\n\r\n### Python Scripts (scripts/)\r\n\r\n| Script | Purpose |\r\n|--------|---------|\r\n| **signature_blob_loader.py** | Load signature blobs |\r\n| **access_to_mariadb_parser.py** | Parse Access to MariaDB |\r\n| **import_access_v2.py** | Import Access v2 |\r\n| **import_csv_v2.py** | Import CSV v2 |\r\n\r\n### SQL Migrations (migrations/)\r\n\r\n| File | Purpose |\r\n|------|---------|\r\n| **20260407_add_conversion_job.sql** | Add conversion job table |\r\n| **20260411_order_items_item_type_name_no_fk.sql** | Order items no FK |\r\n| **20260416_blog_prompt_templates.sql** | Blog prompt templates |\r\n\r\n---\r\n\r\n## File Statistics\r\n\r\n- **Total PHP files:** 200+\r\n- **Total SQL files:** 100+\r\n- **Total HTML pages:** 20+\r\n- **Database tables:** 30+\r\n\r\n---\r\n\r\n*End of Documentation*","content_html":"<h1>Ella&#039;s Alterations - Comprehensive System Documentation</h1>\n<p><strong>Generated:</strong> April 17, 2026</p>\n<p><strong>Location:</strong> C:\\code\\customerdb</p>\n<p>---</p>\n<h2>Table of Contents</h2>\n<p>1. [System Overview](#1-system-overview)</p>\n<p>2. [Directory Structure](#2-directory-structure)</p>\n<p>3. [Database Schema](#3-database-schema)</p>\n<p>4. [API Endpoints](#4-api-endpoints)</p>\n<p>5. [External Integrations](#5-external-integrations)</p>\n<p>6. [Scheduled Jobs / Cron](#6-scheduled-jobs--cron)</p>\n<p>7. [Web Applications](#7-web-applications)</p>\n<p>8. [Settings &amp; Configuration](#8-settings--configuration)</p>\n<p>9. [Migration Notes](#9-migration-notes)</p>\n<p>10. [Scripts &amp; Tools](#10-scripts--tools)</p>\n<p>---</p>\n<h2>1. System Overview</h2>\n<h3>Purpose</h3>\n<p>Ella&#039;s Alterations is a comprehensive customer relationship management (CRM) andAlteration tracking system for a tailor shop. It manages customers, visits/alteration orders, appointments, payments, and provides integration with external services.</p>\n<h3>Server Information</h3>\n<ul>\n<li><strong>Primary Server:</strong> kefa@192.168.7.202</li>\n<li><strong>Mirror Drive:</strong> /mnt/drive2 (mirrors /mnt/drive1)</li>\n<li><strong>Database:</strong> MariaDB - database `ellas_alterations`, user `kefa_admin`</li>\n<li><strong>Web Server:</strong> Apache 2.4 with mod-php</li>\n<li><strong>PHP Version:</strong> 8.3</li>\n</ul>\n<h3>Three Web Applications</h3>\n<p>| App | Local URL | Public URL | Purpose |</p>\n<p>|-----|-----------|------------|---------|</p>\n<p>| Front Desk | http://192.168.7.202:8895 | https://ella.floridaalterations.com | Customer-facing operations |</p>\n<p>| Management | http://192.168.7.202:8894 | (LAN only) | Reports, admin, settings |</p>\n<p>| Scheduler | http://192.168.7.202:8897 | https://schedule.floridaalterations.com | Easy!Appointments booking |</p>\n<p>---</p>\n<h2>2. Directory Structure</h2>\n<p>```</p>\n<p>customerdb/</p>\n<p>├── backend/                    # Main PHP backend API and services</p>\n<p>│   ├── api/                    # REST API endpoints (~57 files)</p>\n<p>│   ├── bin/                    # Binary/executable scripts</p>\n<p>│   ├── backup/                # Backup versions of services</p>\n<p>│   └── jobs/                  # Background job scripts</p>\n<p>├── frontend/                   # Front Desk app (port 8895)</p>\n<p>│   ├── *.html                 # HTML pages</p>\n<p>│   ├── api/                   # PHP API endpoints</p>\n<p>│   └── reports/               # PDF reports (MMDDYYYY/filename.pdf)</p>\n<p>├── webui/                      # Management app (port 8894)</p>\n<p>│   ├── *.html                 # HTML pages</p>\n<p>│   ├── api/                  # PHP API endpoints</p>\n<p>│   ├── backend/               # Backend API copy</p>\n<p>│   └── email/                # Email templates</p>\n<p>├── schedule/                   # Easy!Appointments installation</p>\n<p>├── schema/                    # Database schema files</p>\n<p>├── migrations/               # SQL migrations</p>\n<p>├── scripts/                   # PowerShell/Python import scripts</p>\n<p>├── docs/                     # Documentation</p>\n<p>├── blog/                     # Blog system and reengineering</p>\n<p>├── csv/                      # CSV data files</p>\n<p>├── backups/                  # Backup archives</p>\n<p>├── Topaz/                    # Topaz signature pad configs</p>\n<p>├── webui/                    # Second web interface</p>\n<p>│   ├── api/</p>\n<p>│   ├── backend/</p>\n<p>│   └── frontend/</p>\n<p>├── notused/                  # Deprecated/unused files</p>\n<p>└── wordpress-plugin/          # WordPress integration</p>\n<p>```</p>\n<p>---</p>\n<h2>3. Database Schema</h2>\n<h3>Core Tables (from mariadb_core_schema.sql)</h3>\n<p>#### customers</p>\n<p>Main customer registry.</p>\n<p>| Column | Type | Notes |</p>\n<p>|--------|------|-------|</p>\n<p>| customer_id | INT UNSIGNED PK | Auto-increment |</p>\n<p>| legacy_customer_id | INT NULL | Original Access DB ID |</p>\n<p>| created_at | DATETIME | Record creation time |</p>\n<p>| full_name | VARCHAR(200) | Customer full name |</p>\n<p>| phone | VARCHAR(30) | Formatted (XXX) XXX-XXXX |</p>\n<p>| email | VARCHAR(255) | Email address |</p>\n<p>| pickup_due_at | DATETIME | Next pickup date (synced from EA) |</p>\n<p>| description | TEXT | Description |</p>\n<p>| notes | TEXT | Internal notes |</p>\n<p>| is_new_customer | TINYINT(1) | 1 if flagged as new |</p>\n<p>#### visits</p>\n<p>One row per alteration job/order.</p>\n<p>| Column | Type | Notes |</p>\n<p>|--------|------|-------|</p>\n<p>| visit_id | INT UNSIGNED PK | |</p>\n<p>| legacy_visit_id | INT NULL | Original Access DB ID |</p>\n<p>| customer_id | INT UNSIGNED FK | → customers |</p>\n<p>| visit_date | DATETIME | Drop-off date |</p>\n<p>| pickup_date | DATETIME | Expected pickup |</p>\n<p>| notes | TEXT | General visit notes |</p>\n<p>| customer_name_snapshot | VARCHAR(200) | |</p>\n<p>| phone_snapshot | VARCHAR(30) | |</p>\n<p>| email_snapshot | VARCHAR(255) | |</p>\n<p>| color | VARCHAR(100) | Garment color |</p>\n<p>| alterations_needed | TEXT | |</p>\n<p>| alterations_notes | TEXT | Detailed alteration instructions |</p>\n<p>| alterations_price | DECIMAL(10,2) | Manual price field |</p>\n<p>| total_alteration_price | DECIMAL(10,2) | Calculated from items |</p>\n<p>| expedited_fee | DECIMAL(10,2) | |</p>\n<p>| paid_date | DATETIME | When paid |</p>\n<p>| signature_text | TEXT | Text signature (legacy) |</p>\n<p>| signature_date | DATETIME | |</p>\n<p>| paid_flag | TINYINT(1) | 1 = paid |</p>\n<p>| source_key_value | VARCHAR(100) | |</p>\n<p>#### visit_signatures</p>\n<p>Full resolution signature images per visit.</p>\n<p>| Column | Type | Notes |</p>\n<p>|--------|------|-------|</p>\n<p>| signature_id | BIGINT UNSIGNED PK | |</p>\n<p>| visit_id | INT UNIQUE | One signature per visit |</p>\n<p>| signature_date | DATETIME | |</p>\n<p>| image_format | VARCHAR(50) | Default &#039;image/png&#039; |</p>\n<p>| original_filename | VARCHAR(255) | |</p>\n<p>| original_extension | VARCHAR(20) | |</p>\n<p>| file_size_bytes | BIGINT | |</p>\n<p>| sha256_hash | CHAR(64) | Hash for verification |</p>\n<p>| signature_image | LONGBLOB | Raw PNG binary |</p>\n<p>| created_at | DATETIME | |</p>\n<p>#### item_types</p>\n<p>Master list of alteration types (e.g., Hem, Zipper, Taper).</p>\n<p>| Column | Type | Notes |</p>\n<p>|--------|------|-------|</p>\n<p>| item_type_id | INT UNSIGNED PK | |</p>\n<p>| type_name | VARCHAR(100) UNIQUE | Display name |</p>\n<p>#### orders</p>\n<p>Orders per visit.</p>\n<p>| Column | Type | Notes |</p>\n<p>|--------|------|-------|</p>\n<p>| order_id | BIGINT UNSIGNED PK | |</p>\n<p>| visit_id | INT UNSIGNED FK | → visits |</p>\n<p>| customer_id | INT UNSIGNED FK | → customers |</p>\n<p>| created_at | DATETIME | |</p>\n<p>| no_tax | TINYINT(1) | Tax exempt |</p>\n<p>| picked_up | TINYINT(1) | |</p>\n<p>| source_table | VARCHAR(50) | |</p>\n<p>#### order_items</p>\n<p>Line items for each alteration within a visit.</p>\n<p>| Column | Type | Notes |</p>\n<p>|--------|------|-------|</p>\n<p>| order_item_id | BIGINT UNSIGNED PK | |</p>\n<p>| order_id | BIGINT UNSIGNED FK | → orders |</p>\n<p>| legacy_alteration_id | INT NULL | |</p>\n<p>| item_type_id | INT FK | → item_types |</p>\n<p>| item_type_name | VARCHAR(100) | |</p>\n<p>| description | TEXT | |</p>\n<p>| quantity | INT | Default 1 |</p>\n<p>| unit_price | DECIMAL(10,2) | |</p>\n<p>| total_price | DECIMAL(10,2) | |</p>\n<p>| notes | TEXT | Per-item notes |</p>\n<p>| color | VARCHAR(100) | Garment color |</p>\n<p>| no_tax | TINYINT(1) | Tax exempt |</p>\n<p>| is_range_price | TINYINT(1) | |</p>\n<p>| range_price_label | VARCHAR(100) | |</p>\n<p>| paid_flag | TINYINT(1) | |</p>\n<p>| paid_type | VARCHAR(100) | |</p>\n<p>| picked_up | TINYINT(1) | |</p>\n<p>| created_at | DATETIME | |</p>\n<p>#### order_item_type_links</p>\n<p>Many-to-many links between order items and item types.</p>\n<p>| Column | Type | Notes |</p>\n<p>|--------|------|-------|</p>\n<p>| order_item_type_link_id | BIGINT UNSIGNED PK | |</p>\n<p>| order_item_id | BIGINT UNSIGNED FK | → order_items |</p>\n<p>| item_type_id | INT UNSIGNED FK | → item_types |</p>\n<p>| slot_number | TINYINT UNSIGNED | |</p>\n<p>#### payments</p>\n<p>Payment records per order.</p>\n<p>| Column | Type | Notes |</p>\n<p>|--------|------|-------|</p>\n<p>| payment_id | BIGINT UNSIGNED PK | |</p>\n<p>| order_id | BIGINT UNSIGNED FK | → orders |</p>\n<p>| payment_date | DATETIME | |</p>\n<p>| payment_type | VARCHAR(100) | |</p>\n<p>| payment_method | VARCHAR(100) | |</p>\n<p>| amount | DECIMAL(10,2) | |</p>\n<p>| notes | TEXT | |</p>\n<p>#### tax_payments</p>\n<p>Tax payment records.</p>\n<p>| Column | Type | Notes |</p>\n<p>|--------|------|-------|</p>\n<p>| tax_payment_id | INT UNSIGNED PK | |</p>\n<p>| legacy_tax_payment_id | INT NULL | |</p>\n<p>| payment_date | DATETIME | |</p>\n<p>| payment_type | VARCHAR(100) | |</p>\n<p>| payment_method | VARCHAR(100) | |</p>\n<p>| amount | DECIMAL(10,2) | |</p>\n<p>| notes | TEXT | |</p>\n<p>| receipt_blob | LONGBLOB | |</p>\n<p>#### change_log</p>\n<p>Audit log for changes.</p>\n<p>| Column | Type | Notes |</p>\n<p>|--------|------|-------|</p>\n<p>| log_id | BIGINT UNSIGNED PK | |</p>\n<p>| legacy_log_id | INT NULL | |</p>\n<p>| table_name | VARCHAR(100) | |</p>\n<p>| record_id | BIGINT | |</p>\n<p>| visit_id | INT | |</p>\n<p>| field_name | VARCHAR(100) | |</p>\n<p>| old_value | TEXT | |</p>\n<p>| new_value | TEXT | |</p>\n<p>| changed_at | DATETIME | |</p>\n<p>| changed_by | VARCHAR(100) | |</p>\n<p>#### ads</p>\n<p>Advertising/articles.</p>\n<p>| Column | Type | Notes |</p>\n<p>|--------|------|-------|</p>\n<p>| ad_id | INT UNSIGNED PK | |</p>\n<p>| legacy_ad_id | INT NULL | |</p>\n<p>| article_text | TEXT | |</p>\n<p>| article_picture | LONGBLOB | |</p>\n<p>| site_submitted | VARCHAR(255) | |</p>\n<p>| views | INT | Default 0 |</p>\n<p>| date_posted | DATETIME | |</p>\n<p>#### staging_* tables</p>\n<p>Staging tables for data migration.</p>\n<p>| Table Name | Purpose |</p>\n<p>|------------|---------|</p>\n<p>| staging_customer_table_raw | Staging for legacy customer data |</p>\n<p>| staging_customer_visits_raw | Staging for legacy visits |</p>\n<p>| staging_alteration_items_raw | Staging for items |</p>\n<h3>Additional Backend Tables</h3>\n<p>| Table Name | Purpose |</p>\n<p>|------------|---------|</p>\n<p>| setmore_appointments | Synced from Setmore |</p>\n<p>| backend_conversion_job | Document conversion jobs |</p>\n<p>| backend_job_runs | Background job execution log |</p>\n<p>| customer_totals | Daily customer totals |</p>\n<p>| daily_customer_totals | Daily summary totals |</p>\n<p>| customer_payment_transactions | Payment ledger |</p>\n<p>| legacy_customer_totals_monthly | Monthly totals (legacy) |</p>\n<p>| legacy_customer_totals_irs_monthly | IRS monthly reports |</p>\n<p>| backend_appointment_workflow | Appointment state machine |</p>\n<p>| backend_no_show_log | No-show tracking |</p>\n<p>| backend_error_log | Error logging |</p>\n<p>| backend_change_log | Change audit log |</p>\n<p>| backend_document | Document storage |</p>\n<p>| backend_document_version | Document version history |</p>\n<p>| backend_speed_dial | Quick links |</p>\n<p>| backend_square_terminal_code | Square terminal pairing codes |</p>\n<p>| backend_square_terminal_device | Square device registry |</p>\n<p>| cron_job | Scheduled job definitions |</p>\n<p>| cron_job_run | Cron execution history |</p>\n<p>| app_settings | Global configuration |</p>\n<p>| app_users | Login accounts |</p>\n<p>| remember_tokens | &quot;Remember Me&quot; tokens |</p>\n<p>| customer_reports | PDF report index |</p>\n<p>---</p>\n<h2>4. API Endpoints</h2>\n<h3>4.1 Frontend API (port 8895 /api/)</h3>\n<p>| Endpoint File | Purpose |</p>\n<p>|---------------|---------|</p>\n<p>| <strong>customer_get.php</strong> | Get customer by ID |</p>\n<p>| <strong>customer_save.php</strong> | Create or update customer |</p>\n<p>| <strong>customer_detail.php</strong> | Customer + visits summary |</p>\n<p>| <strong>customer_delete.php</strong> | Delete customer |</p>\n<p>| <strong>customer_list_hide.php</strong> | Hide customer from list |</p>\n<p>| <strong>search_customers.php</strong> | Search by name/phone |</p>\n<p>| <strong>visit_get.php</strong> | Get visit + items |</p>\n<p>| <strong>visit_save.php</strong> | Create/update visit + items |</p>\n<p>| <strong>visit_delete.php</strong> | Delete visit |</p>\n<p>| <strong>visit_report_generate.php</strong> | Generate visit report |</p>\n<p>| <strong>item_types.php</strong> | List all alteration types |</p>\n<p>| <strong>item_type_add.php</strong> | Add new item type |</p>\n<p>| <strong>item_type_update.php</strong> | Update item type |</p>\n<p>| <strong>item_type_delete.php</strong> | Delete item type |</p>\n<p>| <strong>pickups_today.php</strong> | Orders due today |</p>\n<p>| <strong>ready.php</strong> | Orders ready for pickup |</p>\n<p>| <strong>overdue.php</strong> | Overdue orders |</p>\n<p>| <strong>upcoming.php</strong> | Orders due in next N days |</p>\n<p>| <strong>workload_7days.php</strong> | 7-day workload |</p>\n<p>| <strong>save_signature.php</strong> | Save canvas signature |</p>\n<p>| <strong>reports_list.php</strong> | Reports for customer |</p>\n<p>| <strong>attach_reports.php</strong> | Index all PDFs to DB |</p>\n<p>| <strong>save_signature.php</strong> | Save signature image |</p>\n<p>| <strong>today_appointments_list.php</strong> | Today&#039;s appointments |</p>\n<p>| <strong>settings_get.php</strong> | Get app settings |</p>\n<p>| <strong>settings_save.php</strong> | Save app settings |</p>\n<p>| <strong>settings_css.php</strong> | Live theme CSS |</p>\n<p>| <strong>send_email.php</strong> | Send email via SMTP |</p>\n<p>| <strong>send_sms.php</strong> | Send SMS via Twilio |</p>\n<p>| <strong>send_reminders.php</strong> | Send appointment reminders |</p>\n<p>| <strong>ea_appointments.php</strong> | EasyAppointments REST API |</p>\n<p>| <strong>ea_webhook.php</strong> | Receives EA webhook events |</p>\n<p>| <strong>setmore.php</strong> | Setmore API proxy |</p>\n<p>| <strong>setmore_to_ea_import.php</strong> | Import customers to EA |</p>\n<p>| <strong>square_config.php</strong> | Square public config |</p>\n<p>| <strong>square_process.php</strong> | Process Square payment |</p>\n<p>| <strong>square_customer_log.php</strong> | Customer Square log |</p>\n<p>| <strong>square_terminal.php</strong> | Square terminal |</p>\n<p>| <strong>login.php</strong> | Authenticate |</p>\n<p>| <strong>logout.php</strong> | Clear session |</p>\n<p>| <strong>session_check.php</strong> | Check if logged in |</p>\n<p>| <strong>auth.php</strong> | Session authentication |</p>\n<p>| <strong>config.php</strong> | App config constants |</p>\n<p>| <strong>db.php</strong> | Database connection |</p>\n<p>| <strong>log_error.php</strong> | Log client-side error |</p>\n<p>| <strong>todo_list.php</strong> | Todo list management |</p>\n<p>| <strong>send_telegram.php</strong> | Send Telegram messages |</p>\n<h3>4.2 Management API (port 8894 /api/)</h3>\n<p>| Endpoint File | Purpose |</p>\n<p>|---------------|---------|</p>\n<p>| <strong>login.php</strong> | Authenticate |</p>\n<p>| <strong>logout.php</strong> | Clear session |</p>\n<p>| <strong>session_check.php</strong> | Check if logged in |</p>\n<p>| <strong>customer_detail.php</strong> | Customer + visits |</p>\n<p>| <strong>search_customers.php</strong> | Search customers |</p>\n<p>| <strong>update_customer.php</strong> | Update customer |</p>\n<p>| <strong>users_list.php</strong> | List all users |</p>\n<p>| <strong>user_save.php</strong> | Create/update user |</p>\n<p>| <strong>list_report_dirs.php</strong> | Date folders |</p>\n<p>| <strong>list_report_files.php</strong> | PDFs in folder |</p>\n<p>| <strong>report_file.php</strong> | Access report file |</p>\n<p>| <strong>pickups_today.php</strong> | Today&#039;s pickups |</p>\n<p>| <strong>ready.php</strong> | Ready for pickup |</p>\n<p>| <strong>overdue.php</strong> | Overdue |</p>\n<p>| <strong>settings_get.php</strong> | Get settings |</p>\n<p>| <strong>settings_save.php</strong> | Save settings |</p>\n<p>| <strong>settings_css.php</strong> | Live CSS theme |</p>\n<p>| <strong>imap_list.php</strong> | List IMAP folders |</p>\n<p>| <strong>imap_fetch.php</strong> | Fetch emails |</p>\n<p>| <strong>imap_send.php</strong> | Send email via IMAP |</p>\n<p>| <strong>imap_action.php</strong> | IMAP actions |</p>\n<p>| <strong>sms_send_helper.php</strong> | SMS sending helper |</p>\n<p>| <strong>sms_webhook_receive.php</strong> | Receive SMS webhooks |</p>\n<p>| <strong>sms_inbox_api.php</strong> | SMS inbox API |</p>\n<p>| <strong>slideshow_list.php</strong> | Slideshow images |</p>\n<p>| <strong>slideshow_upload.php</strong> | Upload slideshow |</p>\n<p>| <strong>slideshow_delete.php</strong> | Delete slideshow |</p>\n<p>| <strong>users_list.php</strong> | User management |</p>\n<p>| <strong>report_list.php</strong> | Report list |</p>\n<p>| <strong>debug_filters.php</strong> | Debug filters |</p>\n<p>| <strong>sysadmin.php</strong> | System admin |</p>\n<p>| <strong>test.php</strong> | Testing endpoint |</p>\n<h3>4.3 Backend API (C:\\code\\customerdb\\backend\\api\\)</h3>\n<p>| Endpoint File | Purpose |</p>\n<p>|---------------|---------|</p>\n<p>| <strong>customer.php</strong> | Get customer details |</p>\n<p>| <strong>customers.php</strong> | List/search customers |</p>\n<p>| <strong>customer_save.php</strong> | Save/update customer |</p>\n<p>| <strong>visit.php</strong> | Get visit details |</p>\n<p>| <strong>visit_delete.php</strong> | Delete visit |</p>\n<p>| <strong>appointments.php</strong> | Unified appointments |</p>\n<p>| <strong>appointments_summary.php</strong> | Appointment statistics |</p>\n<p>| <strong>setmore_appointments.php</strong> | Setmore appointments |</p>\n<p>| <strong>setmore_import.php</strong> | Import from Setmore |</p>\n<p>| <strong>module_*.php</strong> | Module loaders |</p>\n<p>| <strong>alteration_items.php</strong> | Alteration management |</p>\n<p>| <strong>alteration_items_summary.php</strong> | Alteration statistics |</p>\n<p>| <strong>gold_silver_*.php</strong> | Gold/silver prices |</p>\n<p>| <strong>bank_*.php</strong> | Bank transactions |</p>\n<p>| <strong>stocks_summary.php</strong> | Stock data |</p>\n<p>| <strong>medication_*.php</strong> | Medication tracking |</p>\n<p>| <strong>payroll_import.php</strong> | Payroll import |</p>\n<p>| <strong>car_maintenance_*.php</strong> | Vehicle maintenance |</p>\n<p>| <strong>duke_*.php</strong> | Duke integration |</p>\n<p>| <strong>reports_*.php</strong> | Report generation |</p>\n<p>| <strong>totals_import.php</strong> | Customer totals import |</p>\n<p>| <strong>documents.php</strong> | Document management |</p>\n<p>| <strong>document_upload.php</strong> | File uploads |</p>\n<p>| <strong>cust_email_*.php</strong> | Email data |</p>\n<p>| <strong>mail_*.php</strong> | Email sending |</p>\n<p>| <strong>reminders_create.php</strong> | Create reminders |</p>\n<p>| <strong>nightly_reports.php</strong> | Nightly reports |</p>\n<p>| <strong>morning_jobs.php</strong> | Morning jobs |</p>\n<p>| <strong>appointment_workflow.php</strong> | Workflow management |</p>\n<p>| <strong>sysadmin.php</strong> | System admin |</p>\n<p>| <strong>reporting_module.php</strong> | Reporting |</p>\n<p>| <strong>job_runs.php</strong> | Job tracking |</p>\n<p>| <strong>health.php</strong> | Health check |</p>\n<p>| <strong>overview.php</strong> | Dashboard data |</p>\n<p>---</p>\n<h2>5. External Integrations</h2>\n<h3>5.1 Square (Payment Processing)</h3>\n<ul>\n<li><strong>Purpose:</strong> Point-of-sale payments, receipts, terminal management</li>\n<li><strong>Features:</strong></li>\n<li>Square Terminal device pairing/management</li>\n<li>Payment processing with tips</li>\n<li>Customer payment logging</li>\n<li>Sandbox and live environments</li>\n<li><strong>Tables:</strong> `backend_square_terminal_code`, `backend_square_terminal_device`, `square_customer_log`</li>\n</ul>\n<h3>5.2 Twilio (SMS)</h3>\n<ul>\n<li><strong>Purpose:</strong> SMS notifications and reminders</li>\n<li><strong>Features:</strong></li>\n<li>Send SMS to customers</li>\n<li>Appointment reminders</li>\n<li>SMS consent tracking</li>\n<li><strong>Settings:</strong> `twilio_sid`, `twilio_token`, `twilio_from`</li>\n</ul>\n<h3>5.3 Setmore (Appointment Booking)</h3>\n<ul>\n<li><strong>Purpose:</strong> Appointment synchronization</li>\n<li><strong>Features:</strong></li>\n<li>Pull appointments from Setmore API</li>\n<li>Link to customers/visits</li>\n<li><strong>Table:</strong> `setmore_appointments`</li>\n<li><strong>Settings:</strong> `setmore_refresh_token`, `setmore_staff_key`</li>\n</ul>\n<h3>5.4 EasyAppointments (Alternative Booking)</h3>\n<ul>\n<li><strong>Purpose:</strong> Full appointment booking platform</li>\n<li><strong>Location:</strong> C:\\code\\customerdb\\schedule\\</li>\n<li><strong>Features:</strong></li>\n<li>Customer/provider management</li>\n<li>Web-based booking widget</li>\n<li>REST API</li>\n</ul>\n<h3>5.5 Telegram (Notifications)</h3>\n<ul>\n<li><strong>Purpose:</strong> Bot-based notifications</li>\n<li><strong>Features:</strong></li>\n<li>Send notifications to channels</li>\n<li>Visit alerts</li>\n<li>Cron job status</li>\n<li><strong>Settings:</strong> `telegram_bot_token`, `telegram_chat_id`</li>\n</ul>\n<h3>5.6 Ollama (AI - Optional)</h3>\n<ul>\n<li><strong>Purpose:</strong> Local AI for email generation</li>\n<li><strong>Settings:</strong> `ollama_url`, `ollama_default_model`</li>\n</ul>\n<p>---</p>\n<h2>6. Scheduled Jobs / Cron</h2>\n<h3>Configured Cron Jobs</h3>\n<p>| Job Label | Schedule | Purpose |</p>\n<p>|----------|----------|---------|</p>\n<p>| <strong>Next-Day Customer Emails</strong> | `0 20 <em> </em> *` (8 PM) | Pickup reminder emails |</p>\n<p>| <strong>Morning Import</strong> | `0 6 <em> </em> *` (6 AM) | Morning data import |</p>\n<p>| <strong>Morning Jobs</strong> | `0 9 <em> </em> *` (9 AM) | Appointment sync, workflow |</p>\n<p>| <strong>Nightly Reports</strong> | `0 20 <em> </em> *` (8 PM) | Generate nightly summaries |</p>\n<p>| <strong>Database Backup</strong> | `0 2 <em> </em> *` (2 AM) | Full MariaDB backup |</p>\n<p>| <strong>Daily Cleanup</strong> | `0 4 <em> </em> *` (4 AM) | Temp files, old logs |</p>\n<p>| <strong>Auto Delete</strong> | `15 4 <em> </em> *` (4:15 AM) | Clean placeholder records |</p>\n<h3>Background Job Scripts (backend/jobs/)</h3>\n<p>| Script | Purpose |</p>\n<p>|--------|---------|</p>\n<p>| <strong>run_morning_jobs.php</strong> | Main morning job runner |</p>\n<p>| <strong>smoke_morning_jobs.php</strong> | Smoke test |</p>\n<p>| <strong>send_nightly_reports.php</strong> | Nightly report emailer |</p>\n<p>| <strong>send_nextday_customer_emails.php</strong> | Next-day reminders |</p>\n<p>| <strong>delete_add_name_records.php</strong> | Cleanup job |</p>\n<p>| <strong>rebuild_customer_totals.php</strong> | Rebuild totals |</p>\n<p>| <strong>rebuild_daily_customer_totals.php</strong> | Rebuild daily totals |</p>\n<p>| <strong>rebuild_payment_ledger.php</strong> | Rebuild payment ledger |</p>\n<p>| <strong>import_customer_totals_csv.php</strong> | CSV import |</p>\n<p>| <strong>backfill_square_customer_log.php</strong> | Square log backfill |</p>\n<p>| <strong>run_cron_job.php</strong> | Generic cron runner |</p>\n<p>---</p>\n<h2>7. Web Applications</h2>\n<h3>7.1 Front Desk App (port 8895)</h3>\n<p>| Page | Purpose |</p>\n<p>|------|---------|</p>\n<p>| <strong>index.html</strong> | Main dashboard, search, stats |</p>\n<p>| <strong>customer.html</strong> | Customer detail + visit history |</p>\n<p>| <strong>visit.html</strong> | Create/edit alteration order |</p>\n<p>| <strong>customer_display.html</strong> | Second monitor display |</p>\n<p>| <strong>receipt.html</strong> | Printable receipt |</p>\n<p>| <strong>reports.html</strong> | Order list by status |</p>\n<p>| <strong>upcoming.html</strong> | Next 7 days pickups |</p>\n<p>| <strong>schedule.html</strong> | Appointments calendar |</p>\n<p>| <strong>login.html</strong> | Login page |</p>\n<p>| <strong>item_types.html</strong> | Item type management |</p>\n<h3>7.2 Management App (port 8894)</h3>\n<p>| Page | Purpose |</p>\n<p>|------|---------|</p>\n<p>| <strong>index.html</strong> | Login page |</p>\n<p>| <strong>webui.html</strong> | Dashboard |</p>\n<p>| <strong>customer.html</strong> | Customer detail view |</p>\n<p>| <strong>admin.html</strong> | Reports browser |</p>\n<p>| <strong>settings.html</strong> | App settings editor |</p>\n<p>| <strong>users.html</strong> | User management |</p>\n<p>| <strong>reports.html</strong> | Order reports |</p>\n<p>---</p>\n<h2>8. Settings &amp; Configuration</h2>\n<h3>app_settings Keys</h3>\n<p>| Key | Purpose |</p>\n<p>|-----|---------|</p>\n<p>| theme_bg | Page background color |</p>\n<p>| theme_panel | Card/panel color |</p>\n<p>| theme_text | Text color |</p>\n<p>| theme_accent | Accent/button color |</p>\n<p>| theme_accent_deep | Darker accent |</p>\n<p>| theme_teal | Teal color |</p>\n<p>| theme_font | Font family |</p>\n<p>| smtp_host | Email server hostname |</p>\n<p>| smtp_port | Email server port |</p>\n<p>| smtp_secure | tls or ssl |</p>\n<p>| smtp_user | Email login |</p>\n<p>| smtp_pass | Email password |</p>\n<p>| smtp_from_email | From address |</p>\n<p>| smtp_from_name | From display name |</p>\n<p>| twilio_sid | Twilio Account SID |</p>\n<p>| twilio_token | Twilio Auth Token |</p>\n<p>| twilio_from | Twilio phone number |</p>\n<p>| imap_host | Incoming email server |</p>\n<p>| imap_port | IMAP port |</p>\n<p>| imap_ssl | SSL enable |</p>\n<p>| imap_user | IMAP login |</p>\n<p>| imap_pass | IMAP password |</p>\n<p>| square_token | Square API token |</p>\n<p>| square_location | Square location ID |</p>\n<p>| setmore_staff_key | Setmore API key |</p>\n<p>| setmore_refresh | Setmore refresh token |</p>\n<p>| require_report | PDF required |</p>\n<p>| require_signature | Signature required |</p>\n<p>| reports_base_path | Reports disk path |</p>\n<p>| reports_base_url | Reports URL |</p>\n<p>| ollama_url | Ollama AI URL |</p>\n<p>| ollama_default_model | Ollama model |</p>\n<p>| telegram_bot_token | Telegram bot token |</p>\n<p>| telegram_chat_id | Telegram chat ID |</p>\n<p>---</p>\n<h2>9. Migration Notes</h2>\n<h3>Access to MariaDB Workflow</h3>\n<p>1. <strong>Export source data from Access</strong></p>\n<ul>\n<li>Export ordinary tables to CSV</li>\n<li>Export attachment fields with VBA or DAO Recordset2 logic</li>\n<li>Keep original IDs during migration</li>\n</ul>\n<p>2. <strong>Load into MariaDB staging</strong></p>\n<ul>\n<li>Use `LOAD DATA LOCAL INFILE` for CSV files</li>\n<li>Load signatures separately into `visit_signatures`</li>\n</ul>\n<p>3. <strong>Normalize</strong></p>\n<ul>\n<li>`CustomerTable` → `customers`</li>\n<li>`CustomerVisits` → `visits`</li>\n<li>`AlterationItems` → `orders`, `order_items`, `order_item_type_links`</li>\n<li>`2024TaxPayments` → `tax_payments`</li>\n<li>`AlterationItemsChangeLog` → `change_log`</li>\n</ul>\n<p>4. <strong>Signature BLOB path</strong></p>\n<ul>\n<li>Export Access attachment to temp file</li>\n<li>Convert BMP to PNG</li>\n<li>Insert PNG bytes into `visit_signatures.signature_image`</li>\n</ul>\n<p>5. <strong>Validation</strong></p>\n<ul>\n<li>Compare source row counts vs target</li>\n<li>Compare distinct legacy IDs</li>\n<li>Compare sample signatures by SHA256</li>\n</ul>\n<p>---</p>\n<h2>10. Scripts &amp; Tools</h2>\n<h3>PowerShell Scripts (scripts/)</h3>\n<p>| Script | Purpose |</p>\n<p>|--------|---------|</p>\n<p>| <strong>import_legacy_totals_from_excel.ps1</strong> | Import totals from Excel |</p>\n<p>| <strong>sync_backend_mirror.ps1</strong> | Sync backend mirror |</p>\n<p>| <strong>check_backend_mirror.ps1</strong> | Check mirror status |</p>\n<h3>Python Scripts (scripts/)</h3>\n<p>| Script | Purpose |</p>\n<p>|--------|---------|</p>\n<p>| <strong>signature_blob_loader.py</strong> | Load signature blobs |</p>\n<p>| <strong>access_to_mariadb_parser.py</strong> | Parse Access to MariaDB |</p>\n<p>| <strong>import_access_v2.py</strong> | Import Access v2 |</p>\n<p>| <strong>import_csv_v2.py</strong> | Import CSV v2 |</p>\n<h3>SQL Migrations (migrations/)</h3>\n<p>| File | Purpose |</p>\n<p>|------|---------|</p>\n<p>| <strong>20260407_add_conversion_job.sql</strong> | Add conversion job table |</p>\n<p>| <strong>20260411_order_items_item_type_name_no_fk.sql</strong> | Order items no FK |</p>\n<p>| <strong>20260416_blog_prompt_templates.sql</strong> | Blog prompt templates |</p>\n<p>---</p>\n<h2>File Statistics</h2>\n<ul>\n<li><strong>Total PHP files:</strong> 200+</li>\n<li><strong>Total SQL files:</strong> 100+</li>\n<li><strong>Total HTML pages:</strong> 20+</li>\n<li><strong>Database tables:</strong> 30+</li>\n</ul>\n<p>---</p>\n<p><em>End of Documentation</em></p>","file_name":"COMPREHENSIVE_DOCUMENTATION.md","stored_name":"20260417-160828-6006d4f1.md","mime_type":"application/octet-stream","file_size_bytes":"22313","storage_path":"/mnt/drive1/customerdb/backend/documents_storage/20260417-160828-6006d4f1.md","is_deleted":"0","created_at":"2026-04-17 12:08:29","updated_at":"2026-04-17 12:08:52","editor_content":"# Ella's Alterations - Comprehensive System Documentation\r\n\r\n**Generated:** April 17, 2026\r\n**Location:** C:\\code\\customerdb\r\n\r\n---\r\n\r\n## Table of Contents\r\n\r\n1. [System Overview](#1-system-overview)\r\n2. [Directory Structure](#2-directory-structure)\r\n3. [Database Schema](#3-database-schema)\r\n4. [API Endpoints](#4-api-endpoints)\r\n5. [External Integrations](#5-external-integrations)\r\n6. [Scheduled Jobs / Cron](#6-scheduled-jobs--cron)\r\n7. [Web Applications](#7-web-applications)\r\n8. [Settings & Configuration](#8-settings--configuration)\r\n9. [Migration Notes](#9-migration-notes)\r\n10. [Scripts & Tools](#10-scripts--tools)\r\n\r\n---\r\n\r\n## 1. System Overview\r\n\r\n### Purpose\r\nElla's Alterations is a comprehensive customer relationship management (CRM) andAlteration tracking system for a tailor shop. It manages customers, visits/alteration orders, appointments, payments, and provides integration with external services.\r\n\r\n### Server Information\r\n- **Primary Server:** kefa@192.168.7.202\r\n- **Mirror Drive:** /mnt/drive2 (mirrors /mnt/drive1)\r\n- **Database:** MariaDB - database `ellas_alterations`, user `kefa_admin`\r\n- **Web Server:** Apache 2.4 with mod-php\r\n- **PHP Version:** 8.3\r\n\r\n### Three Web Applications\r\n\r\n| App | Local URL | Public URL | Purpose |\r\n|-----|-----------|------------|---------|\r\n| Front Desk | http://192.168.7.202:8895 | https://ella.floridaalterations.com | Customer-facing operations |\r\n| Management | http://192.168.7.202:8894 | (LAN only) | Reports, admin, settings |\r\n| Scheduler | http://192.168.7.202:8897 | https://schedule.floridaalterations.com | Easy!Appointments booking |\r\n\r\n---\r\n\r\n## 2. Directory Structure\r\n\r\n```\r\ncustomerdb/\r\n├── backend/                    # Main PHP backend API and services\r\n│   ├── api/                    # REST API endpoints (~57 files)\r\n│   ├── bin/                    # Binary/executable scripts\r\n│   ├── backup/                # Backup versions of services\r\n│   └── jobs/                  # Background job scripts\r\n├── frontend/                   # Front Desk app (port 8895)\r\n│   ├── *.html                 # HTML pages\r\n│   ├── api/                   # PHP API endpoints\r\n│   └── reports/               # PDF reports (MMDDYYYY/filename.pdf)\r\n├── webui/                      # Management app (port 8894)\r\n│   ├── *.html                 # HTML pages\r\n│   ├── api/                  # PHP API endpoints\r\n│   ├── backend/               # Backend API copy\r\n│   └── email/                # Email templates\r\n├── schedule/                   # Easy!Appointments installation\r\n├── schema/                    # Database schema files\r\n├── migrations/               # SQL migrations\r\n├── scripts/                   # PowerShell/Python import scripts\r\n├── docs/                     # Documentation\r\n├── blog/                     # Blog system and reengineering\r\n├── csv/                      # CSV data files\r\n├── backups/                  # Backup archives\r\n├── Topaz/                    # Topaz signature pad configs\r\n├── webui/                    # Second web interface\r\n│   ├── api/\r\n│   ├── backend/\r\n│   └── frontend/\r\n├── notused/                  # Deprecated/unused files\r\n└── wordpress-plugin/          # WordPress integration\r\n```\r\n\r\n---\r\n\r\n## 3. Database Schema\r\n\r\n### Core Tables (from mariadb_core_schema.sql)\r\n\r\n#### customers\r\nMain customer registry.\r\n\r\n| Column | Type | Notes |\r\n|--------|------|-------|\r\n| customer_id | INT UNSIGNED PK | Auto-increment |\r\n| legacy_customer_id | INT NULL | Original Access DB ID |\r\n| created_at | DATETIME | Record creation time |\r\n| full_name | VARCHAR(200) | Customer full name |\r\n| phone | VARCHAR(30) | Formatted (XXX) XXX-XXXX |\r\n| email | VARCHAR(255) | Email address |\r\n| pickup_due_at | DATETIME | Next pickup date (synced from EA) |\r\n| description | TEXT | Description |\r\n| notes | TEXT | Internal notes |\r\n| is_new_customer | TINYINT(1) | 1 if flagged as new |\r\n\r\n#### visits\r\nOne row per alteration job/order.\r\n\r\n| Column | Type | Notes |\r\n|--------|------|-------|\r\n| visit_id | INT UNSIGNED PK | |\r\n| legacy_visit_id | INT NULL | Original Access DB ID |\r\n| customer_id | INT UNSIGNED FK | → customers |\r\n| visit_date | DATETIME | Drop-off date |\r\n| pickup_date | DATETIME | Expected pickup |\r\n| notes | TEXT | General visit notes |\r\n| customer_name_snapshot | VARCHAR(200) | |\r\n| phone_snapshot | VARCHAR(30) | |\r\n| email_snapshot | VARCHAR(255) | |\r\n| color | VARCHAR(100) | Garment color |\r\n| alterations_needed | TEXT | |\r\n| alterations_notes | TEXT | Detailed alteration instructions |\r\n| alterations_price | DECIMAL(10,2) | Manual price field |\r\n| total_alteration_price | DECIMAL(10,2) | Calculated from items |\r\n| expedited_fee | DECIMAL(10,2) | |\r\n| paid_date | DATETIME | When paid |\r\n| signature_text | TEXT | Text signature (legacy) |\r\n| signature_date | DATETIME | |\r\n| paid_flag | TINYINT(1) | 1 = paid |\r\n| source_key_value | VARCHAR(100) | |\r\n\r\n#### visit_signatures\r\nFull resolution signature images per visit.\r\n\r\n| Column | Type | Notes |\r\n|--------|------|-------|\r\n| signature_id | BIGINT UNSIGNED PK | |\r\n| visit_id | INT UNIQUE | One signature per visit |\r\n| signature_date | DATETIME | |\r\n| image_format | VARCHAR(50) | Default 'image/png' |\r\n| original_filename | VARCHAR(255) | |\r\n| original_extension | VARCHAR(20) | |\r\n| file_size_bytes | BIGINT | |\r\n| sha256_hash | CHAR(64) | Hash for verification |\r\n| signature_image | LONGBLOB | Raw PNG binary |\r\n| created_at | DATETIME | |\r\n\r\n#### item_types\r\nMaster list of alteration types (e.g., Hem, Zipper, Taper).\r\n\r\n| Column | Type | Notes |\r\n|--------|------|-------|\r\n| item_type_id | INT UNSIGNED PK | |\r\n| type_name | VARCHAR(100) UNIQUE | Display name |\r\n\r\n#### orders\r\nOrders per visit.\r\n\r\n| Column | Type | Notes |\r\n|--------|------|-------|\r\n| order_id | BIGINT UNSIGNED PK | |\r\n| visit_id | INT UNSIGNED FK | → visits |\r\n| customer_id | INT UNSIGNED FK | → customers |\r\n| created_at | DATETIME | |\r\n| no_tax | TINYINT(1) | Tax exempt |\r\n| picked_up | TINYINT(1) | |\r\n| source_table | VARCHAR(50) | |\r\n\r\n#### order_items\r\nLine items for each alteration within a visit.\r\n\r\n| Column | Type | Notes |\r\n|--------|------|-------|\r\n| order_item_id | BIGINT UNSIGNED PK | |\r\n| order_id | BIGINT UNSIGNED FK | → orders |\r\n| legacy_alteration_id | INT NULL | |\r\n| item_type_id | INT FK | → item_types |\r\n| item_type_name | VARCHAR(100) | |\r\n| description | TEXT | |\r\n| quantity | INT | Default 1 |\r\n| unit_price | DECIMAL(10,2) | |\r\n| total_price | DECIMAL(10,2) | |\r\n| notes | TEXT | Per-item notes |\r\n| color | VARCHAR(100) | Garment color |\r\n| no_tax | TINYINT(1) | Tax exempt |\r\n| is_range_price | TINYINT(1) | |\r\n| range_price_label | VARCHAR(100) | |\r\n| paid_flag | TINYINT(1) | |\r\n| paid_type | VARCHAR(100) | |\r\n| picked_up | TINYINT(1) | |\r\n| created_at | DATETIME | |\r\n\r\n#### order_item_type_links\r\nMany-to-many links between order items and item types.\r\n\r\n| Column | Type | Notes |\r\n|--------|------|-------|\r\n| order_item_type_link_id | BIGINT UNSIGNED PK | |\r\n| order_item_id | BIGINT UNSIGNED FK | → order_items |\r\n| item_type_id | INT UNSIGNED FK | → item_types |\r\n| slot_number | TINYINT UNSIGNED | |\r\n\r\n#### payments\r\nPayment records per order.\r\n\r\n| Column | Type | Notes |\r\n|--------|------|-------|\r\n| payment_id | BIGINT UNSIGNED PK | |\r\n| order_id | BIGINT UNSIGNED FK | → orders |\r\n| payment_date | DATETIME | |\r\n| payment_type | VARCHAR(100) | |\r\n| payment_method | VARCHAR(100) | |\r\n| amount | DECIMAL(10,2) | |\r\n| notes | TEXT | |\r\n\r\n#### tax_payments\r\nTax payment records.\r\n\r\n| Column | Type | Notes |\r\n|--------|------|-------|\r\n| tax_payment_id | INT UNSIGNED PK | |\r\n| legacy_tax_payment_id | INT NULL | |\r\n| payment_date | DATETIME | |\r\n| payment_type | VARCHAR(100) | |\r\n| payment_method | VARCHAR(100) | |\r\n| amount | DECIMAL(10,2) | |\r\n| notes | TEXT | |\r\n| receipt_blob | LONGBLOB | |\r\n\r\n#### change_log\r\nAudit log for changes.\r\n\r\n| Column | Type | Notes |\r\n|--------|------|-------|\r\n| log_id | BIGINT UNSIGNED PK | |\r\n| legacy_log_id | INT NULL | |\r\n| table_name | VARCHAR(100) | |\r\n| record_id | BIGINT | |\r\n| visit_id | INT | |\r\n| field_name | VARCHAR(100) | |\r\n| old_value | TEXT | |\r\n| new_value | TEXT | |\r\n| changed_at | DATETIME | |\r\n| changed_by | VARCHAR(100) | |\r\n\r\n#### ads\r\nAdvertising/articles.\r\n\r\n| Column | Type | Notes |\r\n|--------|------|-------|\r\n| ad_id | INT UNSIGNED PK | |\r\n| legacy_ad_id | INT NULL | |\r\n| article_text | TEXT | |\r\n| article_picture | LONGBLOB | |\r\n| site_submitted | VARCHAR(255) | |\r\n| views | INT | Default 0 |\r\n| date_posted | DATETIME | |\r\n\r\n#### staging_* tables\r\nStaging tables for data migration.\r\n\r\n| Table Name | Purpose |\r\n|------------|---------|\r\n| staging_customer_table_raw | Staging for legacy customer data |\r\n| staging_customer_visits_raw | Staging for legacy visits |\r\n| staging_alteration_items_raw | Staging for items |\r\n\r\n### Additional Backend Tables\r\n\r\n| Table Name | Purpose |\r\n|------------|---------|\r\n| setmore_appointments | Synced from Setmore |\r\n| backend_conversion_job | Document conversion jobs |\r\n| backend_job_runs | Background job execution log |\r\n| customer_totals | Daily customer totals |\r\n| daily_customer_totals | Daily summary totals |\r\n| customer_payment_transactions | Payment ledger |\r\n| legacy_customer_totals_monthly | Monthly totals (legacy) |\r\n| legacy_customer_totals_irs_monthly | IRS monthly reports |\r\n| backend_appointment_workflow | Appointment state machine |\r\n| backend_no_show_log | No-show tracking |\r\n| backend_error_log | Error logging |\r\n| backend_change_log | Change audit log |\r\n| backend_document | Document storage |\r\n| backend_document_version | Document version history |\r\n| backend_speed_dial | Quick links |\r\n| backend_square_terminal_code | Square terminal pairing codes |\r\n| backend_square_terminal_device | Square device registry |\r\n| cron_job | Scheduled job definitions |\r\n| cron_job_run | Cron execution history |\r\n| app_settings | Global configuration |\r\n| app_users | Login accounts |\r\n| remember_tokens | \"Remember Me\" tokens |\r\n| customer_reports | PDF report index |\r\n\r\n---\r\n\r\n## 4. API Endpoints\r\n\r\n### 4.1 Frontend API (port 8895 /api/)\r\n\r\n| Endpoint File | Purpose |\r\n|---------------|---------|\r\n| **customer_get.php** | Get customer by ID |\r\n| **customer_save.php** | Create or update customer |\r\n| **customer_detail.php** | Customer + visits summary |\r\n| **customer_delete.php** | Delete customer |\r\n| **customer_list_hide.php** | Hide customer from list |\r\n| **search_customers.php** | Search by name/phone |\r\n| **visit_get.php** | Get visit + items |\r\n| **visit_save.php** | Create/update visit + items |\r\n| **visit_delete.php** | Delete visit |\r\n| **visit_report_generate.php** | Generate visit report |\r\n| **item_types.php** | List all alteration types |\r\n| **item_type_add.php** | Add new item type |\r\n| **item_type_update.php** | Update item type |\r\n| **item_type_delete.php** | Delete item type |\r\n| **pickups_today.php** | Orders due today |\r\n| **ready.php** | Orders ready for pickup |\r\n| **overdue.php** | Overdue orders |\r\n| **upcoming.php** | Orders due in next N days |\r\n| **workload_7days.php** | 7-day workload |\r\n| **save_signature.php** | Save canvas signature |\r\n| **reports_list.php** | Reports for customer |\r\n| **attach_reports.php** | Index all PDFs to DB |\r\n| **save_signature.php** | Save signature image |\r\n| **today_appointments_list.php** | Today's appointments |\r\n| **settings_get.php** | Get app settings |\r\n| **settings_save.php** | Save app settings |\r\n| **settings_css.php** | Live theme CSS |\r\n| **send_email.php** | Send email via SMTP |\r\n| **send_sms.php** | Send SMS via Twilio |\r\n| **send_reminders.php** | Send appointment reminders |\r\n| **ea_appointments.php** | EasyAppointments REST API |\r\n| **ea_webhook.php** | Receives EA webhook events |\r\n| **setmore.php** | Setmore API proxy |\r\n| **setmore_to_ea_import.php** | Import customers to EA |\r\n| **square_config.php** | Square public config |\r\n| **square_process.php** | Process Square payment |\r\n| **square_customer_log.php** | Customer Square log |\r\n| **square_terminal.php** | Square terminal |\r\n| **login.php** | Authenticate |\r\n| **logout.php** | Clear session |\r\n| **session_check.php** | Check if logged in |\r\n| **auth.php** | Session authentication |\r\n| **config.php** | App config constants |\r\n| **db.php** | Database connection |\r\n| **log_error.php** | Log client-side error |\r\n| **todo_list.php** | Todo list management |\r\n| **send_telegram.php** | Send Telegram messages |\r\n\r\n### 4.2 Management API (port 8894 /api/)\r\n\r\n| Endpoint File | Purpose |\r\n|---------------|---------|\r\n| **login.php** | Authenticate |\r\n| **logout.php** | Clear session |\r\n| **session_check.php** | Check if logged in |\r\n| **customer_detail.php** | Customer + visits |\r\n| **search_customers.php** | Search customers |\r\n| **update_customer.php** | Update customer |\r\n| **users_list.php** | List all users |\r\n| **user_save.php** | Create/update user |\r\n| **list_report_dirs.php** | Date folders |\r\n| **list_report_files.php** | PDFs in folder |\r\n| **report_file.php** | Access report file |\r\n| **pickups_today.php** | Today's pickups |\r\n| **ready.php** | Ready for pickup |\r\n| **overdue.php** | Overdue |\r\n| **settings_get.php** | Get settings |\r\n| **settings_save.php** | Save settings |\r\n| **settings_css.php** | Live CSS theme |\r\n| **imap_list.php** | List IMAP folders |\r\n| **imap_fetch.php** | Fetch emails |\r\n| **imap_send.php** | Send email via IMAP |\r\n| **imap_action.php** | IMAP actions |\r\n| **sms_send_helper.php** | SMS sending helper |\r\n| **sms_webhook_receive.php** | Receive SMS webhooks |\r\n| **sms_inbox_api.php** | SMS inbox API |\r\n| **slideshow_list.php** | Slideshow images |\r\n| **slideshow_upload.php** | Upload slideshow |\r\n| **slideshow_delete.php** | Delete slideshow |\r\n| **users_list.php** | User management |\r\n| **report_list.php** | Report list |\r\n| **debug_filters.php** | Debug filters |\r\n| **sysadmin.php** | System admin |\r\n| **test.php** | Testing endpoint |\r\n\r\n### 4.3 Backend API (C:\\code\\customerdb\\backend\\api\\)\r\n\r\n| Endpoint File | Purpose |\r\n|---------------|---------|\r\n| **customer.php** | Get customer details |\r\n| **customers.php** | List/search customers |\r\n| **customer_save.php** | Save/update customer |\r\n| **visit.php** | Get visit details |\r\n| **visit_delete.php** | Delete visit |\r\n| **appointments.php** | Unified appointments |\r\n| **appointments_summary.php** | Appointment statistics |\r\n| **setmore_appointments.php** | Setmore appointments |\r\n| **setmore_import.php** | Import from Setmore |\r\n| **module_*.php** | Module loaders |\r\n| **alteration_items.php** | Alteration management |\r\n| **alteration_items_summary.php** | Alteration statistics |\r\n| **gold_silver_*.php** | Gold/silver prices |\r\n| **bank_*.php** | Bank transactions |\r\n| **stocks_summary.php** | Stock data |\r\n| **medication_*.php** | Medication tracking |\r\n| **payroll_import.php** | Payroll import |\r\n| **car_maintenance_*.php** | Vehicle maintenance |\r\n| **duke_*.php** | Duke integration |\r\n| **reports_*.php** | Report generation |\r\n| **totals_import.php** | Customer totals import |\r\n| **documents.php** | Document management |\r\n| **document_upload.php** | File uploads |\r\n| **cust_email_*.php** | Email data |\r\n| **mail_*.php** | Email sending |\r\n| **reminders_create.php** | Create reminders |\r\n| **nightly_reports.php** | Nightly reports |\r\n| **morning_jobs.php** | Morning jobs |\r\n| **appointment_workflow.php** | Workflow management |\r\n| **sysadmin.php** | System admin |\r\n| **reporting_module.php** | Reporting |\r\n| **job_runs.php** | Job tracking |\r\n| **health.php** | Health check |\r\n| **overview.php** | Dashboard data |\r\n\r\n---\r\n\r\n## 5. External Integrations\r\n\r\n### 5.1 Square (Payment Processing)\r\n- **Purpose:** Point-of-sale payments, receipts, terminal management\r\n- **Features:**\r\n  - Square Terminal device pairing/management\r\n  - Payment processing with tips\r\n  - Customer payment logging\r\n  - Sandbox and live environments\r\n- **Tables:** `backend_square_terminal_code`, `backend_square_terminal_device`, `square_customer_log`\r\n\r\n### 5.2 Twilio (SMS)\r\n- **Purpose:** SMS notifications and reminders\r\n- **Features:**\r\n  - Send SMS to customers\r\n  - Appointment reminders\r\n  - SMS consent tracking\r\n- **Settings:** `twilio_sid`, `twilio_token`, `twilio_from`\r\n\r\n### 5.3 Setmore (Appointment Booking)\r\n- **Purpose:** Appointment synchronization\r\n- **Features:**\r\n  - Pull appointments from Setmore API\r\n  - Link to customers/visits\r\n- **Table:** `setmore_appointments`\r\n- **Settings:** `setmore_refresh_token`, `setmore_staff_key`\r\n\r\n### 5.4 EasyAppointments (Alternative Booking)\r\n- **Purpose:** Full appointment booking platform\r\n- **Location:** C:\\code\\customerdb\\schedule\\\r\n- **Features:**\r\n  - Customer/provider management\r\n  - Web-based booking widget\r\n  - REST API\r\n\r\n### 5.5 Telegram (Notifications)\r\n- **Purpose:** Bot-based notifications\r\n- **Features:**\r\n  - Send notifications to channels\r\n  - Visit alerts\r\n  - Cron job status\r\n- **Settings:** `telegram_bot_token`, `telegram_chat_id`\r\n\r\n### 5.6 Ollama (AI - Optional)\r\n- **Purpose:** Local AI for email generation\r\n- **Settings:** `ollama_url`, `ollama_default_model`\r\n\r\n---\r\n\r\n## 6. Scheduled Jobs / Cron\r\n\r\n### Configured Cron Jobs\r\n\r\n| Job Label | Schedule | Purpose |\r\n|----------|----------|---------|\r\n| **Next-Day Customer Emails** | `0 20 * * *` (8 PM) | Pickup reminder emails |\r\n| **Morning Import** | `0 6 * * *` (6 AM) | Morning data import |\r\n| **Morning Jobs** | `0 9 * * *` (9 AM) | Appointment sync, workflow |\r\n| **Nightly Reports** | `0 20 * * *` (8 PM) | Generate nightly summaries |\r\n| **Database Backup** | `0 2 * * *` (2 AM) | Full MariaDB backup |\r\n| **Daily Cleanup** | `0 4 * * *` (4 AM) | Temp files, old logs |\r\n| **Auto Delete** | `15 4 * * *` (4:15 AM) | Clean placeholder records |\r\n\r\n### Background Job Scripts (backend/jobs/)\r\n\r\n| Script | Purpose |\r\n|--------|---------|\r\n| **run_morning_jobs.php** | Main morning job runner |\r\n| **smoke_morning_jobs.php** | Smoke test |\r\n| **send_nightly_reports.php** | Nightly report emailer |\r\n| **send_nextday_customer_emails.php** | Next-day reminders |\r\n| **delete_add_name_records.php** | Cleanup job |\r\n| **rebuild_customer_totals.php** | Rebuild totals |\r\n| **rebuild_daily_customer_totals.php** | Rebuild daily totals |\r\n| **rebuild_payment_ledger.php** | Rebuild payment ledger |\r\n| **import_customer_totals_csv.php** | CSV import |\r\n| **backfill_square_customer_log.php** | Square log backfill |\r\n| **run_cron_job.php** | Generic cron runner |\r\n\r\n---\r\n\r\n## 7. Web Applications\r\n\r\n### 7.1 Front Desk App (port 8895)\r\n\r\n| Page | Purpose |\r\n|------|---------|\r\n| **index.html** | Main dashboard, search, stats |\r\n| **customer.html** | Customer detail + visit history |\r\n| **visit.html** | Create/edit alteration order |\r\n| **customer_display.html** | Second monitor display |\r\n| **receipt.html** | Printable receipt |\r\n| **reports.html** | Order list by status |\r\n| **upcoming.html** | Next 7 days pickups |\r\n| **schedule.html** | Appointments calendar |\r\n| **login.html** | Login page |\r\n| **item_types.html** | Item type management |\r\n\r\n### 7.2 Management App (port 8894)\r\n\r\n| Page | Purpose |\r\n|------|---------|\r\n| **index.html** | Login page |\r\n| **webui.html** | Dashboard |\r\n| **customer.html** | Customer detail view |\r\n| **admin.html** | Reports browser |\r\n| **settings.html** | App settings editor |\r\n| **users.html** | User management |\r\n| **reports.html** | Order reports |\r\n\r\n---\r\n\r\n## 8. Settings & Configuration\r\n\r\n### app_settings Keys\r\n\r\n| Key | Purpose |\r\n|-----|---------|\r\n| theme_bg | Page background color |\r\n| theme_panel | Card/panel color |\r\n| theme_text | Text color |\r\n| theme_accent | Accent/button color |\r\n| theme_accent_deep | Darker accent |\r\n| theme_teal | Teal color |\r\n| theme_font | Font family |\r\n| smtp_host | Email server hostname |\r\n| smtp_port | Email server port |\r\n| smtp_secure | tls or ssl |\r\n| smtp_user | Email login |\r\n| smtp_pass | Email password |\r\n| smtp_from_email | From address |\r\n| smtp_from_name | From display name |\r\n| twilio_sid | Twilio Account SID |\r\n| twilio_token | Twilio Auth Token |\r\n| twilio_from | Twilio phone number |\r\n| imap_host | Incoming email server |\r\n| imap_port | IMAP port |\r\n| imap_ssl | SSL enable |\r\n| imap_user | IMAP login |\r\n| imap_pass | IMAP password |\r\n| square_token | Square API token |\r\n| square_location | Square location ID |\r\n| setmore_staff_key | Setmore API key |\r\n| setmore_refresh | Setmore refresh token |\r\n| require_report | PDF required |\r\n| require_signature | Signature required |\r\n| reports_base_path | Reports disk path |\r\n| reports_base_url | Reports URL |\r\n| ollama_url | Ollama AI URL |\r\n| ollama_default_model | Ollama model |\r\n| telegram_bot_token | Telegram bot token |\r\n| telegram_chat_id | Telegram chat ID |\r\n\r\n---\r\n\r\n## 9. Migration Notes\r\n\r\n### Access to MariaDB Workflow\r\n\r\n1. **Export source data from Access**\r\n   - Export ordinary tables to CSV\r\n   - Export attachment fields with VBA or DAO Recordset2 logic\r\n   - Keep original IDs during migration\r\n\r\n2. **Load into MariaDB staging**\r\n   - Use `LOAD DATA LOCAL INFILE` for CSV files\r\n   - Load signatures separately into `visit_signatures`\r\n\r\n3. **Normalize**\r\n   - `CustomerTable` → `customers`\r\n   - `CustomerVisits` → `visits`\r\n   - `AlterationItems` → `orders`, `order_items`, `order_item_type_links`\r\n   - `2024TaxPayments` → `tax_payments`\r\n   - `AlterationItemsChangeLog` → `change_log`\r\n\r\n4. **Signature BLOB path**\r\n   - Export Access attachment to temp file\r\n   - Convert BMP to PNG\r\n   - Insert PNG bytes into `visit_signatures.signature_image`\r\n\r\n5. **Validation**\r\n   - Compare source row counts vs target\r\n   - Compare distinct legacy IDs\r\n   - Compare sample signatures by SHA256\r\n\r\n---\r\n\r\n## 10. Scripts & Tools\r\n\r\n### PowerShell Scripts (scripts/)\r\n\r\n| Script | Purpose |\r\n|--------|---------|\r\n| **import_legacy_totals_from_excel.ps1** | Import totals from Excel |\r\n| **sync_backend_mirror.ps1** | Sync backend mirror |\r\n| **check_backend_mirror.ps1** | Check mirror status |\r\n\r\n### Python Scripts (scripts/)\r\n\r\n| Script | Purpose |\r\n|--------|---------|\r\n| **signature_blob_loader.py** | Load signature blobs |\r\n| **access_to_mariadb_parser.py** | Parse Access to MariaDB |\r\n| **import_access_v2.py** | Import Access v2 |\r\n| **import_csv_v2.py** | Import CSV v2 |\r\n\r\n### SQL Migrations (migrations/)\r\n\r\n| File | Purpose |\r\n|------|---------|\r\n| **20260407_add_conversion_job.sql** | Add conversion job table |\r\n| **20260411_order_items_item_type_name_no_fk.sql** | Order items no FK |\r\n| **20260416_blog_prompt_templates.sql** | Blog prompt templates |\r\n\r\n---\r\n\r\n## File Statistics\r\n\r\n- **Total PHP files:** 200+\r\n- **Total SQL files:** 100+\r\n- **Total HTML pages:** 20+\r\n- **Database tables:** 30+\r\n\r\n---\r\n\r\n*End of Documentation*","is_text_editable":1,"can_edit_inline":1}
Changed Data
{"backend_document_id":"20","document_type":"upload","title":"Speed Dial Contents","slug":"speed-dial-contents","summary_text":"Speed Dial Contents","content_markdown":"Here are the names and URLs extracted from the provided bookmarks list:\r\n\r\nGTE Mobile Banking: https://m.gtefcu.org/mobile/Default.aspx?ReturnUrl=%2fmobile%2fMember%2fAccounts%2fTransactionHistory.aspx%3fR6ldQ2Rt%252bjUGc0%252f3%252fhP9UxU2hEVocAsOAVJ4EPdcd9Hh0BsxuR0ilPHrPQzwSXJWzbVCFr3txWVrhtMn9YIzTE6DpzA4jgy3BwTNCXbCmuc%253d-YuyNrzQIfzg%253d&R6ldQ2Rt%2bjUGc0%2f3%2fhP9UxU2hEVocAsOAVJ4EPdcd9Hh0BsxuR0ilPHrPQzwSXJWzbVCFr3txWVrhtMn9YIzTE6DpzA4jgy3BwTNCXbCmuc%3d-YuyNrzQIfzg%3d\r\n\r\nView All Photos | 100 Easy Chicken Recipes | Cooking Light: http://www.cookinglight.com/food/quick-healthy/easy-chicken-recipes/view-all\r\n\r\nYahoo! Mail: https://m.mg.mail.yahoo.com/hg/?.intl=us\r\n\r\nWeather Station History | Weather Underground: http://www.wunderground.com/weatherstation/WXDailyHistory.asp?ID=ITARLACC2\r\n\r\nAbout Shalom Sesame – Shalom Sesame: http://www.shalomsesame.org/about2.html\r\n\r\nAMAZING FACTS: http://www.amazingfacts.org/store/entity/tabid/267/entityname/category/categoryid/126/sename/character-studies/default.aspx\r\n\r\nAncient Hebrew Research Center - Home Page: http://www.ancient-hebrew.org/\r\n\r\nAnthem BlueCross BlueShield - Verizon Home: http://www.anthem.com/verizon/\r\n\r\nAtheist Central -- Ray Comfort's Blog: http://raycomfortfood.blogspot.com/\r\n\r\nAudio Lessons « Think Hebrew: http://thinkhebrew.wordpress.com/audio-lessons/\r\n\r\nBarnes & Noble.com - eBooks Search Orthodox Jewish bible: http://productsearch.barnesandnoble.com/search/results.aspx?store=EBOOK&WRD=Orthodox+Jewish+bible\r\n\r\nBeginning Hebrew Class Tim Hegg: http://www.torahresource.com/Hebrew.html\r\n\r\nBehind The Scenes- 5-9-11: http://www.livingwaters.com/index.php?option=com_k2&view=item&id=2753&Itemid=314&lang=en\r\n\r\nBeit Tehila Congregation - Shalom: http://www.topraise.net/pages/about-us/history.htm\r\n\r\nBeth Messiah Messianic Synagogue Sarasota, Florida USA Rabbi Judah Hungerman: http://www.bethmessiahfla.com/\r\n\r\nBible and Mishneh Torah for All - Jews and Gentiles - Mechon Mamre: http://www.mechon-mamre.org/\r\n\r\nbible passages: http://www.openbible.info/topics/eating_fish\r\n\r\nBible University: http://www.bibleuniversity.com/University/Welcome.asp\r\n\r\nBiblical Hebrew Blog - By eTeacherBiblical.com Learn Biblical Hebrew online: http://blog.eteacherbiblical.com/\r\n\r\nBiblical Hermeneutics BiblicalTraining.org: http://www.biblicaltraining.org/biblical-hermeneutics/robert-stein\r\n\r\nBiblicalDiscipleship.org: http://biblicaldiscipleship.org/\r\n\r\nBirth Issues Yeshua in Context: http://yeshuaincontext.com/2011/03/birth-issues/\r\n\r\nBlogEngine.NET: http://blogengine.codeplex.com/discussions?prog_id=register_cheap_domain_names_cheap_web_hosting&ProjectName=blogengine\r\n\r\nBukharin Yarmulke Pattern k2p2.net Blog: http://k2p2.net/blog2/2006/08/31/bukharin-yarmulke-pattern/\r\n\r\nBuy Jewish Gifts Online - Jewelry - Kippah - Mezuzah - Star of David - Kabbalah Red String Bracelets - Evil Eye Charm: http://www.yourholylandstore.com/\r\n\r\nChabad Jewish Holidays: http://www.chabad.org/library/article_cdo/aid/102698/jewish/Tevet-10.htm\r\n\r\nCHANUKAH ...History & Prophetic End Time Implications: http://www.graftedforlife.org/blogs/index.php/2010/12/03/chanukah-history-aamp-prophetic-end-time-implications?blog=9\r\n\r\nChofetz Chaim Laws of Speech Naaleh Torah Video Online: http://www.naaleh.com/search/class/148\r\n\r\nContact Us: http://www.chabadcountyline.com/index.php?option=com_facileforms&act=quickmode&task=edit&formName=ContactUs&Itemid=152\r\n\r\nCount Today's Omer - Sefirat HaOmer: http://www.chabad.org/holidays/sefirah/omer-count.asp?date=4/19/2011\r\n\r\nCredit Bureau Reporting: http://www.thelpa.com/lpa/credit-reporting.html\r\n\r\nDeuteronomy 1622 Bible Lexicon: http://biblelexicon.org/deuteronomy/16-22.htm\r\n\r\nDidache: http://www.earlychristianwritings.com/didache.html\r\n\r\ndirectoryBedini SG - PESWiki Tesla Generator: http://peswiki.com/energy/Directory:Bedini_SG\r\n\r\nDr. Janice Hughes, Clinical Social Work-Therapist, Cape Coral, FL 33914 Psychology Today's Therapy Directory: http://therapists.psychologytoday.com/rms/prof_detail.php?profid=73368&sid=1281461131.0405_1063&city=Fort+Myers&county=Lee&state=Florida&spec=166\r\n\r\nD'var Torah on the Parashah - Torah Portion of the Week: http://www.artscroll.com/parashah/current.html\r\n\r\nEarly Christian Writings New Testament, Apocrypha, Gnostics, Church Fathers: http://www.earlychristianwritings.com/index.html\r\n\r\nEarly Jewish Writings: http://www.earlyjewishwritings.com/\r\n\r\nEasiest Online Backup Service - Backblaze: http://www.backblaze.com/\r\n\r\nebay Seller Tools File Exchange: http://pages.ebay.com/file_exchange/\r\n\r\nEssays and Articles: http://therefinersfire.org/ea.htm\r\n\r\nEssenes, Essene Teachings and Essene Theology: http://www.thenazareneway.com/\r\n\r\nFilipino Audio Lessons: http://mylanguages.org/filipino_audio.php\r\n\r\nFirm Foundation Guitar Tabs, Chords & Lyrics by Jamie Harvill & Nancy Gordon: http://www.worshiparchive.com/song/firm-foundation\r\n\r\nFirst Fruits Core [Beta]: https://ffoz.org/members/member_cp/index.php\r\n\r\nFlorida Lotto: http://www.flalottery.com/inet/lottoMain.do\r\n\r\nFoundationStone - a free and easy way to learn Hebrew: http://foundationstone.com.au/FoundationStone.html?./OnlineHebrewTutorial.html\r\n\r\nFree Lessons Learn Biblical Hebrew with eTeacher: http://eteacherbiblical.com/free-lessons\r\n\r\nFree Online Hebrew Dictionary. Type in Hebrew-English. Translate Hebrew or Phonetic Hebrew.: http://www.doitinhebrew.com/Translate/default.aspx?kb=IL%20Hebrew%20Phonetic\r\n\r\nFront Page www.jewishpresstampa.com Jewish Press of Tampa: http://www.jewishpresstampa.com/\r\n\r\nG-DCAST: http://www.g-dcast.com/\r\n\r\nGoogle Translate: http://translate.google.com/#\r\n\r\nHanukkah - Chanukah 2010 - Menorah, Dreidels, Latkes, Recipes, Games and more: http://www.chabad.org/holidays/chanukah/default_cdo/jewish/Hanukkah.htm\r\n\r\nHebrew Lessons — Ten Commandments: http://www.levitt.com/hebrew/commandments.html\r\n\r\nHome Yarnell: http://www.yarnellschool.com/online/yarnell/index.html\r\n\r\nInformation Technology Students and Faculty: http://msdn01.e-academy.com/elms/Storefront/Home.aspx?campus=sfc_it\r\n\r\nIntroduction to Islam BiblicalTraining.org: http://www.biblicaltraining.org/introduction-islam/timothy-tennent\r\n\r\niTanakh: http://www.itanakh.org/\r\n\r\nJewish Community, Jewish Synagogue, Kosher Food, Makati, Philippines: http://jewishphilippines.net/newsletter.php#\r\n\r\nJewish Genealogy By Genetics - JewishGen: http://www.jewishgen.org/dna/genbygen.html\r\n\r\nJewish Roots Learning Center Haydid: http://www.haydid.org/\r\n\r\nJewish Studies Org: http://www.jewishstudies.org/\r\n\r\nJourney To Jerusalem Home Page: http://www.journeytojerusalem.com/\r\n\r\nJudaism and Jewish Resources - Andrew Tannenbaum: http://shamash.org/trb/judaism.html#learning\r\n\r\nJVIMS Courses: http://www.jvims.com/index.php?page=shop.browse&category_id=6&option=com_virtuemart&Itemid=64&vmcchk=1&Itemid=64\r\n\r\nJVIMS Rabbi Courses: http://jvims.com/index.php?page=shop.browse&category_id=6&option=com_virtuemart&Itemid=64\r\n\r\nKidsAstronomy.com Online Astronomy Academy: http://www.kidsastronomy.com/academy/index.htm\r\n\r\nLearn Hebrew and Jewish prayer with our user friendly Software, Book and Audio tutorials and products: http://www.hebrewworld.com/specialOffer.html\r\n\r\nLighting Up Chanukah: http://www.betemunah.org/chanukah.html\r\n\r\nListen to Prayers Bet Am Shalom - A Reconstructionist Synagogue, White Plains, NY: http://betamshalom.org/prayers\r\n\r\nLiturgy: http://www.cyber-synagogue.com/Liturgy.htm\r\n\r\nMahal - Volunteer for the IDF - Join the Israeli Army: http://www.mahal-idf-volunteers.org/support/linkus.htm\r\n\r\nMessianic Jewish Rabbinical Council: http://ourrabbis.org/main/\r\n\r\nMessianic Jewish Radio - San Francisco, CA - Listen Online: http://radiotime.com/station/s_111593/Messianic_Jewish_Radio.aspx\r\n\r\nMessianic Symbol Hebraic Roots Banner-Red: https://www.storesonline.com/site/742858/product/SFA-32133\r\n\r\nMoney Transfer - Send Money Online: https://www.xoom.com/sendmoneynow/home2/security\r\n\r\nMount Olive Press: http://mountolivepress.com/Mount_Olive_Press/Home.html\r\n\r\nMovie Showtimes and Tickets for 33982 - Yahoo! Movies: http://movies.yahoo.com/showtimes-tickets/?location=33982&r=sim\r\n\r\nMy Account Login: https://idp.securepaynet.net/login.aspx?isc=wwbb53&prog%5Fid=register%5Fcheap%5Fdomain%5Fnames%5Fcheap%5Fweb%5Fhosting&spkey=SPSWB166&login=9492585&target=myportal%2Fdomainren%2Easp\r\n\r\nMy order history BiblicalTraining.org: http://www.biblicaltraining.org/user/39652/orders\r\n\r\nMy Wish List Decorative Painting Bookstore: http://www.decorativepaintingbookstore.com/mm5/merchant.mvc?\r\n\r\nNazarene Media - Home: http://www.nazarenemedia.net/\r\n\r\nNazerine books and school: http://stores.lulu.com/nazarene\r\n\r\nNot Subject to the Law of God: http://www.yashanet.com/library/underlaw.htm\r\n\r\nOf His Kingdom There Shall Be No End Mashiyach Mashiyach Mashiyach: http://www.mashiyach.com/index.htm\r\n\r\nohr chadash: http://www.ohrchadash.org/contact.htm\r\n\r\nOld Testament Studies: http://www.torahclass.com/old-testament-studies\r\n\r\nOperation Wake Up Call - Nazarene Space: http://nazarenespace.com/group/operationwakeupcall\r\n\r\norderConfirmation: https://www.rewardsuite.com/rewardsuite/Catalog/View/orderConfirmation.aspx?i=dzOj5blTL2o%3d\r\n\r\npage 3: http://www.globalprebuilder.com/page3-v2.php\r\n\r\nPasco County Library System Program Home Page: http://evanced.info/pasco/sr/homepage.asp?ProgramID=27\r\n\r\nPeshitta.org • View forum - Nazarene-Messianic Judaism Forum: http://www.peshitta.org/forum/viewforum.php?f=6\r\n\r\nPrinciples of Christian Dream Interpretation: http://www.cwgministries.org/Principles-of-Christian-Dream-Interpretation\r\n\r\nprophecyrevealed - I Have A Friend Who's Jewish Book: http://prophecyrevealed.com/\r\n\r\nPsalms 23 - Hebrew - English Bible - Mechon-Mamre: http://www.mechon-mamre.org/p/pt/pt2623.htm\r\n\r\nRabbi Eric Levy and Family: http://www.ericlevy.com/\r\n\r\nRevelation 11-6: http://www.yashanet.com/studies/revstudy/text/r1_1-6.htm\r\n\r\nRevelation Study Text Index: http://www.yashanet.com/studies/revstudy/text/index.htm\r\n\r\nRick Recht Online Store -: http://store.jewishrockrecords.com/store/listings.cfm?cat=12\r\n\r\nSAP Support Portal - Homepage: https://websmp202.sap-ag.de/support\r\n\r\nSchool of Biblical Evangelism: http://www.biblicalevangelism.com/register\r\n\r\nShaarei halachah a summary of laws for Jewish living Online Free Books: http://online-free-books.com/title/Txt4EidAVFEC.html\r\n\r\nShoresh David Messianic Jewish Synagogues (Tampa, Lakeland, & Wesley Chapel, FL): http://www.shoreshdavid.org/\r\n\r\nSilver Jerusalem design Hand Embroidered Hat: http://www.ajudaica.com/item/1494_324/Silver+Jerusalem+design+Hand+Embroidered+Hat\r\n\r\nSmile of a Child TV -- Television Program Schedule: http://www.smileofachildtv.org/watch/schedule_weekview.php\r\n\r\nSounds of Shalom: http://www.soundsofshalom.com/\r\n\r\nSubscription Donations; Messianic Christianity: http://www.messianicchristianity.org/subscription_donations.html\r\n\r\nTable of Contents - Torah 101 - Mechon Mamre: http://www.mechon-mamre.org/jewfaq/index.htm\r\n\r\nTanach Index Hebrew with Vowels: http://www.sacred-texts.com/bib/tan/index.htm\r\n\r\nTemple Aron Hakodesh: http://www.tak.org/services.htm\r\n\r\nTemple Israel NH » Prayer Recordings: http://www.templeisraelnh.org/education/prayer-recordings/\r\n\r\nTES - Largest Distributor of Jewish Software, Hebrew Language and Bible Software (0): http://www.jewishsoftware.com/default.asp?page=category&id=4\r\n\r\nTexts of Judaism: http://www.sacred-texts.com/jud/\r\n\r\nThe Aramaic origin of the Fourth gospel - Google Books: http://books.google.com/ebooks/reader?id=2WhAAAAAIAAJ&printsec=frontcover&output=reader\r\n\r\nThe Book of Zohar Books Michael Laitman Kabbalah Library - Bnei Baruch Kabbalah Education & Research Institute: http://www.kabbalah.info/eng/content/view/frame/2842?/eng/content/view/full_list/2842&main\r\n\r\nThe Evolution of a Creationist Jobe Martin Creation vs. Evolution: http://evolutionofacreationist.com/\r\n\r\nThe Foreign Service of the Philippines - Manila Forwarders: http://www.manilaforwarder.com/immigrantvisa_pg2.html\r\n\r\nThe Lotto Black Book! Secrets Exposed...: http://lottoblackbooks.co.cc/aff.php\r\n\r\nThe Nazarite Site: http://www.nazarite.net/home.html\r\n\r\nThe Poetry of Genesis Chapter One: http://www.ancient-hebrew.org/23_genesis_1.html\r\n\r\nThe Revelation of Y'shua HaMoshiach Thus Say The Prophets!: http://jewtoo.org/prophecy/\r\n\r\nThe Shul of the Web: http://www.heartofisrael.net/\r\n\r\nThe Worldwide Nazarene Assembly of Elohim - Directory of WNAE Assemblies: http://www.wnae.org/assemblies.htm\r\n\r\nTHE WORSHIP OF IMAGES catholism: http://www.justforcatholics.org/images.htm\r\n\r\nTim Hegg Shabbat Shalom Page: http://www.torahresource.com/\r\n\r\nTorah (Teachings) of Yahshua Messiah (Jesus, Yeshua) - rebuking the Trinity and Lawlessness: http://www.torahofmessiah.com/trinity_art.html\r\n\r\nTorah Institute FREE PDF DOWNLOADS: http://www.torahzone.net/FREE-PDF-DOWNLOADS/?page=3\r\n\r\ntorah institute: http://www.fossilizedcustoms.com/\r\n\r\nTorah on the Web - Virtual Beit Midrash - Torah: http://www.vbm-torah.org/moadim.html\r\n\r\nTorah on the Web - Virtual Beit Midrash: http://vbm-torah.org/\r\n\r\nTotShabbat.com: http://www.totshabbat.com/\r\n\r\nTwebrew School: http://www.twebrewschool.org/\r\n\r\nTwinkle, twinkle little star: http://www.storytimesongs.com/guitarchords/Twinkle.html\r\n\r\nVictorious Homeschoolers: https://www.homeschool-life.com/sysfiles/member/index_public.cfm?memberid=693\r\n\r\nVirtual Jerusalem-The Place Where Jews Click: http://www.virtualjerusalem.com/\r\n\r\nvirtualyeshiva.com Torah Learning on the Net: http://www.virtualyeshiva.com/\r\n\r\nWalking in Torah Teachings Hebrew Nation: http://walkingintorah.com/Teachings.html\r\n\r\nway of the master radio: http://www.oneplace.com/ministries/way-of-the-master/\r\n\r\nWearing the Tallit Katan: http://www.hebrew4christians.com/Blessings/Daily_Blessings/Tallit_Katan/tallit_katan.html\r\n\r\nWelcome kabbalah course: http://edu.kabbalah.info/group/lc/home\r\n\r\nWelcome to biblediagrams.com: http://biblediagrams.com/diagrams/index.htm\r\n\r\nWelcome to MessianicJewish.net: http://www.messianicjewish.net/\r\n\r\nWelcome to the JewToo.org Blog!: http://jewtoo.multiply.com/\r\n\r\nWelcome to your Tampa Jewish Community Online!: http://www.jewishtampa.com/calendar/index.aspx?startdate=3/9/2011%206:30:00%20PM&enddate=3/9/2011%207:45:00%20PM&id=20&eventid=510947&recurrenceid=11922\r\n\r\nWINK News: http://www.winknews.com/weather/doppler\r\n\r\nWitnessing Resources -: http://www.nazarenemedia.net/witnessing-resources.html\r\n\r\nworship song guitar chords: http://www.worshiparchive.com/\r\n\r\nwww.wstw.fm listen: http://www.wstw.fm/listen%20live.html\r\n\r\nYashaNet HomePage: http://www.yashanet.com/index.htm\r\n\r\nYeshiva Beth HaShem Bible 101: http://yeshivabethhashem.org/yeshiva/1lesson4.html\r\n\r\nYotzer Hame'orot - the Morning Blessing: http://www.hebrew4christians.com/Blessings/Daily_Blessings/Yotzer_Hame_orot/yotzer_hame_orot.html\r\n\r\nThe Straight Way Ministry Home Page: http://thestraightway.org/\r\n\r\nifcj Journey Through the Scriptures: http://www.ifcj.org/site/PageNavigator/eng/jtts\r\n\r\nTanya - The Book of Tanya Translated into English - Text of the Tanya: http://www.chabad.org/library/tanya/tanya_cdo/aid/1028862/jewish/Tanya.htm\r\n\r\nJewish Holidays, Torah, Jewish Jobs, Tuition Affordability, Kosher Certification, Jewish Teens: http://www.ou.org/\r\n\r\nEsynagogue.org - Home: http://www.esynagogue.org/\r\n\r\nKeep It!: javascript:(a%20=%20(b%20=%20document).createElement('script')).src%20=%20'http://keepvid.com/js/bm.js',%20b.body.appendChild(a);void(0;\r\n\r\nwww.VirtualCantor.com: http://virtualcantor.com/CDOrder.htm\r\n\r\nTRI Classes: http://www.triclasses.com/\r\n\r\nAggressive Christianity Library: http://www.aggressivechristianity.net/library.htm\r\n\r\nDictionary of the Targumim, the Talmud Babli and Yerushalmi, and the Midrashic Literature by Marcus Jastrow: [suspicious link removed]\r\n\r\nHalakhah.com Babylonian Talmud Online in English: http://halakhah.com/\r\n\r\nKhabouris Codex Aramaic Peshitta New Testament Manuscript: http://www.aramaicpeshitta.com/AramaicNTtools/khabouris.htm\r\n\r\nJacob Richman's Hot Sites - Jewish - Learn Hebrew Sites: http://www.jr.co.il/hotsites/j-hebrew.htm\r\n\r\nIndex for Part 1 Kitzur Shulchan Aruch Linear Translation by Yona Newman© 1999-2010: http://www.yonanewman.org/kizzur/kiz-index1.html\r\n\r\nIndex for Part 2 Kitzur Shulchan Aruch Linear Translation by Yona Newman© 1999-2010: http://www.yonanewman.org/kizzur/kiz-index2.html\r\n\r\nBiblia Hebraica (Biblical Hebrew - Home): http://www.bible101.org/hebrew/home.html","content_html":"<p>Here are the names and URLs extracted from the provided bookmarks list:</p>\n<p>GTE Mobile Banking: https://m.gtefcu.org/mobile/Default.aspx?ReturnUrl=%2fmobile%2fMember%2fAccounts%2fTransactionHistory.aspx%3fR6ldQ2Rt%252bjUGc0%252f3%252fhP9UxU2hEVocAsOAVJ4EPdcd9Hh0BsxuR0ilPHrPQzwSXJWzbVCFr3txWVrhtMn9YIzTE6DpzA4jgy3BwTNCXbCmuc%253d-YuyNrzQIfzg%253d&amp;R6ldQ2Rt%2bjUGc0%2f3%2fhP9UxU2hEVocAsOAVJ4EPdcd9Hh0BsxuR0ilPHrPQzwSXJWzbVCFr3txWVrhtMn9YIzTE6DpzA4jgy3BwTNCXbCmuc%3d-YuyNrzQIfzg%3d</p>\n<p>View All Photos | 100 Easy Chicken Recipes | Cooking Light: http://www.cookinglight.com/food/quick-healthy/easy-chicken-recipes/view-all</p>\n<p>Yahoo! Mail: https://m.mg.mail.yahoo.com/hg/?.intl=us</p>\n<p>Weather Station History | Weather Underground: http://www.wunderground.com/weatherstation/WXDailyHistory.asp?ID=ITARLACC2</p>\n<p>About Shalom Sesame – Shalom Sesame: http://www.shalomsesame.org/about2.html</p>\n<p>AMAZING FACTS: http://www.amazingfacts.org/store/entity/tabid/267/entityname/category/categoryid/126/sename/character-studies/default.aspx</p>\n<p>Ancient Hebrew Research Center - Home Page: http://www.ancient-hebrew.org/</p>\n<p>Anthem BlueCross BlueShield - Verizon Home: http://www.anthem.com/verizon/</p>\n<p>Atheist Central -- Ray Comfort&#039;s Blog: http://raycomfortfood.blogspot.com/</p>\n<p>Audio Lessons « Think Hebrew: http://thinkhebrew.wordpress.com/audio-lessons/</p>\n<p>Barnes &amp; Noble.com - eBooks Search Orthodox Jewish bible: http://productsearch.barnesandnoble.com/search/results.aspx?store=EBOOK&amp;WRD=Orthodox+Jewish+bible</p>\n<p>Beginning Hebrew Class Tim Hegg: http://www.torahresource.com/Hebrew.html</p>\n<p>Behind The Scenes- 5-9-11: http://www.livingwaters.com/index.php?option=com_k2&amp;view=item&amp;id=2753&amp;Itemid=314&amp;lang=en</p>\n<p>Beit Tehila Congregation - Shalom: http://www.topraise.net/pages/about-us/history.htm</p>\n<p>Beth Messiah Messianic Synagogue Sarasota, Florida USA Rabbi Judah Hungerman: http://www.bethmessiahfla.com/</p>\n<p>Bible and Mishneh Torah for All - Jews and Gentiles - Mechon Mamre: http://www.mechon-mamre.org/</p>\n<p>bible passages: http://www.openbible.info/topics/eating_fish</p>\n<p>Bible University: http://www.bibleuniversity.com/University/Welcome.asp</p>\n<p>Biblical Hebrew Blog - By eTeacherBiblical.com Learn Biblical Hebrew online: http://blog.eteacherbiblical.com/</p>\n<p>Biblical Hermeneutics BiblicalTraining.org: http://www.biblicaltraining.org/biblical-hermeneutics/robert-stein</p>\n<p>BiblicalDiscipleship.org: http://biblicaldiscipleship.org/</p>\n<p>Birth Issues Yeshua in Context: http://yeshuaincontext.com/2011/03/birth-issues/</p>\n<p>BlogEngine.NET: http://blogengine.codeplex.com/discussions?prog_id=register_cheap_domain_names_cheap_web_hosting&amp;ProjectName=blogengine</p>\n<p>Bukharin Yarmulke Pattern k2p2.net Blog: http://k2p2.net/blog2/2006/08/31/bukharin-yarmulke-pattern/</p>\n<p>Buy Jewish Gifts Online - Jewelry - Kippah - Mezuzah - Star of David - Kabbalah Red String Bracelets - Evil Eye Charm: http://www.yourholylandstore.com/</p>\n<p>Chabad Jewish Holidays: http://www.chabad.org/library/article_cdo/aid/102698/jewish/Tevet-10.htm</p>\n<p>CHANUKAH ...History &amp; Prophetic End Time Implications: http://www.graftedforlife.org/blogs/index.php/2010/12/03/chanukah-history-aamp-prophetic-end-time-implications?blog=9</p>\n<p>Chofetz Chaim Laws of Speech Naaleh Torah Video Online: http://www.naaleh.com/search/class/148</p>\n<p>Contact Us: http://www.chabadcountyline.com/index.php?option=com_facileforms&amp;act=quickmode&amp;task=edit&amp;formName=ContactUs&amp;Itemid=152</p>\n<p>Count Today&#039;s Omer - Sefirat HaOmer: http://www.chabad.org/holidays/sefirah/omer-count.asp?date=4/19/2011</p>\n<p>Credit Bureau Reporting: http://www.thelpa.com/lpa/credit-reporting.html</p>\n<p>Deuteronomy 1622 Bible Lexicon: http://biblelexicon.org/deuteronomy/16-22.htm</p>\n<p>Didache: http://www.earlychristianwritings.com/didache.html</p>\n<p>directoryBedini SG - PESWiki Tesla Generator: http://peswiki.com/energy/Directory:Bedini_SG</p>\n<p>Dr. Janice Hughes, Clinical Social Work-Therapist, Cape Coral, FL 33914 Psychology Today&#039;s Therapy Directory: http://therapists.psychologytoday.com/rms/prof_detail.php?profid=73368&amp;sid=1281461131.0405_1063&amp;city=Fort+Myers&amp;county=Lee&amp;state=Florida&amp;spec=166</p>\n<p>D&#039;var Torah on the Parashah - Torah Portion of the Week: http://www.artscroll.com/parashah/current.html</p>\n<p>Early Christian Writings New Testament, Apocrypha, Gnostics, Church Fathers: http://www.earlychristianwritings.com/index.html</p>\n<p>Early Jewish Writings: http://www.earlyjewishwritings.com/</p>\n<p>Easiest Online Backup Service - Backblaze: http://www.backblaze.com/</p>\n<p>ebay Seller Tools File Exchange: http://pages.ebay.com/file_exchange/</p>\n<p>Essays and Articles: http://therefinersfire.org/ea.htm</p>\n<p>Essenes, Essene Teachings and Essene Theology: http://www.thenazareneway.com/</p>\n<p>Filipino Audio Lessons: http://mylanguages.org/filipino_audio.php</p>\n<p>Firm Foundation Guitar Tabs, Chords &amp; Lyrics by Jamie Harvill &amp; Nancy Gordon: http://www.worshiparchive.com/song/firm-foundation</p>\n<p>First Fruits Core [Beta]: https://ffoz.org/members/member_cp/index.php</p>\n<p>Florida Lotto: http://www.flalottery.com/inet/lottoMain.do</p>\n<p>FoundationStone - a free and easy way to learn Hebrew: http://foundationstone.com.au/FoundationStone.html?./OnlineHebrewTutorial.html</p>\n<p>Free Lessons Learn Biblical Hebrew with eTeacher: http://eteacherbiblical.com/free-lessons</p>\n<p>Free Online Hebrew Dictionary. Type in Hebrew-English. Translate Hebrew or Phonetic Hebrew.: http://www.doitinhebrew.com/Translate/default.aspx?kb=IL%20Hebrew%20Phonetic</p>\n<p>Front Page www.jewishpresstampa.com Jewish Press of Tampa: http://www.jewishpresstampa.com/</p>\n<p>G-DCAST: http://www.g-dcast.com/</p>\n<p>Google Translate: http://translate.google.com/#</p>\n<p>Hanukkah - Chanukah 2010 - Menorah, Dreidels, Latkes, Recipes, Games and more: http://www.chabad.org/holidays/chanukah/default_cdo/jewish/Hanukkah.htm</p>\n<p>Hebrew Lessons — Ten Commandments: http://www.levitt.com/hebrew/commandments.html</p>\n<p>Home Yarnell: http://www.yarnellschool.com/online/yarnell/index.html</p>\n<p>Information Technology Students and Faculty: http://msdn01.e-academy.com/elms/Storefront/Home.aspx?campus=sfc_it</p>\n<p>Introduction to Islam BiblicalTraining.org: http://www.biblicaltraining.org/introduction-islam/timothy-tennent</p>\n<p>iTanakh: http://www.itanakh.org/</p>\n<p>Jewish Community, Jewish Synagogue, Kosher Food, Makati, Philippines: http://jewishphilippines.net/newsletter.php#</p>\n<p>Jewish Genealogy By Genetics - JewishGen: http://www.jewishgen.org/dna/genbygen.html</p>\n<p>Jewish Roots Learning Center Haydid: http://www.haydid.org/</p>\n<p>Jewish Studies Org: http://www.jewishstudies.org/</p>\n<p>Journey To Jerusalem Home Page: http://www.journeytojerusalem.com/</p>\n<p>Judaism and Jewish Resources - Andrew Tannenbaum: http://shamash.org/trb/judaism.html#learning</p>\n<p>JVIMS Courses: http://www.jvims.com/index.php?page=shop.browse&amp;category_id=6&amp;option=com_virtuemart&amp;Itemid=64&amp;vmcchk=1&amp;Itemid=64</p>\n<p>JVIMS Rabbi Courses: http://jvims.com/index.php?page=shop.browse&amp;category_id=6&amp;option=com_virtuemart&amp;Itemid=64</p>\n<p>KidsAstronomy.com Online Astronomy Academy: http://www.kidsastronomy.com/academy/index.htm</p>\n<p>Learn Hebrew and Jewish prayer with our user friendly Software, Book and Audio tutorials and products: http://www.hebrewworld.com/specialOffer.html</p>\n<p>Lighting Up Chanukah: http://www.betemunah.org/chanukah.html</p>\n<p>Listen to Prayers Bet Am Shalom - A Reconstructionist Synagogue, White Plains, NY: http://betamshalom.org/prayers</p>\n<p>Liturgy: http://www.cyber-synagogue.com/Liturgy.htm</p>\n<p>Mahal - Volunteer for the IDF - Join the Israeli Army: http://www.mahal-idf-volunteers.org/support/linkus.htm</p>\n<p>Messianic Jewish Rabbinical Council: http://ourrabbis.org/main/</p>\n<p>Messianic Jewish Radio - San Francisco, CA - Listen Online: http://radiotime.com/station/s_111593/Messianic_Jewish_Radio.aspx</p>\n<p>Messianic Symbol Hebraic Roots Banner-Red: https://www.storesonline.com/site/742858/product/SFA-32133</p>\n<p>Money Transfer - Send Money Online: https://www.xoom.com/sendmoneynow/home2/security</p>\n<p>Mount Olive Press: http://mountolivepress.com/Mount_Olive_Press/Home.html</p>\n<p>Movie Showtimes and Tickets for 33982 - Yahoo! Movies: http://movies.yahoo.com/showtimes-tickets/?location=33982&amp;r=sim</p>\n<p>My Account Login: https://idp.securepaynet.net/login.aspx?isc=wwbb53&amp;prog%5Fid=register%5Fcheap%5Fdomain%5Fnames%5Fcheap%5Fweb%5Fhosting&amp;spkey=SPSWB166&amp;login=9492585&amp;target=myportal%2Fdomainren%2Easp</p>\n<p>My order history BiblicalTraining.org: http://www.biblicaltraining.org/user/39652/orders</p>\n<p>My Wish List Decorative Painting Bookstore: http://www.decorativepaintingbookstore.com/mm5/merchant.mvc?</p>\n<p>Nazarene Media - Home: http://www.nazarenemedia.net/</p>\n<p>Nazerine books and school: http://stores.lulu.com/nazarene</p>\n<p>Not Subject to the Law of God: http://www.yashanet.com/library/underlaw.htm</p>\n<p>Of His Kingdom There Shall Be No End Mashiyach Mashiyach Mashiyach: http://www.mashiyach.com/index.htm</p>\n<p>ohr chadash: http://www.ohrchadash.org/contact.htm</p>\n<p>Old Testament Studies: http://www.torahclass.com/old-testament-studies</p>\n<p>Operation Wake Up Call - Nazarene Space: http://nazarenespace.com/group/operationwakeupcall</p>\n<p>orderConfirmation: https://www.rewardsuite.com/rewardsuite/Catalog/View/orderConfirmation.aspx?i=dzOj5blTL2o%3d</p>\n<p>page 3: http://www.globalprebuilder.com/page3-v2.php</p>\n<p>Pasco County Library System Program Home Page: http://evanced.info/pasco/sr/homepage.asp?ProgramID=27</p>\n<p>Peshitta.org • View forum - Nazarene-Messianic Judaism Forum: http://www.peshitta.org/forum/viewforum.php?f=6</p>\n<p>Principles of Christian Dream Interpretation: http://www.cwgministries.org/Principles-of-Christian-Dream-Interpretation</p>\n<p>prophecyrevealed - I Have A Friend Who&#039;s Jewish Book: http://prophecyrevealed.com/</p>\n<p>Psalms 23 - Hebrew - English Bible - Mechon-Mamre: http://www.mechon-mamre.org/p/pt/pt2623.htm</p>\n<p>Rabbi Eric Levy and Family: http://www.ericlevy.com/</p>\n<p>Revelation 11-6: http://www.yashanet.com/studies/revstudy/text/r1_1-6.htm</p>\n<p>Revelation Study Text Index: http://www.yashanet.com/studies/revstudy/text/index.htm</p>\n<p>Rick Recht Online Store -: http://store.jewishrockrecords.com/store/listings.cfm?cat=12</p>\n<p>SAP Support Portal - Homepage: https://websmp202.sap-ag.de/support</p>\n<p>School of Biblical Evangelism: http://www.biblicalevangelism.com/register</p>\n<p>Shaarei halachah a summary of laws for Jewish living Online Free Books: http://online-free-books.com/title/Txt4EidAVFEC.html</p>\n<p>Shoresh David Messianic Jewish Synagogues (Tampa, Lakeland, &amp; Wesley Chapel, FL): http://www.shoreshdavid.org/</p>\n<p>Silver Jerusalem design Hand Embroidered Hat: http://www.ajudaica.com/item/1494_324/Silver+Jerusalem+design+Hand+Embroidered+Hat</p>\n<p>Smile of a Child TV -- Television Program Schedule: http://www.smileofachildtv.org/watch/schedule_weekview.php</p>\n<p>Sounds of Shalom: http://www.soundsofshalom.com/</p>\n<p>Subscription Donations; Messianic Christianity: http://www.messianicchristianity.org/subscription_donations.html</p>\n<p>Table of Contents - Torah 101 - Mechon Mamre: http://www.mechon-mamre.org/jewfaq/index.htm</p>\n<p>Tanach Index Hebrew with Vowels: http://www.sacred-texts.com/bib/tan/index.htm</p>\n<p>Temple Aron Hakodesh: http://www.tak.org/services.htm</p>\n<p>Temple Israel NH » Prayer Recordings: http://www.templeisraelnh.org/education/prayer-recordings/</p>\n<p>TES - Largest Distributor of Jewish Software, Hebrew Language and Bible Software (0): http://www.jewishsoftware.com/default.asp?page=category&amp;id=4</p>\n<p>Texts of Judaism: http://www.sacred-texts.com/jud/</p>\n<p>The Aramaic origin of the Fourth gospel - Google Books: http://books.google.com/ebooks/reader?id=2WhAAAAAIAAJ&amp;printsec=frontcover&amp;output=reader</p>\n<p>The Book of Zohar Books Michael Laitman Kabbalah Library - Bnei Baruch Kabbalah Education &amp; Research Institute: http://www.kabbalah.info/eng/content/view/frame/2842?/eng/content/view/full_list/2842&amp;main</p>\n<p>The Evolution of a Creationist Jobe Martin Creation vs. Evolution: http://evolutionofacreationist.com/</p>\n<p>The Foreign Service of the Philippines - Manila Forwarders: http://www.manilaforwarder.com/immigrantvisa_pg2.html</p>\n<p>The Lotto Black Book! Secrets Exposed...: http://lottoblackbooks.co.cc/aff.php</p>\n<p>The Nazarite Site: http://www.nazarite.net/home.html</p>\n<p>The Poetry of Genesis Chapter One: http://www.ancient-hebrew.org/23_genesis_1.html</p>\n<p>The Revelation of Y&#039;shua HaMoshiach Thus Say The Prophets!: http://jewtoo.org/prophecy/</p>\n<p>The Shul of the Web: http://www.heartofisrael.net/</p>\n<p>The Worldwide Nazarene Assembly of Elohim - Directory of WNAE Assemblies: http://www.wnae.org/assemblies.htm</p>\n<p>THE WORSHIP OF IMAGES catholism: http://www.justforcatholics.org/images.htm</p>\n<p>Tim Hegg Shabbat Shalom Page: http://www.torahresource.com/</p>\n<p>Torah (Teachings) of Yahshua Messiah (Jesus, Yeshua) - rebuking the Trinity and Lawlessness: http://www.torahofmessiah.com/trinity_art.html</p>\n<p>Torah Institute FREE PDF DOWNLOADS: http://www.torahzone.net/FREE-PDF-DOWNLOADS/?page=3</p>\n<p>torah institute: http://www.fossilizedcustoms.com/</p>\n<p>Torah on the Web - Virtual Beit Midrash - Torah: http://www.vbm-torah.org/moadim.html</p>\n<p>Torah on the Web - Virtual Beit Midrash: http://vbm-torah.org/</p>\n<p>TotShabbat.com: http://www.totshabbat.com/</p>\n<p>Twebrew School: http://www.twebrewschool.org/</p>\n<p>Twinkle, twinkle little star: http://www.storytimesongs.com/guitarchords/Twinkle.html</p>\n<p>Victorious Homeschoolers: https://www.homeschool-life.com/sysfiles/member/index_public.cfm?memberid=693</p>\n<p>Virtual Jerusalem-The Place Where Jews Click: http://www.virtualjerusalem.com/</p>\n<p>virtualyeshiva.com Torah Learning on the Net: http://www.virtualyeshiva.com/</p>\n<p>Walking in Torah Teachings Hebrew Nation: http://walkingintorah.com/Teachings.html</p>\n<p>way of the master radio: http://www.oneplace.com/ministries/way-of-the-master/</p>\n<p>Wearing the Tallit Katan: http://www.hebrew4christians.com/Blessings/Daily_Blessings/Tallit_Katan/tallit_katan.html</p>\n<p>Welcome kabbalah course: http://edu.kabbalah.info/group/lc/home</p>\n<p>Welcome to biblediagrams.com: http://biblediagrams.com/diagrams/index.htm</p>\n<p>Welcome to MessianicJewish.net: http://www.messianicjewish.net/</p>\n<p>Welcome to the JewToo.org Blog!: http://jewtoo.multiply.com/</p>\n<p>Welcome to your Tampa Jewish Community Online!: http://www.jewishtampa.com/calendar/index.aspx?startdate=3/9/2011%206:30:00%20PM&amp;enddate=3/9/2011%207:45:00%20PM&amp;id=20&amp;eventid=510947&amp;recurrenceid=11922</p>\n<p>WINK News: http://www.winknews.com/weather/doppler</p>\n<p>Witnessing Resources -: http://www.nazarenemedia.net/witnessing-resources.html</p>\n<p>worship song guitar chords: http://www.worshiparchive.com/</p>\n<p>www.wstw.fm listen: http://www.wstw.fm/listen%20live.html</p>\n<p>YashaNet HomePage: http://www.yashanet.com/index.htm</p>\n<p>Yeshiva Beth HaShem Bible 101: http://yeshivabethhashem.org/yeshiva/1lesson4.html</p>\n<p>Yotzer Hame&#039;orot - the Morning Blessing: http://www.hebrew4christians.com/Blessings/Daily_Blessings/Yotzer_Hame_orot/yotzer_hame_orot.html</p>\n<p>The Straight Way Ministry Home Page: http://thestraightway.org/</p>\n<p>ifcj Journey Through the Scriptures: http://www.ifcj.org/site/PageNavigator/eng/jtts</p>\n<p>Tanya - The Book of Tanya Translated into English - Text of the Tanya: http://www.chabad.org/library/tanya/tanya_cdo/aid/1028862/jewish/Tanya.htm</p>\n<p>Jewish Holidays, Torah, Jewish Jobs, Tuition Affordability, Kosher Certification, Jewish Teens: http://www.ou.org/</p>\n<p>Esynagogue.org - Home: http://www.esynagogue.org/</p>\n<p>Keep It!: javascript:(a%20=%20(b%20=%20document).createElement(&#039;script&#039;)).src%20=%20&#039;http://keepvid.com/js/bm.js&#039;,%20b.body.appendChild(a);void(0;</p>\n<p>www.VirtualCantor.com: http://virtualcantor.com/CDOrder.htm</p>\n<p>TRI Classes: http://www.triclasses.com/</p>\n<p>Aggressive Christianity Library: http://www.aggressivechristianity.net/library.htm</p>\n<p>Dictionary of the Targumim, the Talmud Babli and Yerushalmi, and the Midrashic Literature by Marcus Jastrow: [suspicious link removed]</p>\n<p>Halakhah.com Babylonian Talmud Online in English: http://halakhah.com/</p>\n<p>Khabouris Codex Aramaic Peshitta New Testament Manuscript: http://www.aramaicpeshitta.com/AramaicNTtools/khabouris.htm</p>\n<p>Jacob Richman&#039;s Hot Sites - Jewish - Learn Hebrew Sites: http://www.jr.co.il/hotsites/j-hebrew.htm</p>\n<p>Index for Part 1 Kitzur Shulchan Aruch Linear Translation by Yona Newman© 1999-2010: http://www.yonanewman.org/kizzur/kiz-index1.html</p>\n<p>Index for Part 2 Kitzur Shulchan Aruch Linear Translation by Yona Newman© 1999-2010: http://www.yonanewman.org/kizzur/kiz-index2.html</p>\n<p>Biblia Hebraica (Biblical Hebrew - Home): http://www.bible101.org/hebrew/home.html</p>","file_name":"COMPREHENSIVE_DOCUMENTATION.md","stored_name":"20260417-160828-6006d4f1.md","mime_type":"application/octet-stream","file_size_bytes":"22313","storage_path":"/mnt/drive1/customerdb/backend/documents_storage/20260417-160828-6006d4f1.md","is_deleted":"0","created_at":"2026-04-17 12:08:29","updated_at":"2026-04-17 14:50:34","editor_content":"Here are the names and URLs extracted from the provided bookmarks list:\r\n\r\nGTE Mobile Banking: https://m.gtefcu.org/mobile/Default.aspx?ReturnUrl=%2fmobile%2fMember%2fAccounts%2fTransactionHistory.aspx%3fR6ldQ2Rt%252bjUGc0%252f3%252fhP9UxU2hEVocAsOAVJ4EPdcd9Hh0BsxuR0ilPHrPQzwSXJWzbVCFr3txWVrhtMn9YIzTE6DpzA4jgy3BwTNCXbCmuc%253d-YuyNrzQIfzg%253d&R6ldQ2Rt%2bjUGc0%2f3%2fhP9UxU2hEVocAsOAVJ4EPdcd9Hh0BsxuR0ilPHrPQzwSXJWzbVCFr3txWVrhtMn9YIzTE6DpzA4jgy3BwTNCXbCmuc%3d-YuyNrzQIfzg%3d\r\n\r\nView All Photos | 100 Easy Chicken Recipes | Cooking Light: http://www.cookinglight.com/food/quick-healthy/easy-chicken-recipes/view-all\r\n\r\nYahoo! Mail: https://m.mg.mail.yahoo.com/hg/?.intl=us\r\n\r\nWeather Station History | Weather Underground: http://www.wunderground.com/weatherstation/WXDailyHistory.asp?ID=ITARLACC2\r\n\r\nAbout Shalom Sesame – Shalom Sesame: http://www.shalomsesame.org/about2.html\r\n\r\nAMAZING FACTS: http://www.amazingfacts.org/store/entity/tabid/267/entityname/category/categoryid/126/sename/character-studies/default.aspx\r\n\r\nAncient Hebrew Research Center - Home Page: http://www.ancient-hebrew.org/\r\n\r\nAnthem BlueCross BlueShield - Verizon Home: http://www.anthem.com/verizon/\r\n\r\nAtheist Central -- Ray Comfort's Blog: http://raycomfortfood.blogspot.com/\r\n\r\nAudio Lessons « Think Hebrew: http://thinkhebrew.wordpress.com/audio-lessons/\r\n\r\nBarnes & Noble.com - eBooks Search Orthodox Jewish bible: http://productsearch.barnesandnoble.com/search/results.aspx?store=EBOOK&WRD=Orthodox+Jewish+bible\r\n\r\nBeginning Hebrew Class Tim Hegg: http://www.torahresource.com/Hebrew.html\r\n\r\nBehind The Scenes- 5-9-11: http://www.livingwaters.com/index.php?option=com_k2&view=item&id=2753&Itemid=314&lang=en\r\n\r\nBeit Tehila Congregation - Shalom: http://www.topraise.net/pages/about-us/history.htm\r\n\r\nBeth Messiah Messianic Synagogue Sarasota, Florida USA Rabbi Judah Hungerman: http://www.bethmessiahfla.com/\r\n\r\nBible and Mishneh Torah for All - Jews and Gentiles - Mechon Mamre: http://www.mechon-mamre.org/\r\n\r\nbible passages: http://www.openbible.info/topics/eating_fish\r\n\r\nBible University: http://www.bibleuniversity.com/University/Welcome.asp\r\n\r\nBiblical Hebrew Blog - By eTeacherBiblical.com Learn Biblical Hebrew online: http://blog.eteacherbiblical.com/\r\n\r\nBiblical Hermeneutics BiblicalTraining.org: http://www.biblicaltraining.org/biblical-hermeneutics/robert-stein\r\n\r\nBiblicalDiscipleship.org: http://biblicaldiscipleship.org/\r\n\r\nBirth Issues Yeshua in Context: http://yeshuaincontext.com/2011/03/birth-issues/\r\n\r\nBlogEngine.NET: http://blogengine.codeplex.com/discussions?prog_id=register_cheap_domain_names_cheap_web_hosting&ProjectName=blogengine\r\n\r\nBukharin Yarmulke Pattern k2p2.net Blog: http://k2p2.net/blog2/2006/08/31/bukharin-yarmulke-pattern/\r\n\r\nBuy Jewish Gifts Online - Jewelry - Kippah - Mezuzah - Star of David - Kabbalah Red String Bracelets - Evil Eye Charm: http://www.yourholylandstore.com/\r\n\r\nChabad Jewish Holidays: http://www.chabad.org/library/article_cdo/aid/102698/jewish/Tevet-10.htm\r\n\r\nCHANUKAH ...History & Prophetic End Time Implications: http://www.graftedforlife.org/blogs/index.php/2010/12/03/chanukah-history-aamp-prophetic-end-time-implications?blog=9\r\n\r\nChofetz Chaim Laws of Speech Naaleh Torah Video Online: http://www.naaleh.com/search/class/148\r\n\r\nContact Us: http://www.chabadcountyline.com/index.php?option=com_facileforms&act=quickmode&task=edit&formName=ContactUs&Itemid=152\r\n\r\nCount Today's Omer - Sefirat HaOmer: http://www.chabad.org/holidays/sefirah/omer-count.asp?date=4/19/2011\r\n\r\nCredit Bureau Reporting: http://www.thelpa.com/lpa/credit-reporting.html\r\n\r\nDeuteronomy 1622 Bible Lexicon: http://biblelexicon.org/deuteronomy/16-22.htm\r\n\r\nDidache: http://www.earlychristianwritings.com/didache.html\r\n\r\ndirectoryBedini SG - PESWiki Tesla Generator: http://peswiki.com/energy/Directory:Bedini_SG\r\n\r\nDr. Janice Hughes, Clinical Social Work-Therapist, Cape Coral, FL 33914 Psychology Today's Therapy Directory: http://therapists.psychologytoday.com/rms/prof_detail.php?profid=73368&sid=1281461131.0405_1063&city=Fort+Myers&county=Lee&state=Florida&spec=166\r\n\r\nD'var Torah on the Parashah - Torah Portion of the Week: http://www.artscroll.com/parashah/current.html\r\n\r\nEarly Christian Writings New Testament, Apocrypha, Gnostics, Church Fathers: http://www.earlychristianwritings.com/index.html\r\n\r\nEarly Jewish Writings: http://www.earlyjewishwritings.com/\r\n\r\nEasiest Online Backup Service - Backblaze: http://www.backblaze.com/\r\n\r\nebay Seller Tools File Exchange: http://pages.ebay.com/file_exchange/\r\n\r\nEssays and Articles: http://therefinersfire.org/ea.htm\r\n\r\nEssenes, Essene Teachings and Essene Theology: http://www.thenazareneway.com/\r\n\r\nFilipino Audio Lessons: http://mylanguages.org/filipino_audio.php\r\n\r\nFirm Foundation Guitar Tabs, Chords & Lyrics by Jamie Harvill & Nancy Gordon: http://www.worshiparchive.com/song/firm-foundation\r\n\r\nFirst Fruits Core [Beta]: https://ffoz.org/members/member_cp/index.php\r\n\r\nFlorida Lotto: http://www.flalottery.com/inet/lottoMain.do\r\n\r\nFoundationStone - a free and easy way to learn Hebrew: http://foundationstone.com.au/FoundationStone.html?./OnlineHebrewTutorial.html\r\n\r\nFree Lessons Learn Biblical Hebrew with eTeacher: http://eteacherbiblical.com/free-lessons\r\n\r\nFree Online Hebrew Dictionary. Type in Hebrew-English. Translate Hebrew or Phonetic Hebrew.: http://www.doitinhebrew.com/Translate/default.aspx?kb=IL%20Hebrew%20Phonetic\r\n\r\nFront Page www.jewishpresstampa.com Jewish Press of Tampa: http://www.jewishpresstampa.com/\r\n\r\nG-DCAST: http://www.g-dcast.com/\r\n\r\nGoogle Translate: http://translate.google.com/#\r\n\r\nHanukkah - Chanukah 2010 - Menorah, Dreidels, Latkes, Recipes, Games and more: http://www.chabad.org/holidays/chanukah/default_cdo/jewish/Hanukkah.htm\r\n\r\nHebrew Lessons — Ten Commandments: http://www.levitt.com/hebrew/commandments.html\r\n\r\nHome Yarnell: http://www.yarnellschool.com/online/yarnell/index.html\r\n\r\nInformation Technology Students and Faculty: http://msdn01.e-academy.com/elms/Storefront/Home.aspx?campus=sfc_it\r\n\r\nIntroduction to Islam BiblicalTraining.org: http://www.biblicaltraining.org/introduction-islam/timothy-tennent\r\n\r\niTanakh: http://www.itanakh.org/\r\n\r\nJewish Community, Jewish Synagogue, Kosher Food, Makati, Philippines: http://jewishphilippines.net/newsletter.php#\r\n\r\nJewish Genealogy By Genetics - JewishGen: http://www.jewishgen.org/dna/genbygen.html\r\n\r\nJewish Roots Learning Center Haydid: http://www.haydid.org/\r\n\r\nJewish Studies Org: http://www.jewishstudies.org/\r\n\r\nJourney To Jerusalem Home Page: http://www.journeytojerusalem.com/\r\n\r\nJudaism and Jewish Resources - Andrew Tannenbaum: http://shamash.org/trb/judaism.html#learning\r\n\r\nJVIMS Courses: http://www.jvims.com/index.php?page=shop.browse&category_id=6&option=com_virtuemart&Itemid=64&vmcchk=1&Itemid=64\r\n\r\nJVIMS Rabbi Courses: http://jvims.com/index.php?page=shop.browse&category_id=6&option=com_virtuemart&Itemid=64\r\n\r\nKidsAstronomy.com Online Astronomy Academy: http://www.kidsastronomy.com/academy/index.htm\r\n\r\nLearn Hebrew and Jewish prayer with our user friendly Software, Book and Audio tutorials and products: http://www.hebrewworld.com/specialOffer.html\r\n\r\nLighting Up Chanukah: http://www.betemunah.org/chanukah.html\r\n\r\nListen to Prayers Bet Am Shalom - A Reconstructionist Synagogue, White Plains, NY: http://betamshalom.org/prayers\r\n\r\nLiturgy: http://www.cyber-synagogue.com/Liturgy.htm\r\n\r\nMahal - Volunteer for the IDF - Join the Israeli Army: http://www.mahal-idf-volunteers.org/support/linkus.htm\r\n\r\nMessianic Jewish Rabbinical Council: http://ourrabbis.org/main/\r\n\r\nMessianic Jewish Radio - San Francisco, CA - Listen Online: http://radiotime.com/station/s_111593/Messianic_Jewish_Radio.aspx\r\n\r\nMessianic Symbol Hebraic Roots Banner-Red: https://www.storesonline.com/site/742858/product/SFA-32133\r\n\r\nMoney Transfer - Send Money Online: https://www.xoom.com/sendmoneynow/home2/security\r\n\r\nMount Olive Press: http://mountolivepress.com/Mount_Olive_Press/Home.html\r\n\r\nMovie Showtimes and Tickets for 33982 - Yahoo! Movies: http://movies.yahoo.com/showtimes-tickets/?location=33982&r=sim\r\n\r\nMy Account Login: https://idp.securepaynet.net/login.aspx?isc=wwbb53&prog%5Fid=register%5Fcheap%5Fdomain%5Fnames%5Fcheap%5Fweb%5Fhosting&spkey=SPSWB166&login=9492585&target=myportal%2Fdomainren%2Easp\r\n\r\nMy order history BiblicalTraining.org: http://www.biblicaltraining.org/user/39652/orders\r\n\r\nMy Wish List Decorative Painting Bookstore: http://www.decorativepaintingbookstore.com/mm5/merchant.mvc?\r\n\r\nNazarene Media - Home: http://www.nazarenemedia.net/\r\n\r\nNazerine books and school: http://stores.lulu.com/nazarene\r\n\r\nNot Subject to the Law of God: http://www.yashanet.com/library/underlaw.htm\r\n\r\nOf His Kingdom There Shall Be No End Mashiyach Mashiyach Mashiyach: http://www.mashiyach.com/index.htm\r\n\r\nohr chadash: http://www.ohrchadash.org/contact.htm\r\n\r\nOld Testament Studies: http://www.torahclass.com/old-testament-studies\r\n\r\nOperation Wake Up Call - Nazarene Space: http://nazarenespace.com/group/operationwakeupcall\r\n\r\norderConfirmation: https://www.rewardsuite.com/rewardsuite/Catalog/View/orderConfirmation.aspx?i=dzOj5blTL2o%3d\r\n\r\npage 3: http://www.globalprebuilder.com/page3-v2.php\r\n\r\nPasco County Library System Program Home Page: http://evanced.info/pasco/sr/homepage.asp?ProgramID=27\r\n\r\nPeshitta.org • View forum - Nazarene-Messianic Judaism Forum: http://www.peshitta.org/forum/viewforum.php?f=6\r\n\r\nPrinciples of Christian Dream Interpretation: http://www.cwgministries.org/Principles-of-Christian-Dream-Interpretation\r\n\r\nprophecyrevealed - I Have A Friend Who's Jewish Book: http://prophecyrevealed.com/\r\n\r\nPsalms 23 - Hebrew - English Bible - Mechon-Mamre: http://www.mechon-mamre.org/p/pt/pt2623.htm\r\n\r\nRabbi Eric Levy and Family: http://www.ericlevy.com/\r\n\r\nRevelation 11-6: http://www.yashanet.com/studies/revstudy/text/r1_1-6.htm\r\n\r\nRevelation Study Text Index: http://www.yashanet.com/studies/revstudy/text/index.htm\r\n\r\nRick Recht Online Store -: http://store.jewishrockrecords.com/store/listings.cfm?cat=12\r\n\r\nSAP Support Portal - Homepage: https://websmp202.sap-ag.de/support\r\n\r\nSchool of Biblical Evangelism: http://www.biblicalevangelism.com/register\r\n\r\nShaarei halachah a summary of laws for Jewish living Online Free Books: http://online-free-books.com/title/Txt4EidAVFEC.html\r\n\r\nShoresh David Messianic Jewish Synagogues (Tampa, Lakeland, & Wesley Chapel, FL): http://www.shoreshdavid.org/\r\n\r\nSilver Jerusalem design Hand Embroidered Hat: http://www.ajudaica.com/item/1494_324/Silver+Jerusalem+design+Hand+Embroidered+Hat\r\n\r\nSmile of a Child TV -- Television Program Schedule: http://www.smileofachildtv.org/watch/schedule_weekview.php\r\n\r\nSounds of Shalom: http://www.soundsofshalom.com/\r\n\r\nSubscription Donations; Messianic Christianity: http://www.messianicchristianity.org/subscription_donations.html\r\n\r\nTable of Contents - Torah 101 - Mechon Mamre: http://www.mechon-mamre.org/jewfaq/index.htm\r\n\r\nTanach Index Hebrew with Vowels: http://www.sacred-texts.com/bib/tan/index.htm\r\n\r\nTemple Aron Hakodesh: http://www.tak.org/services.htm\r\n\r\nTemple Israel NH » Prayer Recordings: http://www.templeisraelnh.org/education/prayer-recordings/\r\n\r\nTES - Largest Distributor of Jewish Software, Hebrew Language and Bible Software (0): http://www.jewishsoftware.com/default.asp?page=category&id=4\r\n\r\nTexts of Judaism: http://www.sacred-texts.com/jud/\r\n\r\nThe Aramaic origin of the Fourth gospel - Google Books: http://books.google.com/ebooks/reader?id=2WhAAAAAIAAJ&printsec=frontcover&output=reader\r\n\r\nThe Book of Zohar Books Michael Laitman Kabbalah Library - Bnei Baruch Kabbalah Education & Research Institute: http://www.kabbalah.info/eng/content/view/frame/2842?/eng/content/view/full_list/2842&main\r\n\r\nThe Evolution of a Creationist Jobe Martin Creation vs. Evolution: http://evolutionofacreationist.com/\r\n\r\nThe Foreign Service of the Philippines - Manila Forwarders: http://www.manilaforwarder.com/immigrantvisa_pg2.html\r\n\r\nThe Lotto Black Book! Secrets Exposed...: http://lottoblackbooks.co.cc/aff.php\r\n\r\nThe Nazarite Site: http://www.nazarite.net/home.html\r\n\r\nThe Poetry of Genesis Chapter One: http://www.ancient-hebrew.org/23_genesis_1.html\r\n\r\nThe Revelation of Y'shua HaMoshiach Thus Say The Prophets!: http://jewtoo.org/prophecy/\r\n\r\nThe Shul of the Web: http://www.heartofisrael.net/\r\n\r\nThe Worldwide Nazarene Assembly of Elohim - Directory of WNAE Assemblies: http://www.wnae.org/assemblies.htm\r\n\r\nTHE WORSHIP OF IMAGES catholism: http://www.justforcatholics.org/images.htm\r\n\r\nTim Hegg Shabbat Shalom Page: http://www.torahresource.com/\r\n\r\nTorah (Teachings) of Yahshua Messiah (Jesus, Yeshua) - rebuking the Trinity and Lawlessness: http://www.torahofmessiah.com/trinity_art.html\r\n\r\nTorah Institute FREE PDF DOWNLOADS: http://www.torahzone.net/FREE-PDF-DOWNLOADS/?page=3\r\n\r\ntorah institute: http://www.fossilizedcustoms.com/\r\n\r\nTorah on the Web - Virtual Beit Midrash - Torah: http://www.vbm-torah.org/moadim.html\r\n\r\nTorah on the Web - Virtual Beit Midrash: http://vbm-torah.org/\r\n\r\nTotShabbat.com: http://www.totshabbat.com/\r\n\r\nTwebrew School: http://www.twebrewschool.org/\r\n\r\nTwinkle, twinkle little star: http://www.storytimesongs.com/guitarchords/Twinkle.html\r\n\r\nVictorious Homeschoolers: https://www.homeschool-life.com/sysfiles/member/index_public.cfm?memberid=693\r\n\r\nVirtual Jerusalem-The Place Where Jews Click: http://www.virtualjerusalem.com/\r\n\r\nvirtualyeshiva.com Torah Learning on the Net: http://www.virtualyeshiva.com/\r\n\r\nWalking in Torah Teachings Hebrew Nation: http://walkingintorah.com/Teachings.html\r\n\r\nway of the master radio: http://www.oneplace.com/ministries/way-of-the-master/\r\n\r\nWearing the Tallit Katan: http://www.hebrew4christians.com/Blessings/Daily_Blessings/Tallit_Katan/tallit_katan.html\r\n\r\nWelcome kabbalah course: http://edu.kabbalah.info/group/lc/home\r\n\r\nWelcome to biblediagrams.com: http://biblediagrams.com/diagrams/index.htm\r\n\r\nWelcome to MessianicJewish.net: http://www.messianicjewish.net/\r\n\r\nWelcome to the JewToo.org Blog!: http://jewtoo.multiply.com/\r\n\r\nWelcome to your Tampa Jewish Community Online!: http://www.jewishtampa.com/calendar/index.aspx?startdate=3/9/2011%206:30:00%20PM&enddate=3/9/2011%207:45:00%20PM&id=20&eventid=510947&recurrenceid=11922\r\n\r\nWINK News: http://www.winknews.com/weather/doppler\r\n\r\nWitnessing Resources -: http://www.nazarenemedia.net/witnessing-resources.html\r\n\r\nworship song guitar chords: http://www.worshiparchive.com/\r\n\r\nwww.wstw.fm listen: http://www.wstw.fm/listen%20live.html\r\n\r\nYashaNet HomePage: http://www.yashanet.com/index.htm\r\n\r\nYeshiva Beth HaShem Bible 101: http://yeshivabethhashem.org/yeshiva/1lesson4.html\r\n\r\nYotzer Hame'orot - the Morning Blessing: http://www.hebrew4christians.com/Blessings/Daily_Blessings/Yotzer_Hame_orot/yotzer_hame_orot.html\r\n\r\nThe Straight Way Ministry Home Page: http://thestraightway.org/\r\n\r\nifcj Journey Through the Scriptures: http://www.ifcj.org/site/PageNavigator/eng/jtts\r\n\r\nTanya - The Book of Tanya Translated into English - Text of the Tanya: http://www.chabad.org/library/tanya/tanya_cdo/aid/1028862/jewish/Tanya.htm\r\n\r\nJewish Holidays, Torah, Jewish Jobs, Tuition Affordability, Kosher Certification, Jewish Teens: http://www.ou.org/\r\n\r\nEsynagogue.org - Home: http://www.esynagogue.org/\r\n\r\nKeep It!: javascript:(a%20=%20(b%20=%20document).createElement('script')).src%20=%20'http://keepvid.com/js/bm.js',%20b.body.appendChild(a);void(0;\r\n\r\nwww.VirtualCantor.com: http://virtualcantor.com/CDOrder.htm\r\n\r\nTRI Classes: http://www.triclasses.com/\r\n\r\nAggressive Christianity Library: http://www.aggressivechristianity.net/library.htm\r\n\r\nDictionary of the Targumim, the Talmud Babli and Yerushalmi, and the Midrashic Literature by Marcus Jastrow: [suspicious link removed]\r\n\r\nHalakhah.com Babylonian Talmud Online in English: http://halakhah.com/\r\n\r\nKhabouris Codex Aramaic Peshitta New Testament Manuscript: http://www.aramaicpeshitta.com/AramaicNTtools/khabouris.htm\r\n\r\nJacob Richman's Hot Sites - Jewish - Learn Hebrew Sites: http://www.jr.co.il/hotsites/j-hebrew.htm\r\n\r\nIndex for Part 1 Kitzur Shulchan Aruch Linear Translation by Yona Newman© 1999-2010: http://www.yonanewman.org/kizzur/kiz-index1.html\r\n\r\nIndex for Part 2 Kitzur Shulchan Aruch Linear Translation by Yona Newman© 1999-2010: http://www.yonanewman.org/kizzur/kiz-index2.html\r\n\r\nBiblia Hebraica (Biblical Hebrew - Home): http://www.bible101.org/hebrew/home.html","is_text_editable":1,"can_edit_inline":1}
← Prev 1 14 15 16 17 18 21 Next →