@nesalia/cli 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/.turbo/turbo-build.log +4 -0
- package/dist/commands/auth/index.d.ts +4 -0
- package/dist/commands/auth/index.d.ts.map +1 -0
- package/dist/commands/auth/index.js +4 -0
- package/dist/commands/auth/index.js.map +1 -0
- package/dist/commands/auth/login.d.ts +2 -0
- package/dist/commands/auth/login.d.ts.map +1 -0
- package/dist/commands/auth/login.js +19 -0
- package/dist/commands/auth/login.js.map +1 -0
- package/dist/commands/auth/logout.d.ts +2 -0
- package/dist/commands/auth/logout.d.ts.map +1 -0
- package/dist/commands/auth/logout.js +23 -0
- package/dist/commands/auth/logout.js.map +1 -0
- package/dist/commands/auth/status.d.ts +2 -0
- package/dist/commands/auth/status.d.ts.map +1 -0
- package/dist/commands/auth/status.js +33 -0
- package/dist/commands/auth/status.js.map +1 -0
- package/dist/commands/index.d.ts +2 -0
- package/dist/commands/index.d.ts.map +1 -0
- package/dist/commands/index.js +2 -0
- package/dist/commands/index.js.map +1 -0
- package/dist/commands/post/by-id.d.ts +6 -0
- package/dist/commands/post/by-id.d.ts.map +1 -0
- package/dist/commands/post/by-id.js +32 -0
- package/dist/commands/post/by-id.js.map +1 -0
- package/dist/commands/post/create.d.ts +7 -0
- package/dist/commands/post/create.d.ts.map +1 -0
- package/dist/commands/post/create.js +35 -0
- package/dist/commands/post/create.js.map +1 -0
- package/dist/commands/post/index.d.ts +4 -0
- package/dist/commands/post/index.d.ts.map +1 -0
- package/dist/commands/post/index.js +4 -0
- package/dist/commands/post/index.js.map +1 -0
- package/dist/commands/post/list.d.ts +2 -0
- package/dist/commands/post/list.d.ts.map +1 -0
- package/dist/commands/post/list.js +35 -0
- package/dist/commands/post/list.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +22 -0
- package/dist/index.js.map +1 -0
- package/dist/lib/api/client.d.ts +17 -0
- package/dist/lib/api/client.d.ts.map +1 -0
- package/dist/lib/api/client.js +18 -0
- package/dist/lib/api/client.js.map +1 -0
- package/dist/lib/auth/client.d.ts +2748 -0
- package/dist/lib/auth/client.d.ts.map +1 -0
- package/dist/lib/auth/client.js +11 -0
- package/dist/lib/auth/client.js.map +1 -0
- package/dist/lib/auth/device-flow/config.d.ts +5 -0
- package/dist/lib/auth/device-flow/config.d.ts.map +1 -0
- package/dist/lib/auth/device-flow/config.js +5 -0
- package/dist/lib/auth/device-flow/config.js.map +1 -0
- package/dist/lib/auth/device-flow/device-code.d.ts +10 -0
- package/dist/lib/auth/device-flow/device-code.d.ts.map +1 -0
- package/dist/lib/auth/device-flow/device-code.js +27 -0
- package/dist/lib/auth/device-flow/device-code.js.map +1 -0
- package/dist/lib/auth/device-flow/errors.d.ts +8 -0
- package/dist/lib/auth/device-flow/errors.d.ts.map +1 -0
- package/dist/lib/auth/device-flow/errors.js +26 -0
- package/dist/lib/auth/device-flow/errors.js.map +1 -0
- package/dist/lib/auth/device-flow/index.d.ts +3 -0
- package/dist/lib/auth/device-flow/index.d.ts.map +1 -0
- package/dist/lib/auth/device-flow/index.js +13 -0
- package/dist/lib/auth/device-flow/index.js.map +1 -0
- package/dist/lib/auth/device-flow/polling.d.ts +4 -0
- package/dist/lib/auth/device-flow/polling.d.ts.map +1 -0
- package/dist/lib/auth/device-flow/polling.js +75 -0
- package/dist/lib/auth/device-flow/polling.js.map +1 -0
- package/dist/lib/auth/device-flow/types.d.ts +10 -0
- package/dist/lib/auth/device-flow/types.d.ts.map +1 -0
- package/dist/lib/auth/device-flow/types.js +2 -0
- package/dist/lib/auth/device-flow/types.js.map +1 -0
- package/dist/lib/auth/index.d.ts +12 -0
- package/dist/lib/auth/index.d.ts.map +1 -0
- package/dist/lib/auth/index.js +24 -0
- package/dist/lib/auth/index.js.map +1 -0
- package/dist/lib/auth/storage.d.ts +20 -0
- package/dist/lib/auth/storage.d.ts.map +1 -0
- package/dist/lib/auth/storage.js +48 -0
- package/dist/lib/auth/storage.js.map +1 -0
- package/package.json +36 -0
- package/src/CLAUDE.md +83 -0
- package/src/commands/auth/index.ts +3 -0
- package/src/commands/auth/login.ts +20 -0
- package/src/commands/auth/logout.ts +25 -0
- package/src/commands/auth/status.ts +37 -0
- package/src/commands/index.ts +1 -0
- package/src/index.ts +32 -0
- package/src/lib/api/client.ts +20 -0
- package/src/lib/auth/client.ts +14 -0
- package/src/lib/auth/device-flow/config.ts +4 -0
- package/src/lib/auth/device-flow/device-code.ts +39 -0
- package/src/lib/auth/device-flow/errors.ts +29 -0
- package/src/lib/auth/device-flow/index.ts +19 -0
- package/src/lib/auth/device-flow/polling.ts +91 -0
- package/src/lib/auth/device-flow/types.ts +9 -0
- package/src/lib/auth/index.ts +41 -0
- package/src/lib/auth/storage.ts +69 -0
- package/tests/auth.test.ts +123 -0
- package/tests/setup.ts +43 -0
- package/tsconfig.json +19 -0
- package/vitest.config.ts +9 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/commands/auth/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAC;AACnC,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/commands/auth/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAC;AACnC,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"login.d.ts","sourceRoot":"","sources":["../../../src/commands/auth/login.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,KAAK,QAAa,OAAO,CAAC,IAAI,CAgB1C,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { log } from "@clack/prompts";
|
|
2
|
+
import { saveCredentials, startDeviceFlow } from "../../lib/auth/index.js";
|
|
3
|
+
export const login = async () => {
|
|
4
|
+
try {
|
|
5
|
+
const result = await startDeviceFlow();
|
|
6
|
+
const credentials = {
|
|
7
|
+
accessToken: result.accessToken,
|
|
8
|
+
user: result.user,
|
|
9
|
+
expiresAt: Date.now() + 30 * 24 * 60 * 60 * 1000, // 30 days
|
|
10
|
+
};
|
|
11
|
+
saveCredentials(credentials);
|
|
12
|
+
log.success("Successfully logged in!");
|
|
13
|
+
}
|
|
14
|
+
catch (error) {
|
|
15
|
+
log.error(error instanceof Error ? error.message : "Unknown error");
|
|
16
|
+
process.exit(1);
|
|
17
|
+
}
|
|
18
|
+
};
|
|
19
|
+
//# sourceMappingURL=login.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"login.js","sourceRoot":"","sources":["../../../src/commands/auth/login.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAE,eAAe,EAA0B,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAEnG,MAAM,CAAC,MAAM,KAAK,GAAG,KAAK,IAAmB,EAAE;IAC7C,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,MAAM,eAAe,EAAE,CAAC;QAEvC,MAAM,WAAW,GAAsB;YACrC,WAAW,EAAE,MAAM,CAAC,WAAW;YAC/B,IAAI,EAAE,MAAM,CAAC,IAAI;YACjB,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,UAAU;SAC7D,CAAC;QAEF,eAAe,CAAC,WAAW,CAAC,CAAC;QAC7B,GAAG,CAAC,OAAO,CAAC,yBAAyB,CAAC,CAAC;IACzC,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,GAAG,CAAC,KAAK,CAAC,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC;QACpE,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;AACH,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logout.d.ts","sourceRoot":"","sources":["../../../src/commands/auth/logout.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,MAAM,QAAa,OAAO,CAAC,IAAI,CAqB3C,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { log } from "@clack/prompts";
|
|
2
|
+
import { loadCredentials, clearCredentials, authClient } from "../../lib/auth/index.js";
|
|
3
|
+
export const logout = async () => {
|
|
4
|
+
const credentials = loadCredentials();
|
|
5
|
+
if (!credentials) {
|
|
6
|
+
log.info("Not logged in.");
|
|
7
|
+
return;
|
|
8
|
+
}
|
|
9
|
+
// Invalidate token on the server (best effort)
|
|
10
|
+
try {
|
|
11
|
+
await authClient.signOut({
|
|
12
|
+
fetchOptions: {
|
|
13
|
+
headers: { Authorization: `Bearer ${credentials.accessToken}` },
|
|
14
|
+
},
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
catch {
|
|
18
|
+
// Non-fatal: the token might already be expired or revoked
|
|
19
|
+
}
|
|
20
|
+
clearCredentials();
|
|
21
|
+
log.success("Successfully logged out.");
|
|
22
|
+
};
|
|
23
|
+
//# sourceMappingURL=logout.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logout.js","sourceRoot":"","sources":["../../../src/commands/auth/logout.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAE,eAAe,EAAE,gBAAgB,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AAExF,MAAM,CAAC,MAAM,MAAM,GAAG,KAAK,IAAmB,EAAE;IAC9C,MAAM,WAAW,GAAG,eAAe,EAAE,CAAC;IAEtC,IAAI,CAAC,WAAW,EAAE,CAAC;QACjB,GAAG,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;QAC3B,OAAO;IACT,CAAC;IAED,+CAA+C;IAC/C,IAAI,CAAC;QACH,MAAM,UAAU,CAAC,OAAO,CAAC;YACvB,YAAY,EAAE;gBACZ,OAAO,EAAE,EAAE,aAAa,EAAE,UAAU,WAAW,CAAC,WAAW,EAAE,EAAE;aAChE;SACF,CAAC,CAAC;IACL,CAAC;IAAC,MAAM,CAAC;QACP,2DAA2D;IAC7D,CAAC;IAED,gBAAgB,EAAE,CAAC;IACnB,GAAG,CAAC,OAAO,CAAC,0BAA0B,CAAC,CAAC;AAC1C,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"status.d.ts","sourceRoot":"","sources":["../../../src/commands/auth/status.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,MAAM,QAAa,OAAO,CAAC,IAAI,CAiC3C,CAAC"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { log } from "@clack/prompts";
|
|
2
|
+
import { loadCredentials, clearCredentials, isExpired, authClient } from "../../lib/auth/index.js";
|
|
3
|
+
export const status = async () => {
|
|
4
|
+
const credentials = loadCredentials();
|
|
5
|
+
if (!credentials) {
|
|
6
|
+
log.info("Not logged in. Run 'auth login' to authenticate.");
|
|
7
|
+
return;
|
|
8
|
+
}
|
|
9
|
+
if (isExpired(credentials)) {
|
|
10
|
+
log.warn("Session expired. Run 'auth login' to authenticate again.");
|
|
11
|
+
clearCredentials();
|
|
12
|
+
return;
|
|
13
|
+
}
|
|
14
|
+
// Verify the session with the server
|
|
15
|
+
try {
|
|
16
|
+
const response = await authClient.getSession({
|
|
17
|
+
fetchOptions: {
|
|
18
|
+
headers: { Authorization: `Bearer ${credentials.accessToken}` },
|
|
19
|
+
},
|
|
20
|
+
});
|
|
21
|
+
if (response?.data?.user) {
|
|
22
|
+
const { name, email } = response.data.user;
|
|
23
|
+
log.success(`Logged in as ${name} (${email})`);
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
catch (error) {
|
|
28
|
+
log.warn(`Could not verify session with server — using cached credentials.`);
|
|
29
|
+
}
|
|
30
|
+
// Fall back to local credentials
|
|
31
|
+
log.success(`Logged in as ${credentials.user.name} (${credentials.user.email})`);
|
|
32
|
+
};
|
|
33
|
+
//# sourceMappingURL=status.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"status.js","sourceRoot":"","sources":["../../../src/commands/auth/status.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAE,eAAe,EAAE,gBAAgB,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AAEnG,MAAM,CAAC,MAAM,MAAM,GAAG,KAAK,IAAmB,EAAE;IAC9C,MAAM,WAAW,GAAG,eAAe,EAAE,CAAC;IAEtC,IAAI,CAAC,WAAW,EAAE,CAAC;QACjB,GAAG,CAAC,IAAI,CAAC,kDAAkD,CAAC,CAAC;QAC7D,OAAO;IACT,CAAC;IAED,IAAI,SAAS,CAAC,WAAW,CAAC,EAAE,CAAC;QAC3B,GAAG,CAAC,IAAI,CAAC,0DAA0D,CAAC,CAAC;QACrE,gBAAgB,EAAE,CAAC;QACnB,OAAO;IACT,CAAC;IAED,qCAAqC;IACrC,IAAI,CAAC;QACH,MAAM,QAAQ,GAAG,MAAM,UAAU,CAAC,UAAU,CAAC;YAC3C,YAAY,EAAE;gBACZ,OAAO,EAAE,EAAE,aAAa,EAAE,UAAU,WAAW,CAAC,WAAW,EAAE,EAAE;aAChE;SACF,CAAC,CAAC;QAEH,IAAI,QAAQ,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;YACzB,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC;YAC3C,GAAG,CAAC,OAAO,CAAC,gBAAgB,IAAI,KAAK,KAAK,GAAG,CAAC,CAAC;YAC/C,OAAO;QACT,CAAC;IACH,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,GAAG,CAAC,IAAI,CAAC,kEAAkE,CAAC,CAAC;IAC/E,CAAC;IAED,iCAAiC;IACjC,GAAG,CAAC,OAAO,CAAC,gBAAgB,WAAW,CAAC,IAAI,CAAC,IAAI,KAAK,WAAW,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;AACnF,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/commands/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/commands/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"by-id.d.ts","sourceRoot":"","sources":["../../../src/commands/post/by-id.ts"],"names":[],"mappings":"AAIA,UAAU,WAAW;IACnB,EAAE,EAAE,MAAM,CAAC;CACZ;AAED,eAAO,MAAM,IAAI,GAAU,QAAQ,WAAW,KAAG,OAAO,CAAC,IAAI,CA4B5D,CAAC"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { log } from "@clack/prompts";
|
|
2
|
+
import { trpcClient } from "../../lib/api/client.js";
|
|
3
|
+
import { requireAuth } from "../../lib/auth/storage.js";
|
|
4
|
+
export const byId = async ({ id }) => {
|
|
5
|
+
try {
|
|
6
|
+
requireAuth(); // Ensure user is logged in
|
|
7
|
+
log.info(`Fetching post #${id}...`);
|
|
8
|
+
const post = await trpcClient.post.byId.query({ id });
|
|
9
|
+
if (!post) {
|
|
10
|
+
log.warn(`Post #${id} not found.`);
|
|
11
|
+
return;
|
|
12
|
+
}
|
|
13
|
+
log.success(`Post #${id}:`);
|
|
14
|
+
console.log(` Title: ${post.title}`);
|
|
15
|
+
console.log(` Slug: ${post.slug}`);
|
|
16
|
+
console.log(` ID: ${post.id}`);
|
|
17
|
+
}
|
|
18
|
+
catch (error) {
|
|
19
|
+
if (error && typeof error === "object" && "data" in error) {
|
|
20
|
+
const trpcError = error;
|
|
21
|
+
log.error(trpcError.data?.message ?? "Unknown error");
|
|
22
|
+
if (trpcError.data?.code) {
|
|
23
|
+
log.error(`Error code: ${trpcError.data.code}`);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
log.error(error instanceof Error ? error.message : "Unknown error");
|
|
28
|
+
}
|
|
29
|
+
process.exit(1);
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
//# sourceMappingURL=by-id.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"by-id.js","sourceRoot":"","sources":["../../../src/commands/post/by-id.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AAMxD,MAAM,CAAC,MAAM,IAAI,GAAG,KAAK,EAAE,EAAE,EAAE,EAAe,EAAiB,EAAE;IAC/D,IAAI,CAAC;QACH,WAAW,EAAE,CAAC,CAAC,2BAA2B;QAC1C,GAAG,CAAC,IAAI,CAAC,kBAAkB,EAAE,KAAK,CAAC,CAAC;QAEpC,MAAM,IAAI,GAAG,MAAM,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;QAEtD,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,GAAG,CAAC,IAAI,CAAC,SAAS,EAAE,aAAa,CAAC,CAAC;YACnC,OAAO;QACT,CAAC;QAED,GAAG,CAAC,OAAO,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC;QAC5B,OAAO,CAAC,GAAG,CAAC,YAAY,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;QACtC,OAAO,CAAC,GAAG,CAAC,YAAY,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;QACrC,OAAO,CAAC,GAAG,CAAC,YAAY,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC;IACrC,CAAC;IAAC,OAAO,KAAc,EAAE,CAAC;QACxB,IAAI,KAAK,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,MAAM,IAAI,KAAK,EAAE,CAAC;YAC1D,MAAM,SAAS,GAAG,KAAuD,CAAC;YAC1E,GAAG,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,EAAE,OAAO,IAAI,eAAe,CAAC,CAAC;YACtD,IAAI,SAAS,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC;gBACzB,GAAG,CAAC,KAAK,CAAC,eAAe,SAAS,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;YAClD,CAAC;QACH,CAAC;aAAM,CAAC;YACN,GAAG,CAAC,KAAK,CAAC,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC;QACtE,CAAC;QACD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;AACH,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create.d.ts","sourceRoot":"","sources":["../../../src/commands/post/create.ts"],"names":[],"mappings":"AAIA,UAAU,aAAa;IACrB,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;CACf;AAED,eAAO,MAAM,MAAM,GAAU,iBAAiB,aAAa,KAAG,OAAO,CAAC,IAAI,CA+BzE,CAAC"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { log } from "@clack/prompts";
|
|
2
|
+
import { trpcClient } from "../../lib/api/client.js";
|
|
3
|
+
import { requireAuth } from "../../lib/auth/storage.js";
|
|
4
|
+
export const create = async ({ title, slug }) => {
|
|
5
|
+
try {
|
|
6
|
+
requireAuth(); // Ensure user is logged in
|
|
7
|
+
log.info(`Creating post "${title}"...`);
|
|
8
|
+
const post = await trpcClient.post.create.mutate({
|
|
9
|
+
title,
|
|
10
|
+
slug,
|
|
11
|
+
});
|
|
12
|
+
if (!post) {
|
|
13
|
+
log.error("Failed to create post.");
|
|
14
|
+
return;
|
|
15
|
+
}
|
|
16
|
+
log.success(`Post created!`);
|
|
17
|
+
console.log(` ID: ${post.id}`);
|
|
18
|
+
console.log(` Title: ${post.title}`);
|
|
19
|
+
console.log(` Slug: ${post.slug}`);
|
|
20
|
+
}
|
|
21
|
+
catch (error) {
|
|
22
|
+
if (error && typeof error === "object" && "data" in error) {
|
|
23
|
+
const trpcError = error;
|
|
24
|
+
log.error(trpcError.data?.message ?? "Unknown error");
|
|
25
|
+
if (trpcError.data?.code) {
|
|
26
|
+
log.error(`Error code: ${trpcError.data.code}`);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
else {
|
|
30
|
+
log.error(error instanceof Error ? error.message : "Unknown error");
|
|
31
|
+
}
|
|
32
|
+
process.exit(1);
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
//# sourceMappingURL=create.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create.js","sourceRoot":"","sources":["../../../src/commands/post/create.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AAOxD,MAAM,CAAC,MAAM,MAAM,GAAG,KAAK,EAAE,EAAE,KAAK,EAAE,IAAI,EAAiB,EAAiB,EAAE;IAC5E,IAAI,CAAC;QACH,WAAW,EAAE,CAAC,CAAC,2BAA2B;QAC1C,GAAG,CAAC,IAAI,CAAC,kBAAkB,KAAK,MAAM,CAAC,CAAC;QAExC,MAAM,IAAI,GAAG,MAAM,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC;YAC/C,KAAK;YACL,IAAI;SACL,CAAC,CAAC;QAEH,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,GAAG,CAAC,KAAK,CAAC,wBAAwB,CAAC,CAAC;YACpC,OAAO;QACT,CAAC;QAED,GAAG,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;QAC7B,OAAO,CAAC,GAAG,CAAC,YAAY,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC;QACnC,OAAO,CAAC,GAAG,CAAC,YAAY,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;QACtC,OAAO,CAAC,GAAG,CAAC,YAAY,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;IACvC,CAAC;IAAC,OAAO,KAAc,EAAE,CAAC;QACxB,IAAI,KAAK,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,MAAM,IAAI,KAAK,EAAE,CAAC;YAC1D,MAAM,SAAS,GAAG,KAAuD,CAAC;YAC1E,GAAG,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,EAAE,OAAO,IAAI,eAAe,CAAC,CAAC;YACtD,IAAI,SAAS,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC;gBACzB,GAAG,CAAC,KAAK,CAAC,eAAe,SAAS,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;YAClD,CAAC;QACH,CAAC;aAAM,CAAC;YACN,GAAG,CAAC,KAAK,CAAC,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC;QACtE,CAAC;QACD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;AACH,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/commands/post/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,IAAI,EAAE,MAAM,YAAY,CAAC;AAClC,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/commands/post/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,IAAI,EAAE,MAAM,YAAY,CAAC;AAClC,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"list.d.ts","sourceRoot":"","sources":["../../../src/commands/post/list.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,IAAI,QAAa,OAAO,CAAC,IAAI,CAgCzC,CAAC"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { log } from "@clack/prompts";
|
|
2
|
+
import { trpcClient } from "../../lib/api/client.js";
|
|
3
|
+
import { requireAuth } from "../../lib/auth/storage.js";
|
|
4
|
+
export const list = async () => {
|
|
5
|
+
try {
|
|
6
|
+
requireAuth(); // Ensure user is logged in
|
|
7
|
+
log.info("Fetching posts...");
|
|
8
|
+
const result = await trpcClient.post.list.query({ limit: 20 });
|
|
9
|
+
if (result.items.length === 0) {
|
|
10
|
+
log.warn("No posts found.");
|
|
11
|
+
return;
|
|
12
|
+
}
|
|
13
|
+
log.success(`Found ${result.items.length} post(s):`);
|
|
14
|
+
for (const post of result.items) {
|
|
15
|
+
console.log(` [${post.id}] ${post.title} (slug: ${post.slug})`);
|
|
16
|
+
}
|
|
17
|
+
if (result.nextCursor !== undefined) {
|
|
18
|
+
log.info(`More posts available. Use --cursor ${result.nextCursor} to load more.`);
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
catch (error) {
|
|
22
|
+
if (error && typeof error === "object" && "data" in error) {
|
|
23
|
+
const trpcError = error;
|
|
24
|
+
log.error(trpcError.data?.message ?? "Unknown error");
|
|
25
|
+
if (trpcError.data?.code) {
|
|
26
|
+
log.error(`Error code: ${trpcError.data.code}`);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
else {
|
|
30
|
+
log.error(error instanceof Error ? error.message : "Unknown error");
|
|
31
|
+
}
|
|
32
|
+
process.exit(1);
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
//# sourceMappingURL=list.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"list.js","sourceRoot":"","sources":["../../../src/commands/post/list.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AAExD,MAAM,CAAC,MAAM,IAAI,GAAG,KAAK,IAAmB,EAAE;IAC5C,IAAI,CAAC;QACH,WAAW,EAAE,CAAC,CAAC,2BAA2B;QAC1C,GAAG,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;QAE9B,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC;QAE/D,IAAI,MAAM,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC9B,GAAG,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;YAC5B,OAAO;QACT,CAAC;QAED,GAAG,CAAC,OAAO,CAAC,SAAS,MAAM,CAAC,KAAK,CAAC,MAAM,WAAW,CAAC,CAAC;QACrD,KAAK,MAAM,IAAI,IAAI,MAAM,CAAC,KAAK,EAAE,CAAC;YAChC,OAAO,CAAC,GAAG,CAAC,MAAM,IAAI,CAAC,EAAE,KAAK,IAAI,CAAC,KAAK,WAAW,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;QACnE,CAAC;QAED,IAAI,MAAM,CAAC,UAAU,KAAK,SAAS,EAAE,CAAC;YACpC,GAAG,CAAC,IAAI,CAAC,sCAAsC,MAAM,CAAC,UAAU,gBAAgB,CAAC,CAAC;QACpF,CAAC;IACH,CAAC;IAAC,OAAO,KAAc,EAAE,CAAC;QACxB,IAAI,KAAK,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,MAAM,IAAI,KAAK,EAAE,CAAC;YAC1D,MAAM,SAAS,GAAG,KAAuD,CAAC;YAC1E,GAAG,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,EAAE,OAAO,IAAI,eAAe,CAAC,CAAC;YACtD,IAAI,SAAS,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC;gBACzB,GAAG,CAAC,KAAK,CAAC,eAAe,SAAS,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;YAClD,CAAC;QACH,CAAC;aAAM,CAAC;YACN,GAAG,CAAC,KAAK,CAAC,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC;QACtE,CAAC;QACD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;AACH,CAAC,CAAC"}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":""}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import { Command } from "commander";
|
|
3
|
+
import { login, status, logout } from "./commands/index.js";
|
|
4
|
+
const program = new Command();
|
|
5
|
+
program
|
|
6
|
+
.name("nesalia")
|
|
7
|
+
.version("1.0.0")
|
|
8
|
+
.description("@nesalia/cli — Manage your account authentication");
|
|
9
|
+
program
|
|
10
|
+
.command("auth", { isDefault: false })
|
|
11
|
+
.description("Authentication commands")
|
|
12
|
+
.addCommand(new Command("login")
|
|
13
|
+
.description("Login via device authorization")
|
|
14
|
+
.action(login))
|
|
15
|
+
.addCommand(new Command("status")
|
|
16
|
+
.description("Check authentication status")
|
|
17
|
+
.action(status))
|
|
18
|
+
.addCommand(new Command("logout")
|
|
19
|
+
.description("Logout and clear credentials")
|
|
20
|
+
.action(logout));
|
|
21
|
+
program.parse(process.argv);
|
|
22
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAE5D,MAAM,OAAO,GAAG,IAAI,OAAO,EAAE,CAAC;AAE9B,OAAO;KACJ,IAAI,CAAC,SAAS,CAAC;KACf,OAAO,CAAC,OAAO,CAAC;KAChB,WAAW,CAAC,mDAAmD,CAAC,CAAC;AAEpE,OAAO;KACJ,OAAO,CAAC,MAAM,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC;KACrC,WAAW,CAAC,yBAAyB,CAAC;KACtC,UAAU,CACT,IAAI,OAAO,CAAC,OAAO,CAAC;KACjB,WAAW,CAAC,gCAAgC,CAAC;KAC7C,MAAM,CAAC,KAAK,CAAC,CACjB;KACA,UAAU,CACT,IAAI,OAAO,CAAC,QAAQ,CAAC;KAClB,WAAW,CAAC,6BAA6B,CAAC;KAC1C,MAAM,CAAC,MAAM,CAAC,CAClB;KACA,UAAU,CACT,IAAI,OAAO,CAAC,QAAQ,CAAC;KAClB,WAAW,CAAC,8BAA8B,CAAC;KAC3C,MAAM,CAAC,MAAM,CAAC,CAClB,CAAC;AAEJ,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export declare const trpcClient: import("@trpc/client").TRPCClient<import("@trpc/server").TRPCBuiltRouter<{
|
|
2
|
+
ctx: import("@complete-web-template/api").Context;
|
|
3
|
+
meta: object;
|
|
4
|
+
errorShape: {
|
|
5
|
+
data: {
|
|
6
|
+
zodError: unknown;
|
|
7
|
+
code: import("@trpc/server").TRPC_ERROR_CODE_KEY;
|
|
8
|
+
httpStatus: number;
|
|
9
|
+
path?: string;
|
|
10
|
+
stack?: string;
|
|
11
|
+
};
|
|
12
|
+
message: string;
|
|
13
|
+
code: import("@trpc/server").TRPC_ERROR_CODE_NUMBER;
|
|
14
|
+
};
|
|
15
|
+
transformer: false;
|
|
16
|
+
}, import("@trpc/server").TRPCDecorateCreateRouterOptions<{}>>>;
|
|
17
|
+
//# sourceMappingURL=client.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../../src/lib/api/client.ts"],"names":[],"mappings":"AAMA,eAAO,MAAM,UAAU;;;;;;;;gBAAe,CAAC;iBAC9B,CAAC;;;;;;+DAYR,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { createTRPCClient, httpBatchLink } from "@trpc/client";
|
|
2
|
+
import { loadCredentials } from "../auth/index.js";
|
|
3
|
+
const BASE_URL = process.env.CLI_AUTH_API_URL ?? "http://localhost:3000";
|
|
4
|
+
export const trpcClient = createTRPCClient({
|
|
5
|
+
links: [
|
|
6
|
+
httpBatchLink({
|
|
7
|
+
url: `${BASE_URL}/api/trpc`,
|
|
8
|
+
headers() {
|
|
9
|
+
const creds = loadCredentials();
|
|
10
|
+
if (creds?.accessToken) {
|
|
11
|
+
return { Authorization: `Bearer ${creds.accessToken}` };
|
|
12
|
+
}
|
|
13
|
+
return {};
|
|
14
|
+
},
|
|
15
|
+
}),
|
|
16
|
+
],
|
|
17
|
+
});
|
|
18
|
+
//# sourceMappingURL=client.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client.js","sourceRoot":"","sources":["../../../src/lib/api/client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAE/D,OAAO,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAEnD,MAAM,QAAQ,GAAG,OAAO,CAAC,GAAG,CAAC,gBAAgB,IAAI,uBAAuB,CAAC;AAEzE,MAAM,CAAC,MAAM,UAAU,GAAG,gBAAgB,CAAY;IACpD,KAAK,EAAE;QACL,aAAa,CAAC;YACZ,GAAG,EAAE,GAAG,QAAQ,WAAW;YAC3B,OAAO;gBACL,MAAM,KAAK,GAAG,eAAe,EAAE,CAAC;gBAChC,IAAI,KAAK,EAAE,WAAW,EAAE,CAAC;oBACvB,OAAO,EAAE,aAAa,EAAE,UAAU,KAAK,CAAC,WAAW,EAAE,EAAE,CAAC;gBAC1D,CAAC;gBACD,OAAO,EAAE,CAAC;YACZ,CAAC;SACF,CAAC;KACH;CACF,CAAC,CAAC"}
|