@badgie/crm-cli 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (63) hide show
  1. package/AGENTS.md +91 -0
  2. package/README.md +136 -0
  3. package/dist/bin.js +149 -0
  4. package/dist/bin.js.map +1 -0
  5. package/dist/commands/admin.js +90 -0
  6. package/dist/commands/admin.js.map +1 -0
  7. package/dist/commands/clients.js +135 -0
  8. package/dist/commands/clients.js.map +1 -0
  9. package/dist/commands/directory.js +175 -0
  10. package/dist/commands/directory.js.map +1 -0
  11. package/dist/commands/docs.js +98 -0
  12. package/dist/commands/docs.js.map +1 -0
  13. package/dist/commands/finance.js +311 -0
  14. package/dist/commands/finance.js.map +1 -0
  15. package/dist/commands/intelligence.js +147 -0
  16. package/dist/commands/intelligence.js.map +1 -0
  17. package/dist/commands/leads-list.js +25 -0
  18. package/dist/commands/leads-list.js.map +1 -0
  19. package/dist/commands/leads.js +224 -0
  20. package/dist/commands/leads.js.map +1 -0
  21. package/dist/commands/login.js +11 -0
  22. package/dist/commands/login.js.map +1 -0
  23. package/dist/commands/logout.js +6 -0
  24. package/dist/commands/logout.js.map +1 -0
  25. package/dist/commands/marketing.js +135 -0
  26. package/dist/commands/marketing.js.map +1 -0
  27. package/dist/commands/operations.js +232 -0
  28. package/dist/commands/operations.js.map +1 -0
  29. package/dist/commands/outbound.js +172 -0
  30. package/dist/commands/outbound.js.map +1 -0
  31. package/dist/commands/query.js +189 -0
  32. package/dist/commands/query.js.map +1 -0
  33. package/dist/commands/search.js +71 -0
  34. package/dist/commands/search.js.map +1 -0
  35. package/dist/commands/tasks.js +239 -0
  36. package/dist/commands/tasks.js.map +1 -0
  37. package/dist/commands/top-clients.js +82 -0
  38. package/dist/commands/top-clients.js.map +1 -0
  39. package/dist/commands/webhooks.js +82 -0
  40. package/dist/commands/webhooks.js.map +1 -0
  41. package/dist/commands/welcome.js +81 -0
  42. package/dist/commands/welcome.js.map +1 -0
  43. package/dist/commands/whoami.js +16 -0
  44. package/dist/commands/whoami.js.map +1 -0
  45. package/dist/core/auth.js +107 -0
  46. package/dist/core/auth.js.map +1 -0
  47. package/dist/core/config.js +53 -0
  48. package/dist/core/config.js.map +1 -0
  49. package/dist/core/env.js +46 -0
  50. package/dist/core/env.js.map +1 -0
  51. package/dist/core/format.js +88 -0
  52. package/dist/core/format.js.map +1 -0
  53. package/dist/core/http.js +42 -0
  54. package/dist/core/http.js.map +1 -0
  55. package/dist/core/list-query.js +35 -0
  56. package/dist/core/list-query.js.map +1 -0
  57. package/dist/core/services/leads.js +41 -0
  58. package/dist/core/services/leads.js.map +1 -0
  59. package/dist/core/supabase.js +53 -0
  60. package/dist/core/supabase.js.map +1 -0
  61. package/dist/registry.js +2 -0
  62. package/dist/registry.js.map +1 -0
  63. package/package.json +57 -0
