aerochain-node-sdk 1.0.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.
- package/LICENSE +21 -0
- package/README.md +216 -0
- package/dist/auth.d.ts +26 -0
- package/dist/auth.d.ts.map +1 -0
- package/dist/auth.js +93 -0
- package/dist/client.d.ts +41 -0
- package/dist/client.d.ts.map +1 -0
- package/dist/client.js +44 -0
- package/dist/clients/aircraft-events.d.ts +15 -0
- package/dist/clients/aircraft-events.d.ts.map +1 -0
- package/dist/clients/aircraft-events.js +21 -0
- package/dist/clients/aircraft-models.d.ts +14 -0
- package/dist/clients/aircraft-models.d.ts.map +1 -0
- package/dist/clients/aircraft-models.js +17 -0
- package/dist/clients/aircraft.d.ts +15 -0
- package/dist/clients/aircraft.d.ts.map +1 -0
- package/dist/clients/aircraft.js +19 -0
- package/dist/clients/ata-chapters.d.ts +14 -0
- package/dist/clients/ata-chapters.d.ts.map +1 -0
- package/dist/clients/ata-chapters.js +15 -0
- package/dist/clients/dashboard.d.ts +8 -0
- package/dist/clients/dashboard.d.ts.map +1 -0
- package/dist/clients/dashboard.js +9 -0
- package/dist/clients/documents.d.ts +14 -0
- package/dist/clients/documents.d.ts.map +1 -0
- package/dist/clients/documents.js +15 -0
- package/dist/clients/event-shares.d.ts +31 -0
- package/dist/clients/event-shares.d.ts.map +1 -0
- package/dist/clients/event-shares.js +36 -0
- package/dist/clients/organizations.d.ts +14 -0
- package/dist/clients/organizations.d.ts.map +1 -0
- package/dist/clients/organizations.js +17 -0
- package/dist/clients/part-events.d.ts +27 -0
- package/dist/clients/part-events.d.ts.map +1 -0
- package/dist/clients/part-events.js +31 -0
- package/dist/clients/part-models.d.ts +15 -0
- package/dist/clients/part-models.d.ts.map +1 -0
- package/dist/clients/part-models.js +19 -0
- package/dist/clients/partnerships.d.ts +20 -0
- package/dist/clients/partnerships.d.ts.map +1 -0
- package/dist/clients/partnerships.js +22 -0
- package/dist/clients/parts.d.ts +29 -0
- package/dist/clients/parts.d.ts.map +1 -0
- package/dist/clients/parts.js +42 -0
- package/dist/clients/registry.d.ts +11 -0
- package/dist/clients/registry.d.ts.map +1 -0
- package/dist/clients/registry.js +11 -0
- package/dist/clients/users.d.ts +8 -0
- package/dist/clients/users.d.ts.map +1 -0
- package/dist/clients/users.js +9 -0
- package/dist/http-client.d.ts +8 -0
- package/dist/http-client.d.ts.map +1 -0
- package/dist/http-client.js +63 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +2 -0
- package/dist/types.d.ts +351 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +1 -0
- package/package.json +64 -0
package/LICENSE
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2024 Aerochain
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
package/README.md
ADDED
|
@@ -0,0 +1,216 @@
|
|
|
1
|
+
<p align="center">
|
|
2
|
+
<img src="https://raw.githubusercontent.com/Wingleet/aerochain-node-sdk/main/logo.svg" alt="Aerochain Logo" width="200"/>
|
|
3
|
+
</p>
|
|
4
|
+
|
|
5
|
+
# Aerochain Node SDK
|
|
6
|
+
|
|
7
|
+
[](https://www.npmjs.com/package/aerochain-node-sdk)
|
|
8
|
+
[](https://opensource.org/licenses/MIT)
|
|
9
|
+
[](https://nodejs.org)
|
|
10
|
+
|
|
11
|
+
Official Node.js SDK for the Aerochain API - The blockchain-based aviation parts traceability platform.
|
|
12
|
+
|
|
13
|
+
## Installation
|
|
14
|
+
|
|
15
|
+
```bash
|
|
16
|
+
npm install aerochain-node-sdk
|
|
17
|
+
```
|
|
18
|
+
|
|
19
|
+
## Quick Start
|
|
20
|
+
|
|
21
|
+
### Authentication with Email/Password
|
|
22
|
+
|
|
23
|
+
```typescript
|
|
24
|
+
import { AerochainClient } from 'aerochain-node-sdk';
|
|
25
|
+
|
|
26
|
+
const client = new AerochainClient({
|
|
27
|
+
baseURL: 'https://api.aerochain.com',
|
|
28
|
+
auth: {
|
|
29
|
+
type: 'credentials',
|
|
30
|
+
email: 'user@example.com',
|
|
31
|
+
password: 'your-password',
|
|
32
|
+
},
|
|
33
|
+
});
|
|
34
|
+
|
|
35
|
+
await client.initialize();
|
|
36
|
+
|
|
37
|
+
const parts = await client.parts.list();
|
|
38
|
+
console.log(parts);
|
|
39
|
+
```
|
|
40
|
+
|
|
41
|
+
### Authentication with API Key
|
|
42
|
+
|
|
43
|
+
```typescript
|
|
44
|
+
import { AerochainClient } from 'aerochain-node-sdk';
|
|
45
|
+
|
|
46
|
+
const client = new AerochainClient({
|
|
47
|
+
baseURL: 'https://api.aerochain.com',
|
|
48
|
+
auth: {
|
|
49
|
+
type: 'apiKey',
|
|
50
|
+
apiKey: 'your-api-key',
|
|
51
|
+
},
|
|
52
|
+
});
|
|
53
|
+
|
|
54
|
+
const parts = await client.parts.list();
|
|
55
|
+
console.log(parts);
|
|
56
|
+
```
|
|
57
|
+
|
|
58
|
+
## Features
|
|
59
|
+
|
|
60
|
+
- ✅ Email/Password authentication with automatic JWT token renewal
|
|
61
|
+
- ✅ API Key authentication
|
|
62
|
+
- ✅ Full TypeScript support
|
|
63
|
+
- ✅ Automatic token refresh
|
|
64
|
+
- ✅ Comprehensive API coverage
|
|
65
|
+
|
|
66
|
+
## API Reference
|
|
67
|
+
|
|
68
|
+
### Client Initialization
|
|
69
|
+
|
|
70
|
+
```typescript
|
|
71
|
+
const client = new AerochainClient(config);
|
|
72
|
+
await client.initialize(); // Required for credentials auth
|
|
73
|
+
```
|
|
74
|
+
|
|
75
|
+
### Parts
|
|
76
|
+
|
|
77
|
+
```typescript
|
|
78
|
+
// List parts
|
|
79
|
+
const parts = await client.parts.list({ page: 1, filters: { status: 'active' } });
|
|
80
|
+
|
|
81
|
+
// Get single part
|
|
82
|
+
const part = await client.parts.get('part-id');
|
|
83
|
+
|
|
84
|
+
// Create part
|
|
85
|
+
const newPart = await client.parts.create({
|
|
86
|
+
serialNumber: 'SN123',
|
|
87
|
+
partNumber: 'PN456',
|
|
88
|
+
manufacturer: 'org-id',
|
|
89
|
+
});
|
|
90
|
+
|
|
91
|
+
// Create part with event
|
|
92
|
+
const formData = new FormData();
|
|
93
|
+
formData.append('serialNumber', 'SN123');
|
|
94
|
+
formData.append('file', fileBuffer, 'document.pdf');
|
|
95
|
+
const partWithEvent = await client.parts.createWithEvent(formData);
|
|
96
|
+
```
|
|
97
|
+
|
|
98
|
+
### Event Shares
|
|
99
|
+
|
|
100
|
+
```typescript
|
|
101
|
+
// List event shares
|
|
102
|
+
const shares = await client.eventShares.list({
|
|
103
|
+
entityType: 'part',
|
|
104
|
+
status: 'pending',
|
|
105
|
+
direction: 'received',
|
|
106
|
+
});
|
|
107
|
+
|
|
108
|
+
// Create event share
|
|
109
|
+
const share = await client.eventShares.create({
|
|
110
|
+
entityType: 'part',
|
|
111
|
+
entityUidHex: '0x123...',
|
|
112
|
+
toOrganization: 'org-id',
|
|
113
|
+
});
|
|
114
|
+
|
|
115
|
+
// Accept event share
|
|
116
|
+
await client.eventShares.accept('share-id');
|
|
117
|
+
|
|
118
|
+
// Decline event share
|
|
119
|
+
await client.eventShares.decline('share-id');
|
|
120
|
+
|
|
121
|
+
// Cancel event share
|
|
122
|
+
await client.eventShares.cancel('share-id');
|
|
123
|
+
```
|
|
124
|
+
|
|
125
|
+
### Part Events
|
|
126
|
+
|
|
127
|
+
```typescript
|
|
128
|
+
// List part events
|
|
129
|
+
const events = await client.partEvents.list({ partId: 'part-id' });
|
|
130
|
+
|
|
131
|
+
// Create part event
|
|
132
|
+
const event = await client.partEvents.create({
|
|
133
|
+
eventType: 'inspected',
|
|
134
|
+
eventDate: '2024-01-01',
|
|
135
|
+
partId: 'part-id',
|
|
136
|
+
});
|
|
137
|
+
```
|
|
138
|
+
|
|
139
|
+
### Aircraft
|
|
140
|
+
|
|
141
|
+
```typescript
|
|
142
|
+
// List aircraft
|
|
143
|
+
const aircraft = await client.aircraft.list();
|
|
144
|
+
|
|
145
|
+
// Get single aircraft
|
|
146
|
+
const plane = await client.aircraft.get('aircraft-id');
|
|
147
|
+
|
|
148
|
+
// Create aircraft
|
|
149
|
+
const newAircraft = await client.aircraft.create({
|
|
150
|
+
registration: 'N12345',
|
|
151
|
+
msn: 'MSN123',
|
|
152
|
+
modelId: 'model-id',
|
|
153
|
+
});
|
|
154
|
+
```
|
|
155
|
+
|
|
156
|
+
### Organizations
|
|
157
|
+
|
|
158
|
+
```typescript
|
|
159
|
+
// Get organization
|
|
160
|
+
const org = await client.organizations.get('org-id');
|
|
161
|
+
```
|
|
162
|
+
|
|
163
|
+
### Users
|
|
164
|
+
|
|
165
|
+
```typescript
|
|
166
|
+
// Get user
|
|
167
|
+
const user = await client.users.get('user-id');
|
|
168
|
+
```
|
|
169
|
+
|
|
170
|
+
## Error Handling
|
|
171
|
+
|
|
172
|
+
```typescript
|
|
173
|
+
try {
|
|
174
|
+
const parts = await client.parts.list();
|
|
175
|
+
} catch (error) {
|
|
176
|
+
if (error.response?.status === 401) {
|
|
177
|
+
console.error('Authentication failed');
|
|
178
|
+
} else if (error.response?.status === 422) {
|
|
179
|
+
console.error('Validation errors:', error.formErrors);
|
|
180
|
+
} else {
|
|
181
|
+
console.error('Error:', error.message);
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
```
|
|
185
|
+
|
|
186
|
+
## TypeScript Support
|
|
187
|
+
|
|
188
|
+
This SDK is written in TypeScript and includes complete type definitions. All types are exported from the main package:
|
|
189
|
+
|
|
190
|
+
```typescript
|
|
191
|
+
import { AerochainClient, Part, PartEvent, EventShare, Organization } from 'aerochain-node-sdk';
|
|
192
|
+
```
|
|
193
|
+
|
|
194
|
+
## Contributing
|
|
195
|
+
|
|
196
|
+
We welcome contributions! Please see our [Contributing Guide](CONTRIBUTING.md) for details.
|
|
197
|
+
|
|
198
|
+
## Versioning
|
|
199
|
+
|
|
200
|
+
This project follows [Semantic Versioning](https://semver.org/). For the versions available, see the [tags on this repository](https://github.com/Wingleet/aerochain-node-sdk/tags).
|
|
201
|
+
|
|
202
|
+
See [CHANGELOG.md](CHANGELOG.md) for a detailed history of changes.
|
|
203
|
+
|
|
204
|
+
## Support
|
|
205
|
+
|
|
206
|
+
- **Documentation**: [FILTERS.md](FILTERS.md) for available filters
|
|
207
|
+
- **Issues**: [GitHub Issues](https://github.com/Wingleet/aerochain-node-sdk/issues)
|
|
208
|
+
- **Examples**: See the [examples](examples/) directory
|
|
209
|
+
|
|
210
|
+
## License
|
|
211
|
+
|
|
212
|
+
This project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details.
|
|
213
|
+
|
|
214
|
+
## Acknowledgments
|
|
215
|
+
|
|
216
|
+
Built with ❤️ by the Aerochain team for the aviation industry.
|
package/dist/auth.d.ts
ADDED
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { AxiosInstance, InternalAxiosRequestConfig } from 'axios';
|
|
2
|
+
export type AuthConfig = {
|
|
3
|
+
type: 'credentials';
|
|
4
|
+
email: string;
|
|
5
|
+
password: string;
|
|
6
|
+
} | {
|
|
7
|
+
type: 'apiKey';
|
|
8
|
+
apiKey: string;
|
|
9
|
+
};
|
|
10
|
+
export declare class AuthClient {
|
|
11
|
+
private baseURL;
|
|
12
|
+
private authConfig;
|
|
13
|
+
private token?;
|
|
14
|
+
private refreshToken?;
|
|
15
|
+
private tokenExpiresAt?;
|
|
16
|
+
private refreshPromise?;
|
|
17
|
+
constructor(baseURL: string, authConfig: AuthConfig);
|
|
18
|
+
initialize(): Promise<void>;
|
|
19
|
+
private login;
|
|
20
|
+
private refreshAccessToken;
|
|
21
|
+
private isTokenExpired;
|
|
22
|
+
getValidToken(): Promise<string | undefined>;
|
|
23
|
+
applyAuthToRequest(config: InternalAxiosRequestConfig): InternalAxiosRequestConfig;
|
|
24
|
+
handleAuthError(error: any, axiosInstance: AxiosInstance): Promise<any>;
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=auth.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.d.ts","sourceRoot":"","sources":["../src/auth.ts"],"names":[],"mappings":"AAAA,OAAc,EAAE,aAAa,EAAE,0BAA0B,EAAE,MAAM,OAAO,CAAC;AAGzE,MAAM,MAAM,UAAU,GAClB;IAAE,IAAI,EAAE,aAAa,CAAC;IAAC,KAAK,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAA;CAAE,GACxD;IAAE,IAAI,EAAE,QAAQ,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,CAAC;AAEvC,qBAAa,UAAU;IACrB,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,UAAU,CAAa;IAC/B,OAAO,CAAC,KAAK,CAAC,CAAS;IACvB,OAAO,CAAC,YAAY,CAAC,CAAS;IAC9B,OAAO,CAAC,cAAc,CAAC,CAAS;IAChC,OAAO,CAAC,cAAc,CAAC,CAAkB;gBAE7B,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,UAAU;IAK7C,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;YAMnB,KAAK;YAkBL,kBAAkB;IA8BhC,OAAO,CAAC,cAAc;IAKhB,aAAa,IAAI,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC;IAYlD,kBAAkB,CAAC,MAAM,EAAE,0BAA0B,GAAG,0BAA0B;IAS5E,eAAe,CAAC,KAAK,EAAE,GAAG,EAAE,aAAa,EAAE,aAAa,GAAG,OAAO,CAAC,GAAG,CAAC;CAyB9E"}
|
package/dist/auth.js
ADDED
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import axios from 'axios';
|
|
2
|
+
export class AuthClient {
|
|
3
|
+
constructor(baseURL, authConfig) {
|
|
4
|
+
this.baseURL = baseURL;
|
|
5
|
+
this.authConfig = authConfig;
|
|
6
|
+
}
|
|
7
|
+
async initialize() {
|
|
8
|
+
if (this.authConfig.type === 'credentials') {
|
|
9
|
+
await this.login();
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
async login() {
|
|
13
|
+
if (this.authConfig.type !== 'credentials') {
|
|
14
|
+
throw new Error('Login requires credentials auth type');
|
|
15
|
+
}
|
|
16
|
+
const response = await axios.post(`${this.baseURL}/login`, {
|
|
17
|
+
email: this.authConfig.email,
|
|
18
|
+
password: this.authConfig.password,
|
|
19
|
+
});
|
|
20
|
+
const { token, refreshToken, expiresIn } = response.data.data;
|
|
21
|
+
this.token = token;
|
|
22
|
+
this.refreshToken = refreshToken;
|
|
23
|
+
const expiresInMs = parseInt(expiresIn) * 1000;
|
|
24
|
+
this.tokenExpiresAt = Date.now() + expiresInMs;
|
|
25
|
+
}
|
|
26
|
+
async refreshAccessToken() {
|
|
27
|
+
if (this.refreshPromise) {
|
|
28
|
+
return this.refreshPromise;
|
|
29
|
+
}
|
|
30
|
+
this.refreshPromise = (async () => {
|
|
31
|
+
try {
|
|
32
|
+
if (!this.refreshToken) {
|
|
33
|
+
throw new Error('No refresh token available');
|
|
34
|
+
}
|
|
35
|
+
const response = await axios.post(`${this.baseURL}/refresh-token`, {
|
|
36
|
+
refreshToken: this.refreshToken,
|
|
37
|
+
});
|
|
38
|
+
const { token, expiresIn } = response.data.data;
|
|
39
|
+
this.token = token;
|
|
40
|
+
const expiresInMs = parseInt(expiresIn) * 1000;
|
|
41
|
+
this.tokenExpiresAt = Date.now() + expiresInMs;
|
|
42
|
+
return token;
|
|
43
|
+
}
|
|
44
|
+
finally {
|
|
45
|
+
this.refreshPromise = undefined;
|
|
46
|
+
}
|
|
47
|
+
})();
|
|
48
|
+
return this.refreshPromise;
|
|
49
|
+
}
|
|
50
|
+
isTokenExpired() {
|
|
51
|
+
if (!this.tokenExpiresAt)
|
|
52
|
+
return true;
|
|
53
|
+
return Date.now() >= this.tokenExpiresAt - 60000;
|
|
54
|
+
}
|
|
55
|
+
async getValidToken() {
|
|
56
|
+
if (this.authConfig.type === 'apiKey') {
|
|
57
|
+
return undefined;
|
|
58
|
+
}
|
|
59
|
+
if (this.isTokenExpired() && this.refreshToken) {
|
|
60
|
+
await this.refreshAccessToken();
|
|
61
|
+
}
|
|
62
|
+
return this.token;
|
|
63
|
+
}
|
|
64
|
+
applyAuthToRequest(config) {
|
|
65
|
+
if (this.authConfig.type === 'apiKey') {
|
|
66
|
+
config.headers['X-API-Key'] = this.authConfig.apiKey;
|
|
67
|
+
}
|
|
68
|
+
else if (this.token) {
|
|
69
|
+
config.headers['Authorization'] = `Bearer ${this.token}`;
|
|
70
|
+
}
|
|
71
|
+
return config;
|
|
72
|
+
}
|
|
73
|
+
async handleAuthError(error, axiosInstance) {
|
|
74
|
+
if (error?.response?.status !== 401) {
|
|
75
|
+
return Promise.reject(error);
|
|
76
|
+
}
|
|
77
|
+
const originalRequest = error.config;
|
|
78
|
+
const isAuthRoute = originalRequest.url && /\/(login|refresh-token)(\/|$)/.test(originalRequest.url);
|
|
79
|
+
if (isAuthRoute || originalRequest._retry || this.authConfig.type === 'apiKey') {
|
|
80
|
+
return Promise.reject(error);
|
|
81
|
+
}
|
|
82
|
+
try {
|
|
83
|
+
const newToken = await this.refreshAccessToken();
|
|
84
|
+
const newRequest = { ...originalRequest };
|
|
85
|
+
newRequest._retry = true;
|
|
86
|
+
newRequest.headers['Authorization'] = `Bearer ${newToken}`;
|
|
87
|
+
return axiosInstance(newRequest);
|
|
88
|
+
}
|
|
89
|
+
catch (refreshError) {
|
|
90
|
+
return Promise.reject(refreshError);
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
}
|
package/dist/client.d.ts
ADDED
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { AuthConfig } from './auth.js';
|
|
2
|
+
import { PartsClient } from './clients/parts.js';
|
|
3
|
+
import { EventSharesClient } from './clients/event-shares.js';
|
|
4
|
+
import { PartEventsClient } from './clients/part-events.js';
|
|
5
|
+
import { PartModelsClient } from './clients/part-models.js';
|
|
6
|
+
import { AircraftClient } from './clients/aircraft.js';
|
|
7
|
+
import { AircraftEventsClient } from './clients/aircraft-events.js';
|
|
8
|
+
import { AircraftModelsClient } from './clients/aircraft-models.js';
|
|
9
|
+
import { OrganizationsClient } from './clients/organizations.js';
|
|
10
|
+
import { UsersClient } from './clients/users.js';
|
|
11
|
+
import { PartnershipsClient } from './clients/partnerships.js';
|
|
12
|
+
import { DashboardClient } from './clients/dashboard.js';
|
|
13
|
+
import { DocumentsClient } from './clients/documents.js';
|
|
14
|
+
import { AtaChaptersClient } from './clients/ata-chapters.js';
|
|
15
|
+
import { RegistryClient } from './clients/registry.js';
|
|
16
|
+
export type AerochainClientConfig = {
|
|
17
|
+
baseURL: string;
|
|
18
|
+
auth: AuthConfig;
|
|
19
|
+
timeout?: number;
|
|
20
|
+
};
|
|
21
|
+
export declare class AerochainClient {
|
|
22
|
+
private http;
|
|
23
|
+
private authClient;
|
|
24
|
+
parts: PartsClient;
|
|
25
|
+
eventShares: EventSharesClient;
|
|
26
|
+
partEvents: PartEventsClient;
|
|
27
|
+
partModels: PartModelsClient;
|
|
28
|
+
aircraft: AircraftClient;
|
|
29
|
+
aircraftEvents: AircraftEventsClient;
|
|
30
|
+
aircraftModels: AircraftModelsClient;
|
|
31
|
+
organizations: OrganizationsClient;
|
|
32
|
+
users: UsersClient;
|
|
33
|
+
partnerships: PartnershipsClient;
|
|
34
|
+
dashboard: DashboardClient;
|
|
35
|
+
documents: DocumentsClient;
|
|
36
|
+
ataChapters: AtaChaptersClient;
|
|
37
|
+
registry: RegistryClient;
|
|
38
|
+
constructor(config: AerochainClientConfig);
|
|
39
|
+
initialize(): Promise<void>;
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=client.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":"AACA,OAAO,EAAc,UAAU,EAAE,MAAM,WAAW,CAAC;AAEnD,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AACjD,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAC9D,OAAO,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAC5D,OAAO,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAC5D,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AACvD,OAAO,EAAE,oBAAoB,EAAE,MAAM,8BAA8B,CAAC;AACpE,OAAO,EAAE,oBAAoB,EAAE,MAAM,8BAA8B,CAAC;AACpE,OAAO,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AACjE,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AACjD,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;AAC/D,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AACzD,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AACzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAC9D,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAEvD,MAAM,MAAM,qBAAqB,GAAG;IAClC,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,UAAU,CAAC;IACjB,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB,CAAC;AAEF,qBAAa,eAAe;IAC1B,OAAO,CAAC,IAAI,CAAgB;IAC5B,OAAO,CAAC,UAAU,CAAa;IAExB,KAAK,EAAE,WAAW,CAAC;IACnB,WAAW,EAAE,iBAAiB,CAAC;IAC/B,UAAU,EAAE,gBAAgB,CAAC;IAC7B,UAAU,EAAE,gBAAgB,CAAC;IAC7B,QAAQ,EAAE,cAAc,CAAC;IACzB,cAAc,EAAE,oBAAoB,CAAC;IACrC,cAAc,EAAE,oBAAoB,CAAC;IACrC,aAAa,EAAE,mBAAmB,CAAC;IACnC,KAAK,EAAE,WAAW,CAAC;IACnB,YAAY,EAAE,kBAAkB,CAAC;IACjC,SAAS,EAAE,eAAe,CAAC;IAC3B,SAAS,EAAE,eAAe,CAAC;IAC3B,WAAW,EAAE,iBAAiB,CAAC;IAC/B,QAAQ,EAAE,cAAc,CAAC;gBAEpB,MAAM,EAAE,qBAAqB;IA8BnC,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;CAGlC"}
|
package/dist/client.js
ADDED
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { AuthClient } from './auth.js';
|
|
2
|
+
import { createHttpClient } from './http-client.js';
|
|
3
|
+
import { PartsClient } from './clients/parts.js';
|
|
4
|
+
import { EventSharesClient } from './clients/event-shares.js';
|
|
5
|
+
import { PartEventsClient } from './clients/part-events.js';
|
|
6
|
+
import { PartModelsClient } from './clients/part-models.js';
|
|
7
|
+
import { AircraftClient } from './clients/aircraft.js';
|
|
8
|
+
import { AircraftEventsClient } from './clients/aircraft-events.js';
|
|
9
|
+
import { AircraftModelsClient } from './clients/aircraft-models.js';
|
|
10
|
+
import { OrganizationsClient } from './clients/organizations.js';
|
|
11
|
+
import { UsersClient } from './clients/users.js';
|
|
12
|
+
import { PartnershipsClient } from './clients/partnerships.js';
|
|
13
|
+
import { DashboardClient } from './clients/dashboard.js';
|
|
14
|
+
import { DocumentsClient } from './clients/documents.js';
|
|
15
|
+
import { AtaChaptersClient } from './clients/ata-chapters.js';
|
|
16
|
+
import { RegistryClient } from './clients/registry.js';
|
|
17
|
+
export class AerochainClient {
|
|
18
|
+
constructor(config) {
|
|
19
|
+
this.http = createHttpClient(config.baseURL, config.timeout);
|
|
20
|
+
this.authClient = new AuthClient(config.baseURL, config.auth);
|
|
21
|
+
this.http.interceptors.request.use(async (requestConfig) => {
|
|
22
|
+
await this.authClient.getValidToken();
|
|
23
|
+
return this.authClient.applyAuthToRequest(requestConfig);
|
|
24
|
+
});
|
|
25
|
+
this.http.interceptors.response.use((response) => response, (error) => this.authClient.handleAuthError(error, this.http));
|
|
26
|
+
this.parts = new PartsClient(this.http);
|
|
27
|
+
this.eventShares = new EventSharesClient(this.http);
|
|
28
|
+
this.partEvents = new PartEventsClient(this.http);
|
|
29
|
+
this.partModels = new PartModelsClient(this.http);
|
|
30
|
+
this.aircraft = new AircraftClient(this.http);
|
|
31
|
+
this.aircraftEvents = new AircraftEventsClient(this.http);
|
|
32
|
+
this.aircraftModels = new AircraftModelsClient(this.http);
|
|
33
|
+
this.organizations = new OrganizationsClient(this.http);
|
|
34
|
+
this.users = new UsersClient(this.http);
|
|
35
|
+
this.partnerships = new PartnershipsClient(this.http);
|
|
36
|
+
this.dashboard = new DashboardClient(this.http);
|
|
37
|
+
this.documents = new DocumentsClient(this.http);
|
|
38
|
+
this.ataChapters = new AtaChaptersClient(this.http);
|
|
39
|
+
this.registry = new RegistryClient(this.http);
|
|
40
|
+
}
|
|
41
|
+
async initialize() {
|
|
42
|
+
await this.authClient.initialize();
|
|
43
|
+
}
|
|
44
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { AxiosInstance } from 'axios';
|
|
2
|
+
import { AircraftEvent, CreateAircraftEventPayload, PagedCollection } from '../types.js';
|
|
3
|
+
export declare class AircraftEventsClient {
|
|
4
|
+
private http;
|
|
5
|
+
constructor(http: AxiosInstance);
|
|
6
|
+
list(options?: {
|
|
7
|
+
page?: string;
|
|
8
|
+
filters?: {
|
|
9
|
+
[key: string]: string;
|
|
10
|
+
};
|
|
11
|
+
}): Promise<PagedCollection<AircraftEvent>>;
|
|
12
|
+
get(id: string): Promise<AircraftEvent>;
|
|
13
|
+
create(payload: CreateAircraftEventPayload): Promise<AircraftEvent>;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=aircraft-events.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"aircraft-events.d.ts","sourceRoot":"","sources":["../../src/clients/aircraft-events.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AACtC,OAAO,EAAE,aAAa,EAAE,0BAA0B,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAGzF,qBAAa,oBAAoB;IACnB,OAAO,CAAC,IAAI;gBAAJ,IAAI,EAAE,aAAa;IAEjC,IAAI,CAAC,OAAO,CAAC,EAAE;QACnB,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,OAAO,CAAC,EAAE;YAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAAA;SAAE,CAAC;KACrC,GAAG,OAAO,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC;IAQrC,GAAG,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,CAAC;IAKvC,MAAM,CAAC,OAAO,EAAE,0BAA0B,GAAG,OAAO,CAAC,aAAa,CAAC;CAI1E"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { formatApiParams } from '../http-client.js';
|
|
2
|
+
export class AircraftEventsClient {
|
|
3
|
+
constructor(http) {
|
|
4
|
+
this.http = http;
|
|
5
|
+
}
|
|
6
|
+
async list(options) {
|
|
7
|
+
const params = formatApiParams(options?.page, options?.filters);
|
|
8
|
+
const response = await this.http.get('/aircraft_events', {
|
|
9
|
+
params,
|
|
10
|
+
});
|
|
11
|
+
return response.data;
|
|
12
|
+
}
|
|
13
|
+
async get(id) {
|
|
14
|
+
const response = await this.http.get(`/aircraft_events/${id}`);
|
|
15
|
+
return response.data;
|
|
16
|
+
}
|
|
17
|
+
async create(payload) {
|
|
18
|
+
const response = await this.http.post('/aircraft_events', payload);
|
|
19
|
+
return response.data;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { AxiosInstance } from 'axios';
|
|
2
|
+
import { AircraftModel, PagedCollection } from '../types.js';
|
|
3
|
+
export declare class AircraftModelsClient {
|
|
4
|
+
private http;
|
|
5
|
+
constructor(http: AxiosInstance);
|
|
6
|
+
list(options?: {
|
|
7
|
+
page?: string;
|
|
8
|
+
filters?: {
|
|
9
|
+
[key: string]: string;
|
|
10
|
+
};
|
|
11
|
+
}): Promise<PagedCollection<AircraftModel>>;
|
|
12
|
+
get(id: string): Promise<AircraftModel>;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=aircraft-models.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"aircraft-models.d.ts","sourceRoot":"","sources":["../../src/clients/aircraft-models.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AACtC,OAAO,EAAE,aAAa,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAG7D,qBAAa,oBAAoB;IACnB,OAAO,CAAC,IAAI;gBAAJ,IAAI,EAAE,aAAa;IAEjC,IAAI,CAAC,OAAO,CAAC,EAAE;QACnB,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,OAAO,CAAC,EAAE;YAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAAA;SAAE,CAAC;KACrC,GAAG,OAAO,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC;IAQrC,GAAG,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,CAAC;CAI9C"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { formatApiParams } from '../http-client.js';
|
|
2
|
+
export class AircraftModelsClient {
|
|
3
|
+
constructor(http) {
|
|
4
|
+
this.http = http;
|
|
5
|
+
}
|
|
6
|
+
async list(options) {
|
|
7
|
+
const params = formatApiParams(options?.page, options?.filters);
|
|
8
|
+
const response = await this.http.get('/aircraft_models', {
|
|
9
|
+
params,
|
|
10
|
+
});
|
|
11
|
+
return response.data;
|
|
12
|
+
}
|
|
13
|
+
async get(id) {
|
|
14
|
+
const response = await this.http.get(`/aircraft_models/${id}`);
|
|
15
|
+
return response.data;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { AxiosInstance } from 'axios';
|
|
2
|
+
import { Aircraft, CreateAircraftPayload, PagedCollection } from '../types.js';
|
|
3
|
+
export declare class AircraftClient {
|
|
4
|
+
private http;
|
|
5
|
+
constructor(http: AxiosInstance);
|
|
6
|
+
list(options?: {
|
|
7
|
+
page?: string;
|
|
8
|
+
filters?: {
|
|
9
|
+
[key: string]: string;
|
|
10
|
+
};
|
|
11
|
+
}): Promise<PagedCollection<Aircraft>>;
|
|
12
|
+
get(id: string): Promise<Aircraft>;
|
|
13
|
+
create(payload: CreateAircraftPayload): Promise<Aircraft>;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=aircraft.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"aircraft.d.ts","sourceRoot":"","sources":["../../src/clients/aircraft.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AACtC,OAAO,EAAE,QAAQ,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAG/E,qBAAa,cAAc;IACb,OAAO,CAAC,IAAI;gBAAJ,IAAI,EAAE,aAAa;IAEjC,IAAI,CAAC,OAAO,CAAC,EAAE;QACnB,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,OAAO,CAAC,EAAE;YAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAAA;SAAE,CAAC;KACrC,GAAG,OAAO,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;IAMhC,GAAG,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,QAAQ,CAAC;IAKlC,MAAM,CAAC,OAAO,EAAE,qBAAqB,GAAG,OAAO,CAAC,QAAQ,CAAC;CAIhE"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { formatApiParams } from '../http-client.js';
|
|
2
|
+
export class AircraftClient {
|
|
3
|
+
constructor(http) {
|
|
4
|
+
this.http = http;
|
|
5
|
+
}
|
|
6
|
+
async list(options) {
|
|
7
|
+
const params = formatApiParams(options?.page, options?.filters);
|
|
8
|
+
const response = await this.http.get('/aircraft', { params });
|
|
9
|
+
return response.data;
|
|
10
|
+
}
|
|
11
|
+
async get(id) {
|
|
12
|
+
const response = await this.http.get(`/aircraft/${id}`);
|
|
13
|
+
return response.data;
|
|
14
|
+
}
|
|
15
|
+
async create(payload) {
|
|
16
|
+
const response = await this.http.post('/aircraft', payload);
|
|
17
|
+
return response.data;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { AxiosInstance } from 'axios';
|
|
2
|
+
import { AtaChapter, PagedCollection } from '../types.js';
|
|
3
|
+
export declare class AtaChaptersClient {
|
|
4
|
+
private http;
|
|
5
|
+
constructor(http: AxiosInstance);
|
|
6
|
+
list(options?: {
|
|
7
|
+
page?: string;
|
|
8
|
+
filters?: {
|
|
9
|
+
[key: string]: string;
|
|
10
|
+
};
|
|
11
|
+
}): Promise<PagedCollection<AtaChapter>>;
|
|
12
|
+
get(id: string): Promise<AtaChapter>;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=ata-chapters.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ata-chapters.d.ts","sourceRoot":"","sources":["../../src/clients/ata-chapters.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AACtC,OAAO,EAAE,UAAU,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAG1D,qBAAa,iBAAiB;IAChB,OAAO,CAAC,IAAI;gBAAJ,IAAI,EAAE,aAAa;IAEjC,IAAI,CAAC,OAAO,CAAC,EAAE;QACnB,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,OAAO,CAAC,EAAE;YAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAAA;SAAE,CAAC;KACrC,GAAG,OAAO,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;IAMlC,GAAG,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC;CAI3C"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { formatApiParams } from '../http-client.js';
|
|
2
|
+
export class AtaChaptersClient {
|
|
3
|
+
constructor(http) {
|
|
4
|
+
this.http = http;
|
|
5
|
+
}
|
|
6
|
+
async list(options) {
|
|
7
|
+
const params = formatApiParams(options?.page, options?.filters);
|
|
8
|
+
const response = await this.http.get('/ata_chapters', { params });
|
|
9
|
+
return response.data;
|
|
10
|
+
}
|
|
11
|
+
async get(id) {
|
|
12
|
+
const response = await this.http.get(`/ata_chapters/${id}`);
|
|
13
|
+
return response.data;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dashboard.d.ts","sourceRoot":"","sources":["../../src/clients/dashboard.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AACtC,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAE5C,qBAAa,eAAe;IACd,OAAO,CAAC,IAAI;gBAAJ,IAAI,EAAE,aAAa;IAEjC,GAAG,IAAI,OAAO,CAAC,aAAa,CAAC;CAIpC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { AxiosInstance } from 'axios';
|
|
2
|
+
import { Document, PagedCollection } from '../types.js';
|
|
3
|
+
export declare class DocumentsClient {
|
|
4
|
+
private http;
|
|
5
|
+
constructor(http: AxiosInstance);
|
|
6
|
+
list(options?: {
|
|
7
|
+
page?: string;
|
|
8
|
+
filters?: {
|
|
9
|
+
[key: string]: string;
|
|
10
|
+
};
|
|
11
|
+
}): Promise<PagedCollection<Document>>;
|
|
12
|
+
get(id: string): Promise<Document>;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=documents.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"documents.d.ts","sourceRoot":"","sources":["../../src/clients/documents.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AACtC,OAAO,EAAE,QAAQ,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAGxD,qBAAa,eAAe;IACd,OAAO,CAAC,IAAI;gBAAJ,IAAI,EAAE,aAAa;IAEjC,IAAI,CAAC,OAAO,CAAC,EAAE;QACnB,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,OAAO,CAAC,EAAE;YAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAAA;SAAE,CAAC;KACrC,GAAG,OAAO,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;IAMhC,GAAG,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,QAAQ,CAAC;CAIzC"}
|