@campxdev/server-shared 1.6.33 → 1.6.35
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/domain/mongodb-repositories/mongodb-tenant.repository.d.ts +4 -1
- package/dist/domain/mongodb-repositories/mongodb-tenant.repository.d.ts.map +1 -1
- package/dist/domain/mongodb-repositories/mongodb-tenant.repository.js +11 -2
- package/dist/domain/mongodb-repositories/mongodb-tenant.repository.js.map +1 -1
- package/dist/domain/repositories/tenant.repository.d.ts +4 -1
- package/dist/domain/repositories/tenant.repository.d.ts.map +1 -1
- package/dist/domain/repositories/tenant.repository.js.map +1 -1
- package/dist/domain/services/shared-domain.service.js +1 -1
- package/dist/domain/services/shared-domain.service.js.map +1 -1
- package/dist/frappe/frappe.module.d.ts.map +1 -1
- package/dist/frappe/frappe.module.js +9 -2
- package/dist/frappe/frappe.module.js.map +1 -1
- package/dist/frappe/index.d.ts +4 -2
- package/dist/frappe/index.d.ts.map +1 -1
- package/dist/frappe/index.js +4 -2
- package/dist/frappe/index.js.map +1 -1
- package/dist/frappe/services/department.service.d.ts +21 -10
- package/dist/frappe/services/department.service.d.ts.map +1 -1
- package/dist/frappe/services/department.service.js +39 -61
- package/dist/frappe/services/department.service.js.map +1 -1
- package/dist/frappe/services/designation.service.d.ts +12 -11
- package/dist/frappe/services/designation.service.d.ts.map +1 -1
- package/dist/frappe/services/designation.service.js +27 -58
- package/dist/frappe/services/designation.service.js.map +1 -1
- package/dist/frappe/services/institution.service.d.ts +38 -0
- package/dist/frappe/services/institution.service.d.ts.map +1 -0
- package/dist/frappe/services/institution.service.js +65 -0
- package/dist/frappe/services/institution.service.js.map +1 -0
- package/dist/frappe/services/user.service.d.ts +55 -15
- package/dist/frappe/services/user.service.d.ts.map +1 -1
- package/dist/frappe/services/user.service.js +94 -121
- package/dist/frappe/services/user.service.js.map +1 -1
- package/dist/frappe/utils/frappe.utils.d.ts +93 -0
- package/dist/frappe/utils/frappe.utils.d.ts.map +1 -0
- package/dist/frappe/utils/frappe.utils.js +245 -0
- package/dist/frappe/utils/frappe.utils.js.map +1 -0
- package/dist/index.d.ts +2 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -1
- package/dist/index.js.map +1 -1
- package/dist/request-store/request-store.d.ts +4 -1
- package/dist/request-store/request-store.d.ts.map +1 -1
- package/dist/request-store/request-store.js +25 -5
- package/dist/request-store/request-store.js.map +1 -1
- package/dist/shared-module/shared.module.d.ts.map +1 -1
- package/dist/shared-module/shared.module.js +2 -0
- package/dist/shared-module/shared.module.js.map +1 -1
- package/dist/shared-module/shared.types.d.ts +1 -1
- package/dist/shared-module/shared.types.d.ts.map +1 -1
- package/dist/util-module/index.d.ts +3 -0
- package/dist/util-module/index.d.ts.map +1 -0
- package/dist/util-module/index.js +19 -0
- package/dist/util-module/index.js.map +1 -0
- package/dist/util-module/utils.module.d.ts +3 -0
- package/dist/util-module/utils.module.d.ts.map +1 -0
- package/dist/util-module/utils.module.js +23 -0
- package/dist/util-module/utils.module.js.map +1 -0
- package/dist/util-module/utils.service.d.ts +62 -0
- package/dist/util-module/utils.service.d.ts.map +1 -0
- package/dist/util-module/utils.service.js +144 -0
- package/dist/util-module/utils.service.js.map +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"institution.service.js","sourceRoot":"","sources":["../../../src/frappe/services/institution.service.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAA4C;AAC5C,wDAK+B;AAWxB,IAAM,wBAAwB,GAA9B,MAAM,wBAAwB;IACnC,KAAK,CAAC,iBAAiB,CAAC,KAKvB;QACC,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,KAAK,CAAC;QAE/C,IAAI,CAAC,IAAI,CAAC,gBAAgB;YAAE,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;QAC1D,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QAE1C,OAAO,MAAM,IAAA,iCAAkB,EAAwB;YACrD,OAAO,EAAE,OAAO;YAChB,SAAS,EAAE,KAAK;YAChB,UAAU,EAAE,MAAM;YAClB,OAAO,EAAE,SAAS;YAClB,MAAM,EAAE,IAAI;SACb,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,iBAAiB,CAAC,KAMvB;QACC,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,KAAK,CAAC;QAErD,OAAO,MAAM,IAAA,iCAAkB,EAAC;YAC9B,OAAO,EAAE,OAAO;YAChB,SAAS,EAAE,KAAK;YAChB,UAAU,EAAE,MAAM;YAClB,OAAO,EAAE,SAAS;YAClB,EAAE,EAAE,IAAI;YACR,MAAM,EAAE,IAAI;SACb,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,iBAAiB,CAAC,KAMvB;QACC,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,KAAK,CAAC;QAE3D,OAAO,MAAM,IAAA,iCAAkB,EAAC;YAC9B,OAAO,EAAE,OAAO;YAChB,SAAS,EAAE,KAAK;YAChB,UAAU,EAAE,MAAM;YAClB,OAAO,EAAE,SAAS;YAClB,OAAO,EAAE,OAAO;YAChB,OAAO,EAAE,OAAO;SACjB,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,eAAe,CAAC,KAAyD;QAC7E,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,KAAK,CAAC;QAEzC,MAAM,QAAQ,GAAG,MAAM,IAAA,kCAAmB,EAAC;YACzC,OAAO;YACP,KAAK;YACL,MAAM;YACN,OAAO,EAAE,SAAS;YAClB,YAAY,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;SAC/B,CAAC,CAAC;QAEH,OAAO,QAA4C,CAAC;IACtD,CAAC;CACF,CAAA;AAxEY,4DAAwB;mCAAxB,wBAAwB;IADpC,IAAA,mBAAU,GAAE;GACA,wBAAwB,CAwEpC"}
|
|
@@ -1,46 +1,86 @@
|
|
|
1
|
+
export type FrappeEmployeeType = {
|
|
2
|
+
first_name: string;
|
|
3
|
+
middle_name?: string;
|
|
4
|
+
last_name?: string;
|
|
5
|
+
date_of_birth: string;
|
|
6
|
+
date_of_joining: string;
|
|
7
|
+
gender: string;
|
|
8
|
+
status: 'Active' | 'Inactive';
|
|
9
|
+
company?: string;
|
|
10
|
+
user_id?: string;
|
|
11
|
+
};
|
|
12
|
+
export type FrappeUserType = {
|
|
13
|
+
email: string;
|
|
14
|
+
first_name: string;
|
|
15
|
+
middle_name?: string;
|
|
16
|
+
last_name?: string;
|
|
17
|
+
date_of_birth: string;
|
|
18
|
+
date_of_joining: string;
|
|
19
|
+
gender: string;
|
|
20
|
+
status: 'Active' | 'Inactive';
|
|
21
|
+
roles: {
|
|
22
|
+
role: string;
|
|
23
|
+
}[];
|
|
24
|
+
};
|
|
25
|
+
export type FrappeUserAndEmployeeType = FrappeEmployeeType & {
|
|
26
|
+
email: string;
|
|
27
|
+
};
|
|
1
28
|
export declare class FrappeUserService {
|
|
2
|
-
private getAxiosConfig;
|
|
3
29
|
getLoggedInUser(props: {
|
|
4
30
|
baseUrl: string;
|
|
5
31
|
token: string;
|
|
6
32
|
secret: string;
|
|
7
33
|
}): Promise<any>;
|
|
8
|
-
getUsers(props: {
|
|
9
|
-
baseUrl: string;
|
|
10
|
-
token: string;
|
|
11
|
-
secret: string;
|
|
12
|
-
}): Promise<any>;
|
|
13
34
|
createUser(props: {
|
|
14
35
|
baseUrl: string;
|
|
15
36
|
token: string;
|
|
16
37
|
secret: string;
|
|
17
|
-
|
|
38
|
+
data: FrappeUserType;
|
|
18
39
|
}): Promise<any>;
|
|
19
|
-
|
|
40
|
+
createEmployee(props: {
|
|
20
41
|
baseUrl: string;
|
|
21
42
|
token: string;
|
|
22
43
|
secret: string;
|
|
23
44
|
userId: string;
|
|
24
|
-
|
|
45
|
+
data: FrappeEmployeeType;
|
|
25
46
|
}): Promise<any>;
|
|
26
|
-
|
|
47
|
+
createUserAndEmployee(props: {
|
|
27
48
|
baseUrl: string;
|
|
28
49
|
token: string;
|
|
29
50
|
secret: string;
|
|
30
|
-
|
|
51
|
+
data: FrappeUserAndEmployeeType;
|
|
31
52
|
}): Promise<any>;
|
|
32
|
-
|
|
53
|
+
renameUserEmail(props: {
|
|
33
54
|
baseUrl: string;
|
|
34
55
|
token: string;
|
|
35
56
|
secret: string;
|
|
36
|
-
|
|
57
|
+
oldEmail: string;
|
|
58
|
+
newEmail: string;
|
|
37
59
|
}): Promise<any>;
|
|
38
|
-
|
|
60
|
+
updateUserAndEmployee(props: {
|
|
39
61
|
baseUrl: string;
|
|
40
62
|
token: string;
|
|
41
63
|
secret: string;
|
|
42
|
-
employeeData: any;
|
|
43
64
|
userId: string;
|
|
65
|
+
data: {
|
|
66
|
+
gender?: string;
|
|
67
|
+
date_of_birth?: string;
|
|
68
|
+
date_of_joining?: string;
|
|
69
|
+
status?: 'Active' | 'Inactive';
|
|
70
|
+
first_name?: string;
|
|
71
|
+
middle_name?: string;
|
|
72
|
+
last_name?: string;
|
|
73
|
+
};
|
|
44
74
|
}): Promise<any>;
|
|
75
|
+
findByEmails(props: {
|
|
76
|
+
baseUrl: string;
|
|
77
|
+
token: string;
|
|
78
|
+
secret: string;
|
|
79
|
+
emails: string[];
|
|
80
|
+
}): Promise<{
|
|
81
|
+
data: {
|
|
82
|
+
name: string;
|
|
83
|
+
}[];
|
|
84
|
+
}>;
|
|
45
85
|
}
|
|
46
86
|
//# sourceMappingURL=user.service.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"user.service.d.ts","sourceRoot":"","sources":["../../../src/frappe/services/user.service.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"user.service.d.ts","sourceRoot":"","sources":["../../../src/frappe/services/user.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -12,19 +12,12 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
12
12
|
exports.FrappeUserService = void 0;
|
|
13
13
|
const common_1 = require("@nestjs/common");
|
|
14
14
|
const axios_1 = __importDefault(require("axios"));
|
|
15
|
+
const frappe_utils_1 = require("../utils/frappe.utils");
|
|
15
16
|
let FrappeUserService = class FrappeUserService {
|
|
16
|
-
getAxiosConfig(token, secret) {
|
|
17
|
-
return {
|
|
18
|
-
headers: {
|
|
19
|
-
Authorization: `token ${token}:${secret}`,
|
|
20
|
-
'Content-Type': 'application/json',
|
|
21
|
-
},
|
|
22
|
-
};
|
|
23
|
-
}
|
|
24
17
|
async getLoggedInUser(props) {
|
|
25
18
|
const { baseUrl, token, secret } = props;
|
|
26
19
|
const url = `${baseUrl}/api/method/frappe.auth.get_logged_user`;
|
|
27
|
-
const config =
|
|
20
|
+
const config = (0, frappe_utils_1.getFrappeAxiosConfig)(token, secret);
|
|
28
21
|
try {
|
|
29
22
|
const response = await axios_1.default.get(url, config);
|
|
30
23
|
return response.data;
|
|
@@ -36,134 +29,114 @@ let FrappeUserService = class FrappeUserService {
|
|
|
36
29
|
throw new common_1.UnprocessableEntityException('Unexpected error', error);
|
|
37
30
|
}
|
|
38
31
|
}
|
|
39
|
-
async getUsers(props) {
|
|
40
|
-
const { baseUrl, token, secret } = props;
|
|
41
|
-
// Specify the fields you want to retrieve
|
|
42
|
-
const fields = ['email', 'first_name', 'last_name', 'gender'];
|
|
43
|
-
const url = `${baseUrl}/api/resource/User?fields=${JSON.stringify(fields)}`;
|
|
44
|
-
const config = this.getAxiosConfig(token, secret);
|
|
45
|
-
try {
|
|
46
|
-
const response = await axios_1.default.get(url, config);
|
|
47
|
-
return response.data;
|
|
48
|
-
}
|
|
49
|
-
catch (error) {
|
|
50
|
-
if (axios_1.default.isAxiosError(error)) {
|
|
51
|
-
console.log('Error fetching users from Frappe', error.response?.data || error.message);
|
|
52
|
-
throw new common_1.UnprocessableEntityException('Error fetching users from Frappe', error.response?.data || error.message);
|
|
53
|
-
}
|
|
54
|
-
throw new common_1.UnprocessableEntityException('Unexpected error', error);
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
// Create User in ERPNext
|
|
58
32
|
async createUser(props) {
|
|
59
|
-
const { baseUrl, token, secret,
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
throw new common_1.UnprocessableEntityException('Unexpected error', error);
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
// Update User in ERPNext
|
|
74
|
-
async updateUser(props) {
|
|
75
|
-
const { baseUrl, token, secret, userId, userData } = props;
|
|
76
|
-
const url = `${baseUrl}/api/resource/User/${userId}`;
|
|
77
|
-
const config = this.getAxiosConfig(token, secret);
|
|
78
|
-
try {
|
|
79
|
-
const response = await axios_1.default.put(url, userData, config);
|
|
80
|
-
return response.data;
|
|
81
|
-
}
|
|
82
|
-
catch (error) {
|
|
83
|
-
if (axios_1.default.isAxiosError(error)) {
|
|
84
|
-
throw new common_1.UnprocessableEntityException('Error updating user in Frappe', error.response?.data || error.message);
|
|
85
|
-
}
|
|
86
|
-
throw new common_1.UnprocessableEntityException('Unexpected error', error);
|
|
87
|
-
}
|
|
33
|
+
const { baseUrl, token, secret, data } = props;
|
|
34
|
+
return await (0, frappe_utils_1.insertFrappeRecord)({
|
|
35
|
+
baseUrl: baseUrl,
|
|
36
|
+
authToken: token,
|
|
37
|
+
authSecret: secret,
|
|
38
|
+
doctype: 'User',
|
|
39
|
+
record: {
|
|
40
|
+
...data,
|
|
41
|
+
send_welcome_email: 0,
|
|
42
|
+
},
|
|
43
|
+
});
|
|
88
44
|
}
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
}
|
|
98
|
-
catch (error) {
|
|
99
|
-
if (axios_1.default.isAxiosError(error)) {
|
|
100
|
-
throw new common_1.UnprocessableEntityException('Error deleting user in Frappe', error.response?.data || error.message);
|
|
101
|
-
}
|
|
102
|
-
throw new common_1.UnprocessableEntityException('Unexpected error', error);
|
|
103
|
-
}
|
|
45
|
+
async createEmployee(props) {
|
|
46
|
+
const { baseUrl, token, secret, data, userId } = props;
|
|
47
|
+
return await (0, frappe_utils_1.insertFrappeRecord)({
|
|
48
|
+
baseUrl: baseUrl,
|
|
49
|
+
authToken: token,
|
|
50
|
+
authSecret: secret,
|
|
51
|
+
doctype: 'Employee',
|
|
52
|
+
record: { ...data, user_id: userId },
|
|
53
|
+
});
|
|
104
54
|
}
|
|
105
55
|
// Create User and Employee in Frappe
|
|
106
56
|
async createUserAndEmployee(props) {
|
|
107
|
-
const { baseUrl, token, secret,
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
57
|
+
const { baseUrl, token, secret, data } = props;
|
|
58
|
+
await this.createUser({
|
|
59
|
+
baseUrl,
|
|
60
|
+
token,
|
|
61
|
+
secret,
|
|
62
|
+
data: {
|
|
63
|
+
...data,
|
|
64
|
+
roles: [{ role: 'Employee' }],
|
|
65
|
+
},
|
|
66
|
+
});
|
|
114
67
|
try {
|
|
115
|
-
|
|
116
|
-
const createdUser = await this.createUser({
|
|
68
|
+
await this.createEmployee({
|
|
117
69
|
baseUrl,
|
|
118
70
|
token,
|
|
119
71
|
secret,
|
|
120
|
-
|
|
72
|
+
userId: data.email,
|
|
73
|
+
data: data,
|
|
121
74
|
});
|
|
122
|
-
|
|
123
|
-
|
|
75
|
+
}
|
|
76
|
+
catch (err) {
|
|
77
|
+
await (0, frappe_utils_1.deleteFrappeRecord)({
|
|
124
78
|
baseUrl,
|
|
125
|
-
token,
|
|
126
|
-
secret,
|
|
127
|
-
|
|
128
|
-
|
|
79
|
+
token: token,
|
|
80
|
+
secret: secret,
|
|
81
|
+
doctype: 'User',
|
|
82
|
+
name: data.email,
|
|
129
83
|
});
|
|
130
|
-
|
|
131
|
-
return {
|
|
132
|
-
message: 'User and Employee created and linked successfully',
|
|
133
|
-
user: createdUser,
|
|
134
|
-
employee: createdEmployee,
|
|
135
|
-
};
|
|
136
|
-
}
|
|
137
|
-
catch (error) {
|
|
138
|
-
if (axios_1.default.isAxiosError(error)) {
|
|
139
|
-
throw new common_1.UnprocessableEntityException('Error creating user and employee in Frappe', error.response?.data || error.message);
|
|
140
|
-
}
|
|
141
|
-
throw new common_1.UnprocessableEntityException('Unexpected error', error);
|
|
84
|
+
throw err;
|
|
142
85
|
}
|
|
143
86
|
}
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
const
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
};
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
87
|
+
async renameUserEmail(props) {
|
|
88
|
+
const { baseUrl, token, secret, oldEmail, newEmail } = props;
|
|
89
|
+
const res = await (0, frappe_utils_1.renameFrappeRecord)({
|
|
90
|
+
baseUrl: baseUrl,
|
|
91
|
+
authToken: token,
|
|
92
|
+
authSecret: secret,
|
|
93
|
+
doctype: 'User',
|
|
94
|
+
newName: newEmail,
|
|
95
|
+
oldName: oldEmail,
|
|
96
|
+
});
|
|
97
|
+
return res;
|
|
98
|
+
}
|
|
99
|
+
async updateUserAndEmployee(props) {
|
|
100
|
+
const { baseUrl, token, secret, userId, data } = props;
|
|
101
|
+
await (0, frappe_utils_1.updateFrappeRecord)({
|
|
102
|
+
baseUrl: baseUrl,
|
|
103
|
+
authToken: token,
|
|
104
|
+
authSecret: secret,
|
|
105
|
+
doctype: 'User',
|
|
106
|
+
id: userId,
|
|
107
|
+
record: data,
|
|
108
|
+
});
|
|
109
|
+
const res = await (0, frappe_utils_1.getRecordByOtherFields)({
|
|
110
|
+
baseUrl,
|
|
111
|
+
token,
|
|
112
|
+
secret,
|
|
113
|
+
doctype: 'Employee',
|
|
114
|
+
fields: { user_id: userId },
|
|
115
|
+
});
|
|
116
|
+
const employeeId = res?.data[0]?.name;
|
|
117
|
+
if (employeeId) {
|
|
118
|
+
await (0, frappe_utils_1.updateFrappeRecord)({
|
|
119
|
+
baseUrl: baseUrl,
|
|
120
|
+
authToken: token,
|
|
121
|
+
authSecret: secret,
|
|
122
|
+
doctype: 'Employee',
|
|
123
|
+
id: employeeId,
|
|
124
|
+
record: data,
|
|
125
|
+
});
|
|
165
126
|
}
|
|
166
127
|
}
|
|
128
|
+
async findByEmails(props) {
|
|
129
|
+
const { baseUrl, token, secret, emails } = props;
|
|
130
|
+
const res = (await (0, frappe_utils_1.getFrappeRecordsByIds)({
|
|
131
|
+
baseUrl: baseUrl,
|
|
132
|
+
token: token,
|
|
133
|
+
secret: secret,
|
|
134
|
+
doctype: 'User',
|
|
135
|
+
ids: emails,
|
|
136
|
+
selectFields: ['name'],
|
|
137
|
+
}));
|
|
138
|
+
return res;
|
|
139
|
+
}
|
|
167
140
|
};
|
|
168
141
|
exports.FrappeUserService = FrappeUserService;
|
|
169
142
|
exports.FrappeUserService = FrappeUserService = __decorate([
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"user.service.js","sourceRoot":"","sources":["../../../src/frappe/services/user.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA0E;AAC1E,
|
|
1
|
+
{"version":3,"file":"user.service.js","sourceRoot":"","sources":["../../../src/frappe/services/user.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import { AxiosRequestConfig } from 'axios';
|
|
2
|
+
export type FrappeFieldMetaData = {
|
|
3
|
+
fieldname: string;
|
|
4
|
+
label: string;
|
|
5
|
+
fieldtype: string;
|
|
6
|
+
reqd?: number;
|
|
7
|
+
unique?: number;
|
|
8
|
+
read_only?: number;
|
|
9
|
+
};
|
|
10
|
+
type CreateOrUpdateCustomFieldParams = {
|
|
11
|
+
baseUrl: string;
|
|
12
|
+
authToken: string;
|
|
13
|
+
authSecret: string;
|
|
14
|
+
doctype: string;
|
|
15
|
+
fieldMetaData: FrappeFieldMetaData;
|
|
16
|
+
};
|
|
17
|
+
export declare function getFrappeAxiosConfig(token: string, secret: string): AxiosRequestConfig;
|
|
18
|
+
export declare function createOrUpdateFrappeCustomField({ baseUrl, authToken, authSecret, doctype, fieldMetaData, }: CreateOrUpdateCustomFieldParams): Promise<void>;
|
|
19
|
+
export type InsertRecordParams<T> = {
|
|
20
|
+
baseUrl: string;
|
|
21
|
+
authToken: string;
|
|
22
|
+
authSecret: string;
|
|
23
|
+
doctype: string;
|
|
24
|
+
record: T;
|
|
25
|
+
};
|
|
26
|
+
export type FrappePostResponse = {
|
|
27
|
+
data: any;
|
|
28
|
+
message?: string;
|
|
29
|
+
error?: string;
|
|
30
|
+
};
|
|
31
|
+
export declare function insertFrappeRecord<T>({ baseUrl, authToken, authSecret, doctype, record, }: InsertRecordParams<T>): Promise<FrappePostResponse>;
|
|
32
|
+
interface UpdateRecordParams<T> {
|
|
33
|
+
baseUrl: string;
|
|
34
|
+
authToken: string;
|
|
35
|
+
authSecret: string;
|
|
36
|
+
doctype: string;
|
|
37
|
+
id: string;
|
|
38
|
+
record: Partial<T>;
|
|
39
|
+
}
|
|
40
|
+
export declare function updateFrappeRecord<T>({ baseUrl, authToken, authSecret, doctype, id, record, }: UpdateRecordParams<T>): Promise<FrappePostResponse>;
|
|
41
|
+
export declare function getRecordByOtherFields(props: {
|
|
42
|
+
baseUrl: string;
|
|
43
|
+
token: string;
|
|
44
|
+
secret: string;
|
|
45
|
+
doctype: string;
|
|
46
|
+
fields: Record<string, any>;
|
|
47
|
+
}): Promise<{
|
|
48
|
+
data: any[];
|
|
49
|
+
}>;
|
|
50
|
+
interface RenameRecordParams {
|
|
51
|
+
baseUrl: string;
|
|
52
|
+
authToken: string;
|
|
53
|
+
authSecret: string;
|
|
54
|
+
doctype: string;
|
|
55
|
+
oldName: string;
|
|
56
|
+
newName: string;
|
|
57
|
+
}
|
|
58
|
+
export declare function renameFrappeRecord({ baseUrl, authToken, authSecret, doctype, oldName, newName, }: RenameRecordParams): Promise<any>;
|
|
59
|
+
export declare function getFrappeRecords(props: {
|
|
60
|
+
baseUrl: string;
|
|
61
|
+
token: string;
|
|
62
|
+
secret: string;
|
|
63
|
+
doctype: string;
|
|
64
|
+
selectFields?: string[];
|
|
65
|
+
limit?: number;
|
|
66
|
+
skip?: number;
|
|
67
|
+
}): Promise<{
|
|
68
|
+
data: any[];
|
|
69
|
+
}>;
|
|
70
|
+
export declare function getAllFrappeRecords(props: {
|
|
71
|
+
baseUrl: string;
|
|
72
|
+
token: string;
|
|
73
|
+
secret: string;
|
|
74
|
+
doctype: string;
|
|
75
|
+
selectFields?: string[];
|
|
76
|
+
}): Promise<any[]>;
|
|
77
|
+
export declare function getFrappeRecordsByIds(props: {
|
|
78
|
+
baseUrl: string;
|
|
79
|
+
token: string;
|
|
80
|
+
secret: string;
|
|
81
|
+
doctype: string;
|
|
82
|
+
selectFields?: string[];
|
|
83
|
+
ids: string[];
|
|
84
|
+
}): Promise<any>;
|
|
85
|
+
export declare function deleteFrappeRecord(props: {
|
|
86
|
+
baseUrl: string;
|
|
87
|
+
token: string;
|
|
88
|
+
secret: string;
|
|
89
|
+
doctype: string;
|
|
90
|
+
name: string;
|
|
91
|
+
}): Promise<any>;
|
|
92
|
+
export {};
|
|
93
|
+
//# sourceMappingURL=frappe.utils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"frappe.utils.d.ts","sourceRoot":"","sources":["../../../src/frappe/utils/frappe.utils.ts"],"names":[],"mappings":"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"}
|