@@ -0,0 +1,232 @@
1
+ import { getAuthedClient } from '../core/supabase.js';
2
+ import { commonListOptions, output, parseColumns, parseLimit } from '../core/format.js';
3
+ import { callAppApi } from '../core/http.js';
4
+ // Mission control
5
+ async function mcMetrics(_a, opts) {
6
+ const res = await callAppApi('/api/mission-control/metrics');
7
+ output(res, { pretty: !!opts.pretty });
8
+ }
9
+ // Web design projects
10
+ async function listWebDesign(_a, opts) {
11
+ const { client } = await getAuthedClient();
12
+ let q = client
13
+ .from('web_design_projects')
14
+ .select('id, title, status, current_phase, budget, target_date, client_id, assigned_to, created_at')
15
+ .order('created_at', { ascending: false })
16
+ .limit(parseLimit(opts));
17
+ if (typeof opts.status === 'string')
18
+ q = q.eq('status', opts.status);
19
+ if (typeof opts.clientId === 'string')
20
+ q = q.eq('client_id', opts.clientId);
21
+ if (typeof opts.assignedTo === 'string')
22
+ q = q.eq('assigned_to', opts.assignedTo);
23
+ if (typeof opts.phase === 'string')
24
+ q = q.eq('current_phase', opts.phase);
25
+ if (typeof opts.targetBefore === 'string')
26
+ q = q.lte('target_date', opts.targetBefore);
27
+ if (typeof opts.targetAfter === 'string')
28
+ q = q.gte('target_date', opts.targetAfter);
29
+ if (typeof opts.search === 'string')
30
+ q = q.ilike('title', `%${opts.search}%`);
31
+ const { data, error } = await q;
32
+ if (error)
33
+ throw error;
34
+ output(data ?? [], { pretty: !!opts.pretty, columns: parseColumns(opts) });
35
+ }
36
+ // Team
37
+ async function listTeam(_a, opts) {
38
+ const { client } = await getAuthedClient();
39
+ let q = client
40
+ .from('team_members')
41
+ .select('id, full_name, email, role, is_active, last_login_at, created_at')
42
+ .order('full_name', { ascending: true })
43
+ .limit(parseLimit(opts));
44
+ if (opts.activeOnly !== undefined)
45
+ q = q.eq('is_active', true);
46
+ const { data, error } = await q;
47
+ if (error)
48
+ throw error;
49
+ output(data ?? [], { pretty: !!opts.pretty, columns: parseColumns(opts) });
50
+ }
51
+ // Sports
52
+ async function listSports(_a, opts) {
53
+ const { client } = await getAuthedClient();
54
+ const { data, error } = await client
55
+ .from('sports')
56
+ .select('id, name, icon, is_active')
57
+ .order('name', { ascending: true });
58
+ if (error)
59
+ throw error;
60
+ output(data ?? [], { pretty: !!opts.pretty, columns: parseColumns(opts) });
61
+ }
62
+ // Activities
63
+ async function listActivities(_a, opts) {
64
+ const { client } = await getAuthedClient();
65
+ let q = client
66
+ .from('activities')
67
+ .select('id, type, title, description, lead_id, client_id, task_id, created_by, created_at')
68
+ .order('created_at', { ascending: false })
69
+ .limit(parseLimit(opts));
70
+ if (typeof opts.type === 'string')
71
+ q = q.eq('type', opts.type);
72
+ if (typeof opts.leadId === 'string')
73
+ q = q.eq('lead_id', opts.leadId);
74
+ if (typeof opts.clientId === 'string')
75
+ q = q.eq('client_id', opts.clientId);
76
+ if (typeof opts.taskId === 'string')
77
+ q = q.eq('task_id', opts.taskId);
78
+ if (typeof opts.createdBy === 'string')
79
+ q = q.eq('created_by', opts.createdBy);
80
+ if (typeof opts.since === 'string')
81
+ q = q.gte('created_at', opts.since);
82
+ if (typeof opts.until === 'string')
83
+ q = q.lte('created_at', opts.until);
84
+ if (typeof opts.search === 'string')
85
+ q = q.or(`title.ilike.%${opts.search}%,description.ilike.%${opts.search}%`);
86
+ const { data, error } = await q;
87
+ if (error)
88
+ throw error;
89
+ output(data ?? [], { pretty: !!opts.pretty, columns: parseColumns(opts) });
90
+ }
91
+ // Demo schedules
92
+ async function listDemos(_a, opts) {
93
+ const { client } = await getAuthedClient();
94
+ let q = client
95
+ .from('demo_schedules')
96
+ .select('id, lead_id, assigned_to, scheduled_date, scheduled_time, meeting_url, email_sent, created_at')
97
+ .order('scheduled_date', { ascending: false })
98
+ .limit(parseLimit(opts));
99
+ if (typeof opts.leadId === 'string')
100
+ q = q.eq('lead_id', opts.leadId);
101
+ if (typeof opts.assignedTo === 'string')
102
+ q = q.eq('assigned_to', opts.assignedTo);
103
+ if (typeof opts.since === 'string')
104
+ q = q.gte('scheduled_date', opts.since);
105
+ if (typeof opts.until === 'string')
106
+ q = q.lte('scheduled_date', opts.until);
107
+ if (typeof opts.emailSent === 'string')
108
+ q = q.eq('email_sent', opts.emailSent === 'true');
109
+ const { data, error } = await q;
110
+ if (error)
111
+ throw error;
112
+ output(data ?? [], { pretty: !!opts.pretty, columns: parseColumns(opts) });
113
+ }
114
+ // Onboarding
115
+ async function listOnboarding(_a, opts) {
116
+ const { client } = await getAuthedClient();
117
+ let q = client
118
+ .from('client_boardings')
119
+ .select('*')
120
+ .order('created_at', { ascending: false })
121
+ .limit(parseLimit(opts));
122
+ if (typeof opts.clientId === 'string')
123
+ q = q.eq('client_id', opts.clientId);
124
+ if (typeof opts.since === 'string')
125
+ q = q.gte('created_at', opts.since);
126
+ if (typeof opts.until === 'string')
127
+ q = q.lte('created_at', opts.until);
128
+ const { data, error } = await q;
129
+ if (error) {
130
+ // Fallback to onboarding_scores if client_boardings doesnt exist
131
+ const res2 = await client
132
+ .from('onboarding_scores')
133
+ .select('*')
134
+ .order('created_at', { ascending: false })
135
+ .limit(parseLimit(opts));
136
+ if (res2.error)
137
+ throw res2.error;
138
+ output(res2.data ?? [], { pretty: !!opts.pretty, columns: parseColumns(opts) });
139
+ return;
140
+ }
141
+ output(data ?? [], { pretty: !!opts.pretty, columns: parseColumns(opts) });
142
+ }
143
+ export const operationsModule = {
144
+ name: 'operations',
145
+ summary: 'Mission control, top clients, web design, team, sports, activities, demos, onboarding',
146
+ specs: [
147
+ {
148
+ path: ['mission-control', 'metrics'],
149
+ summary: 'Fetch mission-control metrics (calls the Next app)',
150
+ tags: ['read', 'http'],
151
+ options: [{ flag: '--pretty', description: 'human output' }],
152
+ handler: mcMetrics,
153
+ },
154
+ {
155
+ path: ['web-design', 'list'],
156
+ summary: 'List web-design projects',
157
+ tags: ['read'],
158
+ options: [
159
+ { flag: '--status <s>', description: 'project status' },
160
+ { flag: '--client-id <uuid>', description: 'filter by client' },
161
+ { flag: '--assigned-to <uuid>', description: 'filter by assignee' },
162
+ { flag: '--phase <p>', description: 'filter by current_phase' },
163
+ { flag: '--target-before <date>', description: 'target_date <= YYYY-MM-DD' },
164
+ { flag: '--target-after <date>', description: 'target_date >= YYYY-MM-DD' },
165
+ { flag: '--search <text>', description: 'ilike on title' },
166
+ ...commonListOptions(),
167
+ ],
168
+ handler: listWebDesign,
169
+ },
170
+ {
171
+ path: ['team', 'list'],
172
+ summary: 'List team members',
173
+ tags: ['read'],
174
+ options: [
175
+ { flag: '--active-only', description: 'is_active=true only' },
176
+ ...commonListOptions(),
177
+ ],
178
+ handler: listTeam,
179
+ },
180
+ {
181
+ path: ['sports', 'list'],
182
+ summary: 'List sports',
183
+ tags: ['read'],
184
+ options: [{ flag: '--pretty', description: 'human output' }],
185
+ handler: listSports,
186
+ },
187
+ {
188
+ path: ['activities', 'list'],
189
+ summary: 'List activities (timeline entries)',
190
+ tags: ['read'],
191
+ options: [
192
+ { flag: '--type <t>', description: 'activity type' },
193
+ { flag: '--lead-id <uuid>', description: 'filter by lead' },
194
+ { flag: '--client-id <uuid>', description: 'filter by client' },
195
+ { flag: '--task-id <uuid>', description: 'filter by task' },
196
+ { flag: '--created-by <uuid>', description: 'filter by author (team_members.id)' },
197
+ { flag: '--since <date>', description: 'created_at >= YYYY-MM-DD' },
198
+ { flag: '--until <date>', description: 'created_at <= YYYY-MM-DD' },
199
+ { flag: '--search <text>', description: 'ilike on title or description' },
200
+ ...commonListOptions(),
201
+ ],
202
+ handler: listActivities,
203
+ },
204
+ {
205
+ path: ['demos', 'list'],
206
+ summary: 'List demo_schedules',
207
+ tags: ['read'],
208
+ options: [
209
+ { flag: '--lead-id <uuid>', description: 'filter by lead' },
210
+ { flag: '--assigned-to <uuid>', description: 'filter by assignee' },
211
+ { flag: '--since <date>', description: 'scheduled_date >= YYYY-MM-DD' },
212
+ { flag: '--until <date>', description: 'scheduled_date <= YYYY-MM-DD' },
213
+ { flag: '--email-sent <bool>', description: 'true|false' },
214
+ ...commonListOptions(),
215
+ ],
216
+ handler: listDemos,
217
+ },
218
+ {
219
+ path: ['onboarding', 'list'],
220
+ summary: 'List client_boardings (onboarding tracker)',
221
+ tags: ['read'],
222
+ options: [
223
+ { flag: '--client-id <uuid>', description: 'filter by client' },
224
+ { flag: '--since <date>', description: 'created_at >= YYYY-MM-DD' },
225
+ { flag: '--until <date>', description: 'created_at <= YYYY-MM-DD' },
226
+ ...commonListOptions(),
227
+ ],
228
+ handler: listOnboarding,
229
+ },
230
+ ],
231
+ };
232
+ //# sourceMappingURL=operations.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"operations.js","sourceRoot":"","sources":["../../src/commands/operations.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,172 @@
1
+ import { getAuthedClient } from '../core/supabase.js';
2
+ import { commonListOptions, output, parseColumns, parseLimit } from '../core/format.js';
3
+ async function listProspects(_a, opts) {
4
+ const { client } = await getAuthedClient();
5
+ let q = client
6
+ .from('outbound_prospects')
7
+ .select('id, name, sport_type, city, phone, lead_score, outbound_status, assigned_to, campaign_id, created_at')
8
+ .order('created_at', { ascending: false })
9
+ .limit(parseLimit(opts));
10
+ if (typeof opts.status === 'string')
11
+ q = q.eq('outbound_status', opts.status);
12
+ if (typeof opts.campaignId === 'string')
13
+ q = q.eq('campaign_id', opts.campaignId);
14
+ if (typeof opts.assignedTo === 'string')
15
+ q = q.eq('assigned_to', opts.assignedTo);
16
+ if (typeof opts.sport === 'string')
17
+ q = q.ilike('sport_type', `%${opts.sport}%`);
18
+ if (typeof opts.city === 'string')
19
+ q = q.ilike('city', `%${opts.city}%`);
20
+ if (typeof opts.search === 'string')
21
+ q = q.ilike('name', `%${opts.search}%`);
22
+ const { data, error } = await q;
23
+ if (error)
24
+ throw error;
25
+ output(data ?? [], { pretty: !!opts.pretty, columns: parseColumns(opts) });
26
+ }
27
+ async function setProspectStatus(args, opts) {
28
+ const { client } = await getAuthedClient();
29
+ const { data, error } = await client
30
+ .from('outbound_prospects')
31
+ .update({ outbound_status: args.status })
32
+ .eq('id', args.id)
33
+ .select('id, outbound_status')
34
+ .single();
35
+ if (error)
36
+ throw error;
37
+ output(data, { pretty: !!opts.pretty });
38
+ }
39
+ async function assignProspect(args, opts) {
40
+ const { client } = await getAuthedClient();
41
+ const { data, error } = await client
42
+ .from('outbound_prospects')
43
+ .update({ assigned_to: args.memberId })
44
+ .eq('id', args.id)
45
+ .select('id, assigned_to')
46
+ .single();
47
+ if (error)
48
+ throw error;
49
+ output(data, { pretty: !!opts.pretty });
50
+ }
51
+ async function listCampaigns(_a, opts) {
52
+ const { client } = await getAuthedClient();
53
+ let q = client
54
+ .from('outbound_campaigns')
55
+ .select('id, name, status, sport_filter, region_filter, created_by, created_at')
56
+ .order('created_at', { ascending: false })
57
+ .limit(parseLimit(opts));
58
+ if (typeof opts.status === 'string')
59
+ q = q.eq('status', opts.status);
60
+ const { data, error } = await q;
61
+ if (error)
62
+ throw error;
63
+ output(data ?? [], { pretty: !!opts.pretty, columns: parseColumns(opts) });
64
+ }
65
+ async function listInteractions(_a, opts) {
66
+ const { client } = await getAuthedClient();
67
+ let q = client
68
+ .from('outbound_interactions')
69
+ .select('id, type, prospect_id, created_by, notes, created_at')
70
+ .order('created_at', { ascending: false })
71
+ .limit(parseLimit(opts));
72
+ if (typeof opts.prospectId === 'string')
73
+ q = q.eq('prospect_id', opts.prospectId);
74
+ if (typeof opts.type === 'string')
75
+ q = q.eq('type', opts.type);
76
+ const { data, error } = await q;
77
+ if (error)
78
+ throw error;
79
+ output(data ?? [], { pretty: !!opts.pretty, columns: parseColumns(opts) });
80
+ }
81
+ async function logInteraction(_a, opts) {
82
+ const { client } = await getAuthedClient();
83
+ const { data, error } = await client
84
+ .from('outbound_interactions')
85
+ .insert({
86
+ prospect_id: opts.prospectId,
87
+ type: opts.type ?? 'note',
88
+ notes: opts.notes ?? null,
89
+ })
90
+ .select('*')
91
+ .single();
92
+ if (error)
93
+ throw error;
94
+ output(data, { pretty: !!opts.pretty });
95
+ }
96
+ export const outboundModule = {
97
+ name: 'outbound',
98
+ summary: 'Outbound prospecting — prospects, campaigns, interactions',
99
+ specs: [
100
+ {
101
+ path: ['outbound', 'prospects', 'list'],
102
+ summary: 'List outbound prospects',
103
+ tags: ['read'],
104
+ options: [
105
+ { flag: '--status <s>', description: 'outbound_status filter' },
106
+ { flag: '--campaign-id <uuid>', description: 'filter by campaign' },
107
+ { flag: '--assigned-to <uuid>', description: 'filter by assignee' },
108
+ { flag: '--sport <s>', description: 'ilike sport_type' },
109
+ { flag: '--city <c>', description: 'ilike city' },
110
+ { flag: '--search <text>', description: 'ilike name' },
111
+ ...commonListOptions(),
112
+ ],
113
+ handler: listProspects,
114
+ },
115
+ {
116
+ path: ['outbound', 'prospects', 'set-status'],
117
+ summary: 'Change prospect outbound_status',
118
+ tags: ['write'],
119
+ args: [
120
+ { name: 'id', required: true, description: 'prospect uuid' },
121
+ { name: 'status', required: true, description: 'new outbound_status' },
122
+ ],
123
+ options: [{ flag: '--pretty', description: 'human output' }],
124
+ handler: setProspectStatus,
125
+ },
126
+ {
127
+ path: ['outbound', 'prospects', 'assign'],
128
+ summary: 'Assign prospect to a team member',
129
+ tags: ['write'],
130
+ args: [
131
+ { name: 'id', required: true, description: 'prospect uuid' },
132
+ { name: 'memberId', required: true, description: 'team_members.id' },
133
+ ],
134
+ options: [{ flag: '--pretty', description: 'human output' }],
135
+ handler: assignProspect,
136
+ },
137
+ {
138
+ path: ['outbound', 'campaigns', 'list'],
139
+ summary: 'List outbound campaigns',
140
+ tags: ['read'],
141
+ options: [
142
+ { flag: '--status <s>', description: 'campaign status' },
143
+ ...commonListOptions(),
144
+ ],
145
+ handler: listCampaigns,
146
+ },
147
+ {
148
+ path: ['outbound', 'interactions', 'list'],
149
+ summary: 'List outbound interactions',
150
+ tags: ['read'],
151
+ options: [
152
+ { flag: '--prospect-id <uuid>', description: 'filter by prospect' },
153
+ { flag: '--type <t>', description: 'interaction type' },
154
+ ...commonListOptions(),
155
+ ],
156
+ handler: listInteractions,
157
+ },
158
+ {
159
+ path: ['outbound', 'interactions', 'log'],
160
+ summary: 'Log an outbound interaction',
161
+ tags: ['write'],
162
+ options: [
163
+ { flag: '--prospect-id <uuid>', description: 'prospect uuid (required)' },
164
+ { flag: '--type <t>', description: 'note|call|email|whatsapp|…' },
165
+ { flag: '--notes <text>', description: 'free-text notes' },
166
+ { flag: '--pretty', description: 'human output' },
167
+ ],
168
+ handler: logInteraction,
169
+ },
170
+ ],
171
+ };
172
+ //# sourceMappingURL=outbound.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"outbound.js","sourceRoot":"","sources":["../../src/commands/outbound.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,189 @@
1
+ import { getAuthedClient } from '../core/supabase.js';
2
+ import { commonListOptions, output, parseColumns, parseLimit } from '../core/format.js';
3
+ /**
4
+ * Parse a --where expression like:
5
+ * category=salarios -> eq
6
+ * invoice_date:gte:2026-03-01 -> gte
7
+ * description:ilike:gym -> ilike (% wrapped automatically)
8
+ * status:in:paid,pending -> in
9
+ * paid_date:is:null -> is null
10
+ */
11
+ function parseWhere(expr) {
12
+ // explicit op form: column:op:value
13
+ const withOp = /^([^:=]+):(eq|neq|gt|gte|lt|lte|like|ilike|in|is|not):(.+)$/.exec(expr);
14
+ if (withOp) {
15
+ return { column: withOp[1], op: withOp[2], value: withOp[3] };
16
+ }
17
+ // shorthand: column=value (eq)
18
+ const eqForm = /^([^=]+)=(.*)$/.exec(expr);
19
+ if (eqForm)
20
+ return { column: eqForm[1], op: 'eq', value: eqForm[2] };
21
+ throw new Error(`Invalid --where "${expr}". Use column=value or column:op:value (op ∈ eq,neq,gt,gte,lt,lte,like,ilike,in,is,not)`);
22
+ }
23
+ function applyClause(q, c) {
24
+ const v = c.value;
25
+ switch (c.op) {
26
+ case 'eq':
27
+ return q.eq(c.column, coerce(v));
28
+ case 'neq':
29
+ return q.neq(c.column, coerce(v));
30
+ case 'gt':
31
+ return q.gt(c.column, coerce(v));
32
+ case 'gte':
33
+ return q.gte(c.column, coerce(v));
34
+ case 'lt':
35
+ return q.lt(c.column, coerce(v));
36
+ case 'lte':
37
+ return q.lte(c.column, coerce(v));
38
+ case 'like':
39
+ return q.like(c.column, v.includes('%') ? v : `%${v}%`);
40
+ case 'ilike':
41
+ return q.ilike(c.column, v.includes('%') ? v : `%${v}%`);
42
+ case 'in':
43
+ return q.in(c.column, v.split(',').map((s) => coerce(s.trim())));
44
+ case 'is': {
45
+ if (v === 'null')
46
+ return q.is(c.column, null);
47
+ if (v === 'true' || v === 'false')
48
+ return q.is(c.column, v === 'true');
49
+ throw new Error(`is supports null|true|false, got "${v}"`);
50
+ }
51
+ case 'not':
52
+ // column:not:null → not(column,is,null). Limited helper.
53
+ if (v === 'null')
54
+ return q.not(c.column, 'is', null);
55
+ return q.not(c.column, 'eq', coerce(v));
56
+ }
57
+ }
58
+ function coerce(v) {
59
+ if (v === 'null')
60
+ return null;
61
+ if (v === 'true')
62
+ return true;
63
+ if (v === 'false')
64
+ return false;
65
+ if (/^-?\d+(\.\d+)?$/.test(v))
66
+ return Number(v);
67
+ return v;
68
+ }
69
+ async function queryHandler(args, opts) {
70
+ const table = args.table;
71
+ if (!table)
72
+ throw new Error('table is required');
73
+ const { client } = await getAuthedClient();
74
+ const select = opts.select ?? '*';
75
+ const limit = parseLimit(opts, 50);
76
+ let q = client.from(table).select(select).limit(limit);
77
+ const wheres = asArray(opts.where);
78
+ for (const w of wheres)
79
+ q = applyClause(q, parseWhere(w));
80
+ if (typeof opts.order === 'string') {
81
+ const [col, dir] = opts.order.split(':');
82
+ q = q.order(col, { ascending: (dir ?? 'desc') === 'asc' });
83
+ }
84
+ else {
85
+ q = q.order('created_at', { ascending: false });
86
+ }
87
+ if (typeof opts.offset === 'string') {
88
+ const off = parseInt(opts.offset, 10);
89
+ q = q.range(off, off + limit - 1);
90
+ }
91
+ const { data, error } = await q;
92
+ if (error)
93
+ throw error;
94
+ output(data ?? [], { pretty: !!opts.pretty, columns: parseColumns(opts) });
95
+ }
96
+ async function countHandler(args, opts) {
97
+ const table = args.table;
98
+ if (!table)
99
+ throw new Error('table is required');
100
+ const { client } = await getAuthedClient();
101
+ let q = client.from(table).select('*', { count: 'exact', head: true });
102
+ const wheres = asArray(opts.where);
103
+ for (const w of wheres)
104
+ q = applyClause(q, parseWhere(w));
105
+ const { count, error } = await q;
106
+ if (error)
107
+ throw error;
108
+ output({ table, count: count ?? 0, where: wheres }, { pretty: !!opts.pretty });
109
+ }
110
+ async function describeHandler(args, opts) {
111
+ const table = args.table;
112
+ if (!table)
113
+ throw new Error('table is required');
114
+ const { client } = await getAuthedClient();
115
+ // Grab one row to infer columns
116
+ const { data, error } = await client.from(table).select('*').limit(1);
117
+ if (error)
118
+ throw error;
119
+ const row = data?.[0] ?? {};
120
+ const columns = Object.entries(row).map(([name, value]) => ({
121
+ name,
122
+ type: value === null ? 'unknown (null in sample)' : Array.isArray(value) ? 'array' : typeof value,
123
+ sample: value,
124
+ }));
125
+ output({ table, columns }, { pretty: !!opts.pretty });
126
+ }
127
+ function asArray(v) {
128
+ if (Array.isArray(v))
129
+ return v;
130
+ if (typeof v === 'string')
131
+ return [v];
132
+ return [];
133
+ }
134
+ export const queryModule = {
135
+ name: 'query',
136
+ summary: 'Generic queries against any Supabase table (filter any column)',
137
+ specs: [
138
+ {
139
+ path: ['query'],
140
+ summary: 'Filter any column of any table with --where expressions',
141
+ description: 'Escape hatch for ad-hoc queries. Every --where flag can be repeated.\n\n' +
142
+ 'Shorthand: column=value (eq)\n' +
143
+ 'Explicit: column:op:value (op ∈ eq,neq,gt,gte,lt,lte,like,ilike,in,is,not)\n\n' +
144
+ 'Examples of value handling: "null" → NULL, "true"/"false" → bool, numbers → number, comma-list for `in`.',
145
+ tags: ['read'],
146
+ args: [
147
+ { name: 'table', required: true, description: 'Supabase table name (e.g. invoices, leads, bank_movements)' },
148
+ ],
149
+ options: [
150
+ { flag: '--where <expr>', description: 'filter expression, repeatable. e.g. "category=salarios"', collect: true },
151
+ { flag: '--select <cols>', description: 'Supabase select string (default *)' },
152
+ { flag: '--order <col:dir>', description: 'e.g. invoice_date:desc (default created_at:desc)' },
153
+ { flag: '--offset <n>', description: 'pagination offset' },
154
+ ...commonListOptions(),
155
+ ],
156
+ examples: [
157
+ 'badgie-crm query invoices --where "category=salarios" --where "invoice_date:gte:2026-03-01" --where "invoice_date:lte:2026-03-31" --pretty',
158
+ 'badgie-crm query bank_movements --where "amount:gte:1000" --where "description:ilike:gym" --limit 20',
159
+ 'badgie-crm query leads --where "status_id:in:uuid1,uuid2" --pretty',
160
+ 'badgie-crm query clients --where "sport=Padel" --where "city:ilike:madrid" --pretty',
161
+ ],
162
+ handler: queryHandler,
163
+ },
164
+ {
165
+ path: ['query', 'count'],
166
+ summary: 'Count rows matching filters (no data returned)',
167
+ tags: ['read'],
168
+ args: [{ name: 'table', required: true, description: 'table name' }],
169
+ options: [
170
+ { flag: '--where <expr>', description: 'filter expression, repeatable', collect: true },
171
+ { flag: '--pretty', description: 'human output' },
172
+ ],
173
+ examples: [
174
+ 'badgie-crm query count invoices --where "category=salarios" --where "invoice_date:gte:2026-03-01"',
175
+ ],
176
+ handler: countHandler,
177
+ },
178
+ {
179
+ path: ['query', 'describe'],
180
+ summary: 'Show columns (inferred from a sample row) for a table',
181
+ tags: ['read'],
182
+ args: [{ name: 'table', required: true, description: 'table name' }],
183
+ options: [{ flag: '--pretty', description: 'human output' }],
184
+ examples: ['badgie-crm query describe invoices --pretty'],
185
+ handler: describeHandler,
186
+ },
187
+ ],
188
+ };
189
+ //# sourceMappingURL=query.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"query.js","sourceRoot":"","sources":["../../src/commands/query.ts"],"names":[],"mappings":"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"}