@deepintel-ltd/farmpro-contracts 1.5.8 → 1.5.9
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.
- package/dist/index.js +50 -92
- package/dist/routes/admin.routes.js +13 -16
- package/dist/routes/agent-workflows.routes.js +81 -84
- package/dist/routes/agents.routes.js +29 -32
- package/dist/routes/analytics.routes.js +11 -14
- package/dist/routes/auth.routes.js +55 -58
- package/dist/routes/categories.routes.js +23 -26
- package/dist/routes/documents.routes.js +67 -70
- package/dist/routes/equipment.routes.js +55 -58
- package/dist/routes/farms.routes.js +32 -35
- package/dist/routes/field-monitoring.routes.js +70 -73
- package/dist/routes/field-observations.routes.js +41 -44
- package/dist/routes/fields.routes.js +44 -47
- package/dist/routes/finance.routes.js +121 -124
- package/dist/routes/harvest.routes.js +46 -49
- package/dist/routes/health.routes.js +6 -9
- package/dist/routes/index.js +51 -54
- package/dist/routes/input-usage.routes.js +14 -17
- package/dist/routes/inventory.routes.js +57 -60
- package/dist/routes/seasonal-plans.routes.js +14 -17
- package/dist/routes/soil-tests.routes.js +45 -48
- package/dist/routes/suppliers.routes.js +70 -73
- package/dist/routes/tasks.routes.js +65 -68
- package/dist/routes/team.routes.js +57 -60
- package/dist/routes/users.routes.js +13 -16
- package/dist/routes/weather.routes.js +10 -13
- package/dist/schemas/admin.schemas.js +43 -46
- package/dist/schemas/agent-workflows.schemas.js +34 -37
- package/dist/schemas/agents.schemas.js +46 -49
- package/dist/schemas/analytics.schemas.js +51 -54
- package/dist/schemas/auth.schemas.js +96 -99
- package/dist/schemas/categories.schemas.js +27 -30
- package/dist/schemas/common.schemas.js +89 -95
- package/dist/schemas/documents.schemas.js +59 -62
- package/dist/schemas/equipment.schemas.js +86 -89
- package/dist/schemas/farms.schemas.js +40 -43
- package/dist/schemas/field-monitoring.schemas.js +207 -210
- package/dist/schemas/field-observations.schemas.js +93 -96
- package/dist/schemas/fields.schemas.js +82 -85
- package/dist/schemas/finance.schemas.js +134 -137
- package/dist/schemas/harvest.schemas.js +46 -49
- package/dist/schemas/health.schemas.js +14 -17
- package/dist/schemas/input-usage.schemas.js +21 -24
- package/dist/schemas/inventory.schemas.js +58 -61
- package/dist/schemas/recommendations.schemas.js +22 -25
- package/dist/schemas/seasonal-plans.schemas.js +21 -24
- package/dist/schemas/soil-tests.schemas.js +70 -73
- package/dist/schemas/suppliers.schemas.js +90 -93
- package/dist/schemas/tasks.schemas.js +93 -96
- package/dist/schemas/team.schemas.js +35 -38
- package/dist/schemas/users.schemas.js +19 -22
- package/dist/schemas/weather.schemas.js +32 -35
- package/package.json +9 -1
|
@@ -1,25 +1,22 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
const
|
|
5
|
-
const
|
|
6
|
-
const field_observations_schemas_1 = require("../schemas/field-observations.schemas");
|
|
7
|
-
const c = (0, core_1.initContract)();
|
|
8
|
-
exports.fieldObservationsRouter = c.router({
|
|
1
|
+
import { initContract } from '@ts-rest/core';
|
|
2
|
+
import { z } from 'zod';
|
|
3
|
+
import { uploadObservationBodySchema, observationResponseSchema, observationListResponseSchema, observationListQuerySchema, updateObservationActionInputSchema, observationStatsQuerySchema, } from '../schemas/field-observations.schemas';
|
|
4
|
+
const c = initContract();
|
|
5
|
+
export const fieldObservationsRouter = c.router({
|
|
9
6
|
// Upload new observation photo (farm-level)
|
|
10
7
|
createFarmObservation: {
|
|
11
8
|
method: 'POST',
|
|
12
9
|
path: '/farms/:farmId/observations',
|
|
13
10
|
contentType: 'multipart/form-data',
|
|
14
|
-
body:
|
|
11
|
+
body: uploadObservationBodySchema,
|
|
15
12
|
responses: {
|
|
16
|
-
202:
|
|
17
|
-
message:
|
|
18
|
-
observationId:
|
|
19
|
-
status:
|
|
13
|
+
202: z.object({
|
|
14
|
+
message: z.string(),
|
|
15
|
+
observationId: z.string().uuid(),
|
|
16
|
+
status: z.literal('accepted'),
|
|
20
17
|
}),
|
|
21
|
-
400:
|
|
22
|
-
404:
|
|
18
|
+
400: z.object({ message: z.string(), code: z.string() }),
|
|
19
|
+
404: z.object({ message: z.string(), code: z.string() }),
|
|
23
20
|
},
|
|
24
21
|
summary: 'Upload farm observation photo for AI analysis',
|
|
25
22
|
},
|
|
@@ -28,15 +25,15 @@ exports.fieldObservationsRouter = c.router({
|
|
|
28
25
|
method: 'POST',
|
|
29
26
|
path: '/fields/:fieldId/observations',
|
|
30
27
|
contentType: 'multipart/form-data',
|
|
31
|
-
body:
|
|
28
|
+
body: uploadObservationBodySchema,
|
|
32
29
|
responses: {
|
|
33
|
-
202:
|
|
34
|
-
message:
|
|
35
|
-
observationId:
|
|
36
|
-
status:
|
|
30
|
+
202: z.object({
|
|
31
|
+
message: z.string(),
|
|
32
|
+
observationId: z.string().uuid(),
|
|
33
|
+
status: z.literal('accepted'),
|
|
37
34
|
}),
|
|
38
|
-
400:
|
|
39
|
-
404:
|
|
35
|
+
400: z.object({ message: z.string(), code: z.string() }),
|
|
36
|
+
404: z.object({ message: z.string(), code: z.string() }),
|
|
40
37
|
},
|
|
41
38
|
summary: 'Upload field observation photo for AI analysis',
|
|
42
39
|
},
|
|
@@ -45,8 +42,8 @@ exports.fieldObservationsRouter = c.router({
|
|
|
45
42
|
method: 'GET',
|
|
46
43
|
path: '/observations/:id',
|
|
47
44
|
responses: {
|
|
48
|
-
200:
|
|
49
|
-
404:
|
|
45
|
+
200: observationResponseSchema,
|
|
46
|
+
404: z.object({ message: z.string(), code: z.string() }),
|
|
50
47
|
},
|
|
51
48
|
summary: 'Get observation details and analysis results',
|
|
52
49
|
},
|
|
@@ -54,10 +51,10 @@ exports.fieldObservationsRouter = c.router({
|
|
|
54
51
|
listFieldObservations: {
|
|
55
52
|
method: 'GET',
|
|
56
53
|
path: '/fields/:fieldId/observations',
|
|
57
|
-
query:
|
|
54
|
+
query: observationListQuerySchema,
|
|
58
55
|
responses: {
|
|
59
|
-
200:
|
|
60
|
-
404:
|
|
56
|
+
200: observationListResponseSchema,
|
|
57
|
+
404: z.object({ message: z.string(), code: z.string() }),
|
|
61
58
|
},
|
|
62
59
|
summary: 'List all observations for a field',
|
|
63
60
|
},
|
|
@@ -65,9 +62,9 @@ exports.fieldObservationsRouter = c.router({
|
|
|
65
62
|
listFarmObservations: {
|
|
66
63
|
method: 'GET',
|
|
67
64
|
path: '/farms/:farmId/observations',
|
|
68
|
-
query:
|
|
65
|
+
query: observationListQuerySchema,
|
|
69
66
|
responses: {
|
|
70
|
-
200:
|
|
67
|
+
200: observationListResponseSchema,
|
|
71
68
|
},
|
|
72
69
|
summary: 'List all observations across all farm fields',
|
|
73
70
|
},
|
|
@@ -75,10 +72,10 @@ exports.fieldObservationsRouter = c.router({
|
|
|
75
72
|
updateObservationAction: {
|
|
76
73
|
method: 'PATCH',
|
|
77
74
|
path: '/observations/:id/action',
|
|
78
|
-
body:
|
|
75
|
+
body: updateObservationActionInputSchema,
|
|
79
76
|
responses: {
|
|
80
|
-
200:
|
|
81
|
-
404:
|
|
77
|
+
200: observationResponseSchema,
|
|
78
|
+
404: z.object({ message: z.string(), code: z.string() }),
|
|
82
79
|
},
|
|
83
80
|
summary: 'Update action status for observation',
|
|
84
81
|
},
|
|
@@ -87,8 +84,8 @@ exports.fieldObservationsRouter = c.router({
|
|
|
87
84
|
method: 'DELETE',
|
|
88
85
|
path: '/observations/:id',
|
|
89
86
|
responses: {
|
|
90
|
-
204:
|
|
91
|
-
404:
|
|
87
|
+
204: z.void(),
|
|
88
|
+
404: z.object({ message: z.string(), code: z.string() }),
|
|
92
89
|
},
|
|
93
90
|
summary: 'Delete observation and associated photo',
|
|
94
91
|
},
|
|
@@ -96,17 +93,17 @@ exports.fieldObservationsRouter = c.router({
|
|
|
96
93
|
getObservationStats: {
|
|
97
94
|
method: 'GET',
|
|
98
95
|
path: '/fields/:fieldId/observations/stats',
|
|
99
|
-
query:
|
|
96
|
+
query: observationStatsQuerySchema,
|
|
100
97
|
responses: {
|
|
101
|
-
200:
|
|
102
|
-
total:
|
|
103
|
-
byType:
|
|
104
|
-
bySeverity:
|
|
105
|
-
avgConfidence:
|
|
106
|
-
mostCommonIssues:
|
|
107
|
-
name:
|
|
108
|
-
count:
|
|
109
|
-
avgSeverity:
|
|
98
|
+
200: z.object({
|
|
99
|
+
total: z.number(),
|
|
100
|
+
byType: z.record(z.number()),
|
|
101
|
+
bySeverity: z.record(z.number()),
|
|
102
|
+
avgConfidence: z.number(),
|
|
103
|
+
mostCommonIssues: z.array(z.object({
|
|
104
|
+
name: z.string(),
|
|
105
|
+
count: z.number(),
|
|
106
|
+
avgSeverity: z.string(),
|
|
110
107
|
})),
|
|
111
108
|
}),
|
|
112
109
|
},
|
|
@@ -1,26 +1,23 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
const
|
|
6
|
-
const
|
|
7
|
-
const common_schemas_1 = require("../schemas/common.schemas");
|
|
8
|
-
const c = (0, core_1.initContract)();
|
|
9
|
-
exports.fieldsRouter = c.router({
|
|
1
|
+
import { initContract } from '@ts-rest/core';
|
|
2
|
+
import { z } from 'zod';
|
|
3
|
+
import { createFieldSchema, updateFieldSchema, fieldResponseSchema, fieldDetailResponseSchema, fieldListResponseSchema, } from '../schemas/fields.schemas';
|
|
4
|
+
import { jsonApiErrorResponseSchema, jsonApiSuccessResponseSchema, jsonApiPaginationQuerySchema, jsonApiSortQuerySchema, jsonApiIncludeQuerySchema, jsonApiFilterQuerySchema } from '../schemas/common.schemas';
|
|
5
|
+
const c = initContract();
|
|
6
|
+
export const fieldsRouter = c.router({
|
|
10
7
|
// List fields for a farm
|
|
11
8
|
listFields: {
|
|
12
9
|
method: 'GET',
|
|
13
10
|
path: '/farms/:farmId/fields',
|
|
14
|
-
pathParams:
|
|
15
|
-
query:
|
|
16
|
-
.merge(
|
|
17
|
-
.merge(
|
|
18
|
-
.merge(
|
|
11
|
+
pathParams: z.object({ farmId: z.string().uuid() }),
|
|
12
|
+
query: jsonApiPaginationQuerySchema
|
|
13
|
+
.merge(jsonApiSortQuerySchema)
|
|
14
|
+
.merge(jsonApiIncludeQuerySchema)
|
|
15
|
+
.merge(jsonApiFilterQuerySchema),
|
|
19
16
|
responses: {
|
|
20
|
-
200:
|
|
21
|
-
400:
|
|
22
|
-
404:
|
|
23
|
-
401:
|
|
17
|
+
200: fieldListResponseSchema,
|
|
18
|
+
400: jsonApiErrorResponseSchema,
|
|
19
|
+
404: jsonApiErrorResponseSchema,
|
|
20
|
+
401: jsonApiErrorResponseSchema,
|
|
24
21
|
},
|
|
25
22
|
summary: 'List fields for a farm',
|
|
26
23
|
description: 'Get all fields for a specific farm with optional filtering',
|
|
@@ -29,14 +26,14 @@ exports.fieldsRouter = c.router({
|
|
|
29
26
|
createField: {
|
|
30
27
|
method: 'POST',
|
|
31
28
|
path: '/farms/:farmId/fields',
|
|
32
|
-
pathParams:
|
|
33
|
-
body:
|
|
29
|
+
pathParams: z.object({ farmId: z.string().uuid() }),
|
|
30
|
+
body: z.object({ data: createFieldSchema }),
|
|
34
31
|
responses: {
|
|
35
|
-
201:
|
|
36
|
-
400:
|
|
37
|
-
404:
|
|
38
|
-
401:
|
|
39
|
-
422:
|
|
32
|
+
201: fieldResponseSchema,
|
|
33
|
+
400: jsonApiErrorResponseSchema,
|
|
34
|
+
404: jsonApiErrorResponseSchema,
|
|
35
|
+
401: jsonApiErrorResponseSchema,
|
|
36
|
+
422: jsonApiErrorResponseSchema,
|
|
40
37
|
},
|
|
41
38
|
summary: 'Create a new field',
|
|
42
39
|
description: 'Create a new field with optional geometry',
|
|
@@ -45,15 +42,15 @@ exports.fieldsRouter = c.router({
|
|
|
45
42
|
getField: {
|
|
46
43
|
method: 'GET',
|
|
47
44
|
path: '/farms/:farmId/fields/:id',
|
|
48
|
-
pathParams:
|
|
49
|
-
farmId:
|
|
50
|
-
id:
|
|
45
|
+
pathParams: z.object({
|
|
46
|
+
farmId: z.string().uuid(),
|
|
47
|
+
id: z.string().uuid(),
|
|
51
48
|
}),
|
|
52
|
-
query:
|
|
49
|
+
query: jsonApiIncludeQuerySchema,
|
|
53
50
|
responses: {
|
|
54
|
-
200:
|
|
55
|
-
404:
|
|
56
|
-
401:
|
|
51
|
+
200: fieldDetailResponseSchema,
|
|
52
|
+
404: jsonApiErrorResponseSchema,
|
|
53
|
+
401: jsonApiErrorResponseSchema,
|
|
57
54
|
},
|
|
58
55
|
summary: 'Get field by ID',
|
|
59
56
|
description: 'Get detailed information about a specific field',
|
|
@@ -62,17 +59,17 @@ exports.fieldsRouter = c.router({
|
|
|
62
59
|
updateField: {
|
|
63
60
|
method: 'PATCH',
|
|
64
61
|
path: '/farms/:farmId/fields/:id',
|
|
65
|
-
pathParams:
|
|
66
|
-
farmId:
|
|
67
|
-
id:
|
|
62
|
+
pathParams: z.object({
|
|
63
|
+
farmId: z.string().uuid(),
|
|
64
|
+
id: z.string().uuid(),
|
|
68
65
|
}),
|
|
69
|
-
body:
|
|
66
|
+
body: z.object({ data: updateFieldSchema }),
|
|
70
67
|
responses: {
|
|
71
|
-
200:
|
|
72
|
-
400:
|
|
73
|
-
404:
|
|
74
|
-
401:
|
|
75
|
-
422:
|
|
68
|
+
200: fieldResponseSchema,
|
|
69
|
+
400: jsonApiErrorResponseSchema,
|
|
70
|
+
404: jsonApiErrorResponseSchema,
|
|
71
|
+
401: jsonApiErrorResponseSchema,
|
|
72
|
+
422: jsonApiErrorResponseSchema,
|
|
76
73
|
},
|
|
77
74
|
summary: 'Update field',
|
|
78
75
|
description: 'Update field information including geometry and crop lifecycle',
|
|
@@ -81,14 +78,14 @@ exports.fieldsRouter = c.router({
|
|
|
81
78
|
deleteField: {
|
|
82
79
|
method: 'DELETE',
|
|
83
80
|
path: '/farms/:farmId/fields/:id',
|
|
84
|
-
pathParams:
|
|
85
|
-
farmId:
|
|
86
|
-
id:
|
|
81
|
+
pathParams: z.object({
|
|
82
|
+
farmId: z.string().uuid(),
|
|
83
|
+
id: z.string().uuid(),
|
|
87
84
|
}),
|
|
88
85
|
responses: {
|
|
89
|
-
204:
|
|
90
|
-
404:
|
|
91
|
-
401:
|
|
86
|
+
204: jsonApiSuccessResponseSchema,
|
|
87
|
+
404: jsonApiErrorResponseSchema,
|
|
88
|
+
401: jsonApiErrorResponseSchema,
|
|
92
89
|
},
|
|
93
90
|
summary: 'Delete field',
|
|
94
91
|
description: 'Delete a field and all associated data',
|
|
@@ -1,24 +1,21 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
const
|
|
6
|
-
const
|
|
7
|
-
const common_schemas_1 = require("../schemas/common.schemas");
|
|
8
|
-
const c = (0, core_1.initContract)();
|
|
9
|
-
exports.financeRouter = c.router({
|
|
1
|
+
import { initContract } from '@ts-rest/core';
|
|
2
|
+
import { z } from 'zod';
|
|
3
|
+
import { createBudgetSchema, updateBudgetSchema, budgetResponseSchema, budgetListResponseSchema, createExpenseSchema, updateExpenseSchema, expenseResponseSchema, expenseDetailResponseSchema, expenseListResponseSchema, createRevenueSchema, updateRevenueSchema, revenueResponseSchema, revenueDetailResponseSchema, revenueListResponseSchema, financeSummaryResponseSchema, } from '../schemas/finance.schemas';
|
|
4
|
+
import { jsonApiErrorResponseSchema, jsonApiSuccessResponseSchema, jsonApiPaginationQuerySchema, jsonApiSortQuerySchema, jsonApiIncludeQuerySchema, jsonApiFilterQuerySchema } from '../schemas/common.schemas';
|
|
5
|
+
const c = initContract();
|
|
6
|
+
export const financeRouter = c.router({
|
|
10
7
|
// Budget routes
|
|
11
8
|
listBudget: {
|
|
12
9
|
method: 'GET',
|
|
13
10
|
path: '/farms/:farmId/budget',
|
|
14
|
-
pathParams:
|
|
15
|
-
query:
|
|
16
|
-
.merge(
|
|
17
|
-
.merge(
|
|
11
|
+
pathParams: z.object({ farmId: z.string().uuid() }),
|
|
12
|
+
query: jsonApiPaginationQuerySchema
|
|
13
|
+
.merge(jsonApiSortQuerySchema)
|
|
14
|
+
.merge(jsonApiIncludeQuerySchema),
|
|
18
15
|
responses: {
|
|
19
|
-
200:
|
|
20
|
-
404:
|
|
21
|
-
401:
|
|
16
|
+
200: budgetListResponseSchema,
|
|
17
|
+
404: jsonApiErrorResponseSchema,
|
|
18
|
+
401: jsonApiErrorResponseSchema,
|
|
22
19
|
},
|
|
23
20
|
summary: 'List budget items',
|
|
24
21
|
description: 'Get all budget categories for a farm',
|
|
@@ -26,14 +23,14 @@ exports.financeRouter = c.router({
|
|
|
26
23
|
createBudget: {
|
|
27
24
|
method: 'POST',
|
|
28
25
|
path: '/farms/:farmId/budget',
|
|
29
|
-
pathParams:
|
|
30
|
-
body:
|
|
26
|
+
pathParams: z.object({ farmId: z.string().uuid() }),
|
|
27
|
+
body: z.object({ data: createBudgetSchema }),
|
|
31
28
|
responses: {
|
|
32
|
-
201:
|
|
33
|
-
400:
|
|
34
|
-
404:
|
|
35
|
-
401:
|
|
36
|
-
422:
|
|
29
|
+
201: budgetResponseSchema,
|
|
30
|
+
400: jsonApiErrorResponseSchema,
|
|
31
|
+
404: jsonApiErrorResponseSchema,
|
|
32
|
+
401: jsonApiErrorResponseSchema,
|
|
33
|
+
422: jsonApiErrorResponseSchema,
|
|
37
34
|
},
|
|
38
35
|
summary: 'Create budget item',
|
|
39
36
|
description: 'Create a new budget category',
|
|
@@ -41,17 +38,17 @@ exports.financeRouter = c.router({
|
|
|
41
38
|
updateBudget: {
|
|
42
39
|
method: 'PATCH',
|
|
43
40
|
path: '/farms/:farmId/budget/:id',
|
|
44
|
-
pathParams:
|
|
45
|
-
farmId:
|
|
46
|
-
id:
|
|
41
|
+
pathParams: z.object({
|
|
42
|
+
farmId: z.string().uuid(),
|
|
43
|
+
id: z.string().uuid(),
|
|
47
44
|
}),
|
|
48
|
-
body:
|
|
45
|
+
body: z.object({ data: updateBudgetSchema }),
|
|
49
46
|
responses: {
|
|
50
|
-
200:
|
|
51
|
-
400:
|
|
52
|
-
404:
|
|
53
|
-
401:
|
|
54
|
-
422:
|
|
47
|
+
200: budgetResponseSchema,
|
|
48
|
+
400: jsonApiErrorResponseSchema,
|
|
49
|
+
404: jsonApiErrorResponseSchema,
|
|
50
|
+
401: jsonApiErrorResponseSchema,
|
|
51
|
+
422: jsonApiErrorResponseSchema,
|
|
55
52
|
},
|
|
56
53
|
summary: 'Update budget item',
|
|
57
54
|
description: 'Update a budget category',
|
|
@@ -59,14 +56,14 @@ exports.financeRouter = c.router({
|
|
|
59
56
|
deleteBudget: {
|
|
60
57
|
method: 'DELETE',
|
|
61
58
|
path: '/farms/:farmId/budget/:id',
|
|
62
|
-
pathParams:
|
|
63
|
-
farmId:
|
|
64
|
-
id:
|
|
59
|
+
pathParams: z.object({
|
|
60
|
+
farmId: z.string().uuid(),
|
|
61
|
+
id: z.string().uuid(),
|
|
65
62
|
}),
|
|
66
63
|
responses: {
|
|
67
|
-
204:
|
|
68
|
-
404:
|
|
69
|
-
401:
|
|
64
|
+
204: jsonApiSuccessResponseSchema,
|
|
65
|
+
404: jsonApiErrorResponseSchema,
|
|
66
|
+
401: jsonApiErrorResponseSchema,
|
|
70
67
|
},
|
|
71
68
|
summary: 'Delete budget item',
|
|
72
69
|
description: 'Delete a budget category',
|
|
@@ -75,20 +72,20 @@ exports.financeRouter = c.router({
|
|
|
75
72
|
listExpenses: {
|
|
76
73
|
method: 'GET',
|
|
77
74
|
path: '/farms/:farmId/expenses',
|
|
78
|
-
pathParams:
|
|
79
|
-
query:
|
|
80
|
-
.merge(
|
|
81
|
-
.merge(
|
|
82
|
-
.merge(
|
|
83
|
-
.merge(
|
|
84
|
-
'filter[category]':
|
|
85
|
-
'filter[fieldId]':
|
|
86
|
-
'filter[cropId]':
|
|
75
|
+
pathParams: z.object({ farmId: z.string().uuid() }),
|
|
76
|
+
query: jsonApiPaginationQuerySchema
|
|
77
|
+
.merge(jsonApiSortQuerySchema)
|
|
78
|
+
.merge(jsonApiIncludeQuerySchema)
|
|
79
|
+
.merge(jsonApiFilterQuerySchema)
|
|
80
|
+
.merge(z.object({
|
|
81
|
+
'filter[category]': z.string().optional(),
|
|
82
|
+
'filter[fieldId]': z.string().uuid().optional(),
|
|
83
|
+
'filter[cropId]': z.string().optional(),
|
|
87
84
|
})),
|
|
88
85
|
responses: {
|
|
89
|
-
200:
|
|
90
|
-
404:
|
|
91
|
-
401:
|
|
86
|
+
200: expenseListResponseSchema,
|
|
87
|
+
404: jsonApiErrorResponseSchema,
|
|
88
|
+
401: jsonApiErrorResponseSchema,
|
|
92
89
|
},
|
|
93
90
|
summary: 'List expenses',
|
|
94
91
|
description: 'Get all expenses for a farm with optional filtering',
|
|
@@ -96,14 +93,14 @@ exports.financeRouter = c.router({
|
|
|
96
93
|
createExpense: {
|
|
97
94
|
method: 'POST',
|
|
98
95
|
path: '/farms/:farmId/expenses',
|
|
99
|
-
pathParams:
|
|
100
|
-
body:
|
|
96
|
+
pathParams: z.object({ farmId: z.string().uuid() }),
|
|
97
|
+
body: z.object({ data: createExpenseSchema }),
|
|
101
98
|
responses: {
|
|
102
|
-
201:
|
|
103
|
-
400:
|
|
104
|
-
404:
|
|
105
|
-
401:
|
|
106
|
-
422:
|
|
99
|
+
201: expenseResponseSchema,
|
|
100
|
+
400: jsonApiErrorResponseSchema,
|
|
101
|
+
404: jsonApiErrorResponseSchema,
|
|
102
|
+
401: jsonApiErrorResponseSchema,
|
|
103
|
+
422: jsonApiErrorResponseSchema,
|
|
107
104
|
},
|
|
108
105
|
summary: 'Create expense',
|
|
109
106
|
description: 'Create a new expense with optional field/crop allocation',
|
|
@@ -111,15 +108,15 @@ exports.financeRouter = c.router({
|
|
|
111
108
|
getExpense: {
|
|
112
109
|
method: 'GET',
|
|
113
110
|
path: '/farms/:farmId/expenses/:id',
|
|
114
|
-
pathParams:
|
|
115
|
-
farmId:
|
|
116
|
-
id:
|
|
111
|
+
pathParams: z.object({
|
|
112
|
+
farmId: z.string().uuid(),
|
|
113
|
+
id: z.string().uuid(),
|
|
117
114
|
}),
|
|
118
|
-
query:
|
|
115
|
+
query: jsonApiIncludeQuerySchema,
|
|
119
116
|
responses: {
|
|
120
|
-
200:
|
|
121
|
-
404:
|
|
122
|
-
401:
|
|
117
|
+
200: expenseDetailResponseSchema,
|
|
118
|
+
404: jsonApiErrorResponseSchema,
|
|
119
|
+
401: jsonApiErrorResponseSchema,
|
|
123
120
|
},
|
|
124
121
|
summary: 'Get expense by ID',
|
|
125
122
|
description: 'Get detailed information about a specific expense',
|
|
@@ -127,17 +124,17 @@ exports.financeRouter = c.router({
|
|
|
127
124
|
updateExpense: {
|
|
128
125
|
method: 'PATCH',
|
|
129
126
|
path: '/farms/:farmId/expenses/:id',
|
|
130
|
-
pathParams:
|
|
131
|
-
farmId:
|
|
132
|
-
id:
|
|
127
|
+
pathParams: z.object({
|
|
128
|
+
farmId: z.string().uuid(),
|
|
129
|
+
id: z.string().uuid(),
|
|
133
130
|
}),
|
|
134
|
-
body:
|
|
131
|
+
body: z.object({ data: updateExpenseSchema }),
|
|
135
132
|
responses: {
|
|
136
|
-
200:
|
|
137
|
-
400:
|
|
138
|
-
404:
|
|
139
|
-
401:
|
|
140
|
-
422:
|
|
133
|
+
200: expenseResponseSchema,
|
|
134
|
+
400: jsonApiErrorResponseSchema,
|
|
135
|
+
404: jsonApiErrorResponseSchema,
|
|
136
|
+
401: jsonApiErrorResponseSchema,
|
|
137
|
+
422: jsonApiErrorResponseSchema,
|
|
141
138
|
},
|
|
142
139
|
summary: 'Update expense',
|
|
143
140
|
description: 'Update an expense',
|
|
@@ -145,14 +142,14 @@ exports.financeRouter = c.router({
|
|
|
145
142
|
deleteExpense: {
|
|
146
143
|
method: 'DELETE',
|
|
147
144
|
path: '/farms/:farmId/expenses/:id',
|
|
148
|
-
pathParams:
|
|
149
|
-
farmId:
|
|
150
|
-
id:
|
|
145
|
+
pathParams: z.object({
|
|
146
|
+
farmId: z.string().uuid(),
|
|
147
|
+
id: z.string().uuid(),
|
|
151
148
|
}),
|
|
152
149
|
responses: {
|
|
153
|
-
204:
|
|
154
|
-
404:
|
|
155
|
-
401:
|
|
150
|
+
204: jsonApiSuccessResponseSchema,
|
|
151
|
+
404: jsonApiErrorResponseSchema,
|
|
152
|
+
401: jsonApiErrorResponseSchema,
|
|
156
153
|
},
|
|
157
154
|
summary: 'Delete expense',
|
|
158
155
|
description: 'Delete an expense',
|
|
@@ -161,19 +158,19 @@ exports.financeRouter = c.router({
|
|
|
161
158
|
listRevenue: {
|
|
162
159
|
method: 'GET',
|
|
163
160
|
path: '/farms/:farmId/revenue',
|
|
164
|
-
pathParams:
|
|
165
|
-
query:
|
|
166
|
-
.merge(
|
|
167
|
-
.merge(
|
|
168
|
-
.merge(
|
|
169
|
-
.merge(
|
|
170
|
-
'filter[crop]':
|
|
171
|
-
'filter[fieldId]':
|
|
161
|
+
pathParams: z.object({ farmId: z.string().uuid() }),
|
|
162
|
+
query: jsonApiPaginationQuerySchema
|
|
163
|
+
.merge(jsonApiSortQuerySchema)
|
|
164
|
+
.merge(jsonApiIncludeQuerySchema)
|
|
165
|
+
.merge(jsonApiFilterQuerySchema)
|
|
166
|
+
.merge(z.object({
|
|
167
|
+
'filter[crop]': z.string().optional(),
|
|
168
|
+
'filter[fieldId]': z.string().uuid().optional(),
|
|
172
169
|
})),
|
|
173
170
|
responses: {
|
|
174
|
-
200:
|
|
175
|
-
404:
|
|
176
|
-
401:
|
|
171
|
+
200: revenueListResponseSchema,
|
|
172
|
+
404: jsonApiErrorResponseSchema,
|
|
173
|
+
401: jsonApiErrorResponseSchema,
|
|
177
174
|
},
|
|
178
175
|
summary: 'List revenue',
|
|
179
176
|
description: 'Get all revenue entries for a farm',
|
|
@@ -181,14 +178,14 @@ exports.financeRouter = c.router({
|
|
|
181
178
|
createRevenue: {
|
|
182
179
|
method: 'POST',
|
|
183
180
|
path: '/farms/:farmId/revenue',
|
|
184
|
-
pathParams:
|
|
185
|
-
body:
|
|
181
|
+
pathParams: z.object({ farmId: z.string().uuid() }),
|
|
182
|
+
body: z.object({ data: createRevenueSchema }),
|
|
186
183
|
responses: {
|
|
187
|
-
201:
|
|
188
|
-
400:
|
|
189
|
-
404:
|
|
190
|
-
401:
|
|
191
|
-
422:
|
|
184
|
+
201: revenueResponseSchema,
|
|
185
|
+
400: jsonApiErrorResponseSchema,
|
|
186
|
+
404: jsonApiErrorResponseSchema,
|
|
187
|
+
401: jsonApiErrorResponseSchema,
|
|
188
|
+
422: jsonApiErrorResponseSchema,
|
|
192
189
|
},
|
|
193
190
|
summary: 'Create revenue',
|
|
194
191
|
description: 'Create a new revenue entry',
|
|
@@ -196,15 +193,15 @@ exports.financeRouter = c.router({
|
|
|
196
193
|
getRevenue: {
|
|
197
194
|
method: 'GET',
|
|
198
195
|
path: '/farms/:farmId/revenue/:id',
|
|
199
|
-
pathParams:
|
|
200
|
-
farmId:
|
|
201
|
-
id:
|
|
196
|
+
pathParams: z.object({
|
|
197
|
+
farmId: z.string().uuid(),
|
|
198
|
+
id: z.string().uuid(),
|
|
202
199
|
}),
|
|
203
|
-
query:
|
|
200
|
+
query: jsonApiIncludeQuerySchema,
|
|
204
201
|
responses: {
|
|
205
|
-
200:
|
|
206
|
-
404:
|
|
207
|
-
401:
|
|
202
|
+
200: revenueDetailResponseSchema,
|
|
203
|
+
404: jsonApiErrorResponseSchema,
|
|
204
|
+
401: jsonApiErrorResponseSchema,
|
|
208
205
|
},
|
|
209
206
|
summary: 'Get revenue by ID',
|
|
210
207
|
description: 'Get detailed information about a specific revenue entry',
|
|
@@ -212,17 +209,17 @@ exports.financeRouter = c.router({
|
|
|
212
209
|
updateRevenue: {
|
|
213
210
|
method: 'PATCH',
|
|
214
211
|
path: '/farms/:farmId/revenue/:id',
|
|
215
|
-
pathParams:
|
|
216
|
-
farmId:
|
|
217
|
-
id:
|
|
212
|
+
pathParams: z.object({
|
|
213
|
+
farmId: z.string().uuid(),
|
|
214
|
+
id: z.string().uuid(),
|
|
218
215
|
}),
|
|
219
|
-
body:
|
|
216
|
+
body: z.object({ data: updateRevenueSchema }),
|
|
220
217
|
responses: {
|
|
221
|
-
200:
|
|
222
|
-
400:
|
|
223
|
-
404:
|
|
224
|
-
401:
|
|
225
|
-
422:
|
|
218
|
+
200: revenueResponseSchema,
|
|
219
|
+
400: jsonApiErrorResponseSchema,
|
|
220
|
+
404: jsonApiErrorResponseSchema,
|
|
221
|
+
401: jsonApiErrorResponseSchema,
|
|
222
|
+
422: jsonApiErrorResponseSchema,
|
|
226
223
|
},
|
|
227
224
|
summary: 'Update revenue',
|
|
228
225
|
description: 'Update a revenue entry',
|
|
@@ -230,14 +227,14 @@ exports.financeRouter = c.router({
|
|
|
230
227
|
deleteRevenue: {
|
|
231
228
|
method: 'DELETE',
|
|
232
229
|
path: '/farms/:farmId/revenue/:id',
|
|
233
|
-
pathParams:
|
|
234
|
-
farmId:
|
|
235
|
-
id:
|
|
230
|
+
pathParams: z.object({
|
|
231
|
+
farmId: z.string().uuid(),
|
|
232
|
+
id: z.string().uuid(),
|
|
236
233
|
}),
|
|
237
234
|
responses: {
|
|
238
|
-
204:
|
|
239
|
-
404:
|
|
240
|
-
401:
|
|
235
|
+
204: jsonApiSuccessResponseSchema,
|
|
236
|
+
404: jsonApiErrorResponseSchema,
|
|
237
|
+
401: jsonApiErrorResponseSchema,
|
|
241
238
|
},
|
|
242
239
|
summary: 'Delete revenue',
|
|
243
240
|
description: 'Delete a revenue entry',
|
|
@@ -246,12 +243,12 @@ exports.financeRouter = c.router({
|
|
|
246
243
|
getFinanceSummary: {
|
|
247
244
|
method: 'GET',
|
|
248
245
|
path: '/farms/:farmId/finance/summary',
|
|
249
|
-
pathParams:
|
|
250
|
-
query:
|
|
246
|
+
pathParams: z.object({ farmId: z.string().uuid() }),
|
|
247
|
+
query: jsonApiFilterQuerySchema,
|
|
251
248
|
responses: {
|
|
252
|
-
200:
|
|
253
|
-
404:
|
|
254
|
-
401:
|
|
249
|
+
200: financeSummaryResponseSchema,
|
|
250
|
+
404: jsonApiErrorResponseSchema,
|
|
251
|
+
401: jsonApiErrorResponseSchema,
|
|
255
252
|
},
|
|
256
253
|
summary: 'Get finance summary',
|
|
257
254
|
description: 'Get financial overview including totals, profit, and budget breakdown',
|