@oh-gc/cli 0.7.2 → 0.7.4
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/README.md +44 -16
- package/dist/api/user.d.ts +225 -2
- package/dist/api/user.js +107 -1
- package/dist/api/user.js.map +1 -1
- package/dist/commands/search/users.d.ts +16 -0
- package/dist/commands/search/users.js +52 -0
- package/dist/commands/search/users.js.map +1 -0
- package/dist/commands/user/edit.d.ts +17 -0
- package/dist/commands/user/edit.js +79 -0
- package/dist/commands/user/edit.js.map +1 -0
- package/dist/commands/user/events.d.ts +14 -0
- package/dist/commands/user/events.js +61 -0
- package/dist/commands/user/events.js.map +1 -0
- package/dist/commands/user/issues.d.ts +21 -0
- package/dist/commands/user/issues.js +81 -0
- package/dist/commands/user/issues.js.map +1 -0
- package/dist/commands/user/key-add.d.ts +11 -0
- package/dist/commands/user/key-add.js +28 -0
- package/dist/commands/user/key-add.js.map +1 -0
- package/dist/commands/user/key-delete.d.ts +12 -0
- package/dist/commands/user/key-delete.js +27 -0
- package/dist/commands/user/key-delete.js.map +1 -0
- package/dist/commands/user/key-get.d.ts +12 -0
- package/dist/commands/user/key-get.js +36 -0
- package/dist/commands/user/key-get.js.map +1 -0
- package/dist/commands/user/keys.d.ts +11 -0
- package/dist/commands/user/keys.js +44 -0
- package/dist/commands/user/keys.js.map +1 -0
- package/dist/commands/user/leave-org.d.ts +12 -0
- package/dist/commands/user/leave-org.js +29 -0
- package/dist/commands/user/leave-org.js.map +1 -0
- package/dist/commands/user/membership.d.ts +12 -0
- package/dist/commands/user/membership.js +37 -0
- package/dist/commands/user/membership.js.map +1 -0
- package/dist/commands/user/namespace.d.ts +12 -0
- package/dist/commands/user/namespace.js +39 -0
- package/dist/commands/user/namespace.js.map +1 -0
- package/dist/commands/user/namespaces.d.ts +12 -0
- package/dist/commands/user/namespaces.js +51 -0
- package/dist/commands/user/namespaces.js.map +1 -0
- package/dist/commands/user/orgs.d.ts +14 -0
- package/dist/commands/user/orgs.js +48 -0
- package/dist/commands/user/orgs.js.map +1 -0
- package/dist/commands/user/prs.d.ts +22 -0
- package/dist/commands/user/prs.js +80 -0
- package/dist/commands/user/prs.js.map +1 -0
- package/dist/commands/user/search.d.ts +16 -0
- package/dist/commands/user/search.js +57 -0
- package/dist/commands/user/search.js.map +1 -0
- package/dist/commands/user/starred.d.ts +16 -0
- package/dist/commands/user/starred.js +60 -0
- package/dist/commands/user/starred.js.map +1 -0
- package/dist/commands/user/subscriptions.d.ts +16 -0
- package/dist/commands/user/subscriptions.js +60 -0
- package/dist/commands/user/subscriptions.js.map +1 -0
- package/dist/commands/user/update.d.ts +15 -0
- package/dist/commands/user/update.js +60 -0
- package/dist/commands/user/update.js.map +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { BaseCommand } from '../../base-command';
|
|
2
|
+
export default class UserOrgs extends BaseCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static flags: {
|
|
6
|
+
page: import("@oclif/core/lib/interfaces").OptionFlag<number, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
7
|
+
'per-page': import("@oclif/core/lib/interfaces").OptionFlag<number, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
8
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
9
|
+
};
|
|
10
|
+
static args: {
|
|
11
|
+
username: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
12
|
+
};
|
|
13
|
+
run(): Promise<void>;
|
|
14
|
+
}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const base_command_1 = require("../../base-command");
|
|
4
|
+
const user_1 = require("../../api/user");
|
|
5
|
+
const config_1 = require("../../config");
|
|
6
|
+
const ui_1 = require("../../ui");
|
|
7
|
+
const core_1 = require("@oclif/core");
|
|
8
|
+
class UserOrgs extends base_command_1.BaseCommand {
|
|
9
|
+
async run() {
|
|
10
|
+
const { flags, args } = await this.parse(UserOrgs);
|
|
11
|
+
const token = (0, config_1.getToken)();
|
|
12
|
+
if (!token) {
|
|
13
|
+
this.error('Not authenticated. Run: oh-gc auth login');
|
|
14
|
+
}
|
|
15
|
+
const orgs = await (0, user_1.listUserOrgsByUsername)(token, args.username, {
|
|
16
|
+
page: flags.page,
|
|
17
|
+
per_page: flags['per-page'],
|
|
18
|
+
});
|
|
19
|
+
if (flags.json) {
|
|
20
|
+
(0, ui_1.printJson)(orgs);
|
|
21
|
+
}
|
|
22
|
+
else {
|
|
23
|
+
if (orgs.length === 0) {
|
|
24
|
+
this.log('No organizations found.');
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
27
|
+
(0, ui_1.printTable)(orgs.map((o) => ({
|
|
28
|
+
login: o.login,
|
|
29
|
+
name: o.name,
|
|
30
|
+
description: o.description || '',
|
|
31
|
+
})), ['login', 'name', 'description']);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
UserOrgs.description = 'List organizations a user belongs to';
|
|
36
|
+
UserOrgs.examples = [
|
|
37
|
+
'<%= config.bin %> user:orgs alice',
|
|
38
|
+
];
|
|
39
|
+
UserOrgs.flags = {
|
|
40
|
+
...base_command_1.BaseCommand.baseFlags,
|
|
41
|
+
page: core_1.Flags.integer({ description: 'Page number', default: 1 }),
|
|
42
|
+
'per-page': core_1.Flags.integer({ description: 'Results per page (max 100)', default: 20 }),
|
|
43
|
+
};
|
|
44
|
+
UserOrgs.args = {
|
|
45
|
+
username: core_1.Args.string({ description: 'Username', required: true }),
|
|
46
|
+
};
|
|
47
|
+
exports.default = UserOrgs;
|
|
48
|
+
//# sourceMappingURL=orgs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"orgs.js","sourceRoot":"","sources":["../../../src/commands/user/orgs.ts"],"names":[],"mappings":";;AAAA,qDAAgD;AAChD,yCAAuD;AACvD,yCAAuC;AACvC,iCAAgD;AAChD,sCAAyC;AAEzC,MAAqB,QAAS,SAAQ,0BAAW;IAiB/C,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAA;QAClD,MAAM,KAAK,GAAG,IAAA,iBAAQ,GAAE,CAAA;QACxB,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,IAAI,CAAC,KAAK,CAAC,0CAA0C,CAAC,CAAA;QACxD,CAAC;QAED,MAAM,IAAI,GAAG,MAAM,IAAA,6BAAsB,EAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,EAAE;YAC9D,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,QAAQ,EAAE,KAAK,CAAC,UAAU,CAAC;SAC5B,CAAC,CAAA;QAEF,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;YACf,IAAA,cAAS,EAAC,IAAI,CAAC,CAAA;QACjB,CAAC;aAAM,CAAC;YACN,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACtB,IAAI,CAAC,GAAG,CAAC,yBAAyB,CAAC,CAAA;gBACnC,OAAM;YACR,CAAC;YACD,IAAA,eAAU,EACR,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;gBACf,KAAK,EAAE,CAAC,CAAC,KAAK;gBACd,IAAI,EAAE,CAAC,CAAC,IAAI;gBACZ,WAAW,EAAE,CAAC,CAAC,WAAW,IAAI,EAAE;aACjC,CAAC,CAAC,EACH,CAAC,OAAO,EAAE,MAAM,EAAE,aAAa,CAAC,CACjC,CAAA;QACH,CAAC;IACH,CAAC;;AA5CM,oBAAW,GAAG,sCAAsC,CAAA;AAEpD,iBAAQ,GAAG;IAChB,mCAAmC;CACpC,CAAA;AAEM,cAAK,GAAG;IACb,GAAG,0BAAW,CAAC,SAAS;IACxB,IAAI,EAAE,YAAK,CAAC,OAAO,CAAC,EAAE,WAAW,EAAE,aAAa,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC;IAC/D,UAAU,EAAE,YAAK,CAAC,OAAO,CAAC,EAAE,WAAW,EAAE,4BAA4B,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;CACtF,CAAA;AAEM,aAAI,GAAG;IACZ,QAAQ,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,UAAU,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;CACnE,CAAA;kBAfkB,QAAQ"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { BaseCommand } from '../../base-command';
|
|
2
|
+
export default class UserPRs extends BaseCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static flags: {
|
|
6
|
+
state: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
7
|
+
sort: import("@oclif/core/lib/interfaces").OptionFlag<string, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
8
|
+
direction: import("@oclif/core/lib/interfaces").OptionFlag<string, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
9
|
+
labels: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
10
|
+
scope: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
11
|
+
'source-branch': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
12
|
+
'target-branch': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
13
|
+
'created-after': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
14
|
+
'created-before': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
15
|
+
'updated-after': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
16
|
+
'updated-before': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
17
|
+
page: import("@oclif/core/lib/interfaces").OptionFlag<number, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
18
|
+
'per-page': import("@oclif/core/lib/interfaces").OptionFlag<number, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
19
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
20
|
+
};
|
|
21
|
+
run(): Promise<void>;
|
|
22
|
+
}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const base_command_1 = require("../../base-command");
|
|
4
|
+
const user_1 = require("../../api/user");
|
|
5
|
+
const config_1 = require("../../config");
|
|
6
|
+
const ui_1 = require("../../ui");
|
|
7
|
+
const core_1 = require("@oclif/core");
|
|
8
|
+
class UserPRs extends base_command_1.BaseCommand {
|
|
9
|
+
async run() {
|
|
10
|
+
const { flags } = await this.parse(UserPRs);
|
|
11
|
+
const token = (0, config_1.getToken)();
|
|
12
|
+
if (!token) {
|
|
13
|
+
this.error('Not authenticated. Run: oh-gc auth login');
|
|
14
|
+
}
|
|
15
|
+
const prs = await (0, user_1.listUserPRs)(token, {
|
|
16
|
+
state: flags.state,
|
|
17
|
+
sort: flags.sort,
|
|
18
|
+
direction: flags.direction,
|
|
19
|
+
labels: flags.labels,
|
|
20
|
+
scope: flags.scope,
|
|
21
|
+
source_branch: flags['source-branch'],
|
|
22
|
+
target_branch: flags['target-branch'],
|
|
23
|
+
created_after: flags['created-after'],
|
|
24
|
+
created_before: flags['created-before'],
|
|
25
|
+
updated_after: flags['updated-after'],
|
|
26
|
+
updated_before: flags['updated-before'],
|
|
27
|
+
page: flags.page,
|
|
28
|
+
per_page: flags['per-page'],
|
|
29
|
+
});
|
|
30
|
+
if (flags.json) {
|
|
31
|
+
(0, ui_1.printJson)(prs);
|
|
32
|
+
}
|
|
33
|
+
else {
|
|
34
|
+
if (prs.length === 0) {
|
|
35
|
+
this.log('No pull requests found.');
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
(0, ui_1.printTable)(prs.map((p) => ({
|
|
39
|
+
number: `#${p.number}`,
|
|
40
|
+
title: p.title,
|
|
41
|
+
draft: p.draft ? 'draft' : '',
|
|
42
|
+
labels: p.labels?.map((l) => l.name).join(',') || '',
|
|
43
|
+
})), ['number', 'title', 'draft', 'labels']);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
UserPRs.description = 'List authenticated user pull requests across all repos';
|
|
48
|
+
UserPRs.examples = [
|
|
49
|
+
'<%= config.bin %> user:prs',
|
|
50
|
+
'<%= config.bin %> user:prs --state merged',
|
|
51
|
+
'<%= config.bin %> user:prs --scope assigned_to_me',
|
|
52
|
+
];
|
|
53
|
+
UserPRs.flags = {
|
|
54
|
+
...base_command_1.BaseCommand.baseFlags,
|
|
55
|
+
state: core_1.Flags.string({
|
|
56
|
+
description: 'PR state: open, closed, locked, merged, all',
|
|
57
|
+
}),
|
|
58
|
+
sort: core_1.Flags.string({
|
|
59
|
+
description: 'Sort by: created, updated, or merged_at',
|
|
60
|
+
default: 'created',
|
|
61
|
+
}),
|
|
62
|
+
direction: core_1.Flags.string({
|
|
63
|
+
description: 'Sort direction: asc or desc',
|
|
64
|
+
default: 'desc',
|
|
65
|
+
}),
|
|
66
|
+
labels: core_1.Flags.string({ description: 'Comma-separated label names' }),
|
|
67
|
+
scope: core_1.Flags.string({
|
|
68
|
+
description: 'Scope: need_my_approve, created_by_me, assigned_to_me, need_my_review',
|
|
69
|
+
}),
|
|
70
|
+
'source-branch': core_1.Flags.string({ description: 'Filter by source branch name' }),
|
|
71
|
+
'target-branch': core_1.Flags.string({ description: 'Filter by target branch name' }),
|
|
72
|
+
'created-after': core_1.Flags.string({ description: 'PRs created after this time (ISO 8601)' }),
|
|
73
|
+
'created-before': core_1.Flags.string({ description: 'PRs created before this time (ISO 8601)' }),
|
|
74
|
+
'updated-after': core_1.Flags.string({ description: 'PRs updated after this time (ISO 8601)' }),
|
|
75
|
+
'updated-before': core_1.Flags.string({ description: 'PRs updated before this time (ISO 8601)' }),
|
|
76
|
+
page: core_1.Flags.integer({ description: 'Page number', default: 1 }),
|
|
77
|
+
'per-page': core_1.Flags.integer({ description: 'Results per page (max 100)', default: 20 }),
|
|
78
|
+
};
|
|
79
|
+
exports.default = UserPRs;
|
|
80
|
+
//# sourceMappingURL=prs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prs.js","sourceRoot":"","sources":["../../../src/commands/user/prs.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { BaseCommand } from '../../base-command';
|
|
2
|
+
export default class UserSearch extends BaseCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static flags: {
|
|
6
|
+
sort: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
7
|
+
order: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
8
|
+
page: import("@oclif/core/lib/interfaces").OptionFlag<number, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
9
|
+
'per-page': import("@oclif/core/lib/interfaces").OptionFlag<number, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
10
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
11
|
+
};
|
|
12
|
+
static args: {
|
|
13
|
+
query: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
14
|
+
};
|
|
15
|
+
run(): Promise<void>;
|
|
16
|
+
}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const base_command_1 = require("../../base-command");
|
|
4
|
+
const user_1 = require("../../api/user");
|
|
5
|
+
const config_1 = require("../../config");
|
|
6
|
+
const ui_1 = require("../../ui");
|
|
7
|
+
const core_1 = require("@oclif/core");
|
|
8
|
+
class UserSearch extends base_command_1.BaseCommand {
|
|
9
|
+
async run() {
|
|
10
|
+
const { flags, args } = await this.parse(UserSearch);
|
|
11
|
+
const token = (0, config_1.getToken)();
|
|
12
|
+
if (!token) {
|
|
13
|
+
this.error('Not authenticated. Run: oh-gc auth login');
|
|
14
|
+
}
|
|
15
|
+
const users = await (0, user_1.searchUsers)(token, {
|
|
16
|
+
q: args.query,
|
|
17
|
+
page: flags.page,
|
|
18
|
+
per_page: flags['per-page'],
|
|
19
|
+
sort: flags.sort,
|
|
20
|
+
order: flags.order,
|
|
21
|
+
});
|
|
22
|
+
if (flags.json) {
|
|
23
|
+
(0, ui_1.printJson)(users);
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
if (users.length === 0) {
|
|
27
|
+
this.log('No users found.');
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
(0, ui_1.printTable)(users.map((u) => ({
|
|
31
|
+
login: u.login,
|
|
32
|
+
name: u.name || '',
|
|
33
|
+
})), ['login', 'name']);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
UserSearch.description = 'Search users';
|
|
38
|
+
UserSearch.examples = [
|
|
39
|
+
'<%= config.bin %> user:search alice',
|
|
40
|
+
'<%= config.bin %> user:search bob --sort joined_at --order desc',
|
|
41
|
+
];
|
|
42
|
+
UserSearch.flags = {
|
|
43
|
+
...base_command_1.BaseCommand.baseFlags,
|
|
44
|
+
sort: core_1.Flags.string({
|
|
45
|
+
description: 'Sort field: joined_at (registration time), default is best match',
|
|
46
|
+
}),
|
|
47
|
+
order: core_1.Flags.string({
|
|
48
|
+
description: 'Sort order: asc or desc (default: desc)',
|
|
49
|
+
}),
|
|
50
|
+
page: core_1.Flags.integer({ description: 'Page number (max 100)', default: 1 }),
|
|
51
|
+
'per-page': core_1.Flags.integer({ description: 'Results per page (max 50)', default: 30 }),
|
|
52
|
+
};
|
|
53
|
+
UserSearch.args = {
|
|
54
|
+
query: core_1.Args.string({ description: 'Search query', required: true }),
|
|
55
|
+
};
|
|
56
|
+
exports.default = UserSearch;
|
|
57
|
+
//# sourceMappingURL=search.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"search.js","sourceRoot":"","sources":["../../../src/commands/user/search.ts"],"names":[],"mappings":";;AAAA,qDAAgD;AAChD,yCAA4C;AAC5C,yCAAuC;AACvC,iCAAgD;AAChD,sCAAyC;AAEzC,MAAqB,UAAW,SAAQ,0BAAW;IAwBjD,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAA;QACpD,MAAM,KAAK,GAAG,IAAA,iBAAQ,GAAE,CAAA;QACxB,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,IAAI,CAAC,KAAK,CAAC,0CAA0C,CAAC,CAAA;QACxD,CAAC;QAED,MAAM,KAAK,GAAG,MAAM,IAAA,kBAAW,EAAC,KAAK,EAAE;YACrC,CAAC,EAAE,IAAI,CAAC,KAAK;YACb,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,QAAQ,EAAE,KAAK,CAAC,UAAU,CAAC;YAC3B,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,KAAK,EAAE,KAAK,CAAC,KAAK;SACnB,CAAC,CAAA;QAEF,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;YACf,IAAA,cAAS,EAAC,KAAK,CAAC,CAAA;QAClB,CAAC;aAAM,CAAC;YACN,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACvB,IAAI,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAA;gBAC3B,OAAM;YACR,CAAC;YACD,IAAA,eAAU,EACR,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;gBAChB,KAAK,EAAE,CAAC,CAAC,KAAK;gBACd,IAAI,EAAE,CAAC,CAAC,IAAI,IAAI,EAAE;aACnB,CAAC,CAAC,EACH,CAAC,OAAO,EAAE,MAAM,CAAC,CAClB,CAAA;QACH,CAAC;IACH,CAAC;;AArDM,sBAAW,GAAG,cAAc,CAAA;AAE5B,mBAAQ,GAAG;IAChB,qCAAqC;IACrC,iEAAiE;CAClE,CAAA;AAEM,gBAAK,GAAG;IACb,GAAG,0BAAW,CAAC,SAAS;IACxB,IAAI,EAAE,YAAK,CAAC,MAAM,CAAC;QACjB,WAAW,EAAE,kEAAkE;KAChF,CAAC;IACF,KAAK,EAAE,YAAK,CAAC,MAAM,CAAC;QAClB,WAAW,EAAE,yCAAyC;KACvD,CAAC;IACF,IAAI,EAAE,YAAK,CAAC,OAAO,CAAC,EAAE,WAAW,EAAE,uBAAuB,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC;IACzE,UAAU,EAAE,YAAK,CAAC,OAAO,CAAC,EAAE,WAAW,EAAE,2BAA2B,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;CACrF,CAAA;AAEM,eAAI,GAAG;IACZ,KAAK,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,cAAc,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;CACpE,CAAA;kBAtBkB,UAAU"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { BaseCommand } from '../../base-command';
|
|
2
|
+
export default class UserStarred extends BaseCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static flags: {
|
|
6
|
+
sort: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
7
|
+
direction: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
8
|
+
page: import("@oclif/core/lib/interfaces").OptionFlag<number, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
9
|
+
'per-page': import("@oclif/core/lib/interfaces").OptionFlag<number, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
10
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
11
|
+
};
|
|
12
|
+
static args: {
|
|
13
|
+
username: import("@oclif/core/lib/interfaces").Arg<string | undefined, Record<string, unknown>>;
|
|
14
|
+
};
|
|
15
|
+
run(): Promise<void>;
|
|
16
|
+
}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const base_command_1 = require("../../base-command");
|
|
4
|
+
const user_1 = require("../../api/user");
|
|
5
|
+
const config_1 = require("../../config");
|
|
6
|
+
const ui_1 = require("../../ui");
|
|
7
|
+
const core_1 = require("@oclif/core");
|
|
8
|
+
class UserStarred extends base_command_1.BaseCommand {
|
|
9
|
+
async run() {
|
|
10
|
+
const { flags, args } = await this.parse(UserStarred);
|
|
11
|
+
const token = (0, config_1.getToken)();
|
|
12
|
+
if (!token) {
|
|
13
|
+
this.error('Not authenticated. Run: oh-gc auth login');
|
|
14
|
+
}
|
|
15
|
+
const params = {
|
|
16
|
+
sort: flags.sort,
|
|
17
|
+
direction: flags.direction,
|
|
18
|
+
page: flags.page,
|
|
19
|
+
per_page: flags['per-page'],
|
|
20
|
+
};
|
|
21
|
+
const repos = args.username
|
|
22
|
+
? await (0, user_1.getUserStarredByUsername)(token, args.username, params)
|
|
23
|
+
: await (0, user_1.getUserStarred)(token, params);
|
|
24
|
+
if (flags.json) {
|
|
25
|
+
(0, ui_1.printJson)(repos);
|
|
26
|
+
}
|
|
27
|
+
else {
|
|
28
|
+
if (repos.length === 0) {
|
|
29
|
+
this.log('No starred repositories found.');
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
(0, ui_1.printTable)(repos.map((r) => ({
|
|
33
|
+
full_name: r.full_name,
|
|
34
|
+
namespace: r.namespace?.path || '',
|
|
35
|
+
})), ['full_name', 'namespace']);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
UserStarred.description = 'List starred repositories';
|
|
40
|
+
UserStarred.examples = [
|
|
41
|
+
'<%= config.bin %> user:starred',
|
|
42
|
+
'<%= config.bin %> user:starred alice',
|
|
43
|
+
'<%= config.bin %> user:starred --sort last_push',
|
|
44
|
+
];
|
|
45
|
+
UserStarred.flags = {
|
|
46
|
+
...base_command_1.BaseCommand.baseFlags,
|
|
47
|
+
sort: core_1.Flags.string({
|
|
48
|
+
description: 'Sort by: created or last_push (default: created)',
|
|
49
|
+
}),
|
|
50
|
+
direction: core_1.Flags.string({
|
|
51
|
+
description: 'Sort direction: asc or desc (default: desc)',
|
|
52
|
+
}),
|
|
53
|
+
page: core_1.Flags.integer({ description: 'Page number', default: 1 }),
|
|
54
|
+
'per-page': core_1.Flags.integer({ description: 'Results per page (max 100)', default: 20 }),
|
|
55
|
+
};
|
|
56
|
+
UserStarred.args = {
|
|
57
|
+
username: core_1.Args.string({ description: 'Username (defaults to authenticated user)' }),
|
|
58
|
+
};
|
|
59
|
+
exports.default = UserStarred;
|
|
60
|
+
//# sourceMappingURL=starred.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"starred.js","sourceRoot":"","sources":["../../../src/commands/user/starred.ts"],"names":[],"mappings":";;AAAA,qDAAgD;AAChD,yCAAyE;AACzE,yCAAuC;AACvC,iCAAgD;AAChD,sCAAyC;AAEzC,MAAqB,WAAY,SAAQ,0BAAW;IAyBlD,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAA;QACrD,MAAM,KAAK,GAAG,IAAA,iBAAQ,GAAE,CAAA;QACxB,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,IAAI,CAAC,KAAK,CAAC,0CAA0C,CAAC,CAAA;QACxD,CAAC;QAED,MAAM,MAAM,GAAG;YACb,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,SAAS,EAAE,KAAK,CAAC,SAAS;YAC1B,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,QAAQ,EAAE,KAAK,CAAC,UAAU,CAAC;SAC5B,CAAA;QAED,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ;YACzB,CAAC,CAAC,MAAM,IAAA,+BAAwB,EAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,EAAE,MAAM,CAAC;YAC9D,CAAC,CAAC,MAAM,IAAA,qBAAc,EAAC,KAAK,EAAE,MAAM,CAAC,CAAA;QAEvC,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;YACf,IAAA,cAAS,EAAC,KAAK,CAAC,CAAA;QAClB,CAAC;aAAM,CAAC;YACN,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACvB,IAAI,CAAC,GAAG,CAAC,gCAAgC,CAAC,CAAA;gBAC1C,OAAM;YACR,CAAC;YACD,IAAA,eAAU,EACR,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;gBAChB,SAAS,EAAE,CAAC,CAAC,SAAS;gBACtB,SAAS,EAAE,CAAC,CAAC,SAAS,EAAE,IAAI,IAAI,EAAE;aACnC,CAAC,CAAC,EACH,CAAC,WAAW,EAAE,WAAW,CAAC,CAC3B,CAAA;QACH,CAAC;IACH,CAAC;;AAzDM,uBAAW,GAAG,2BAA2B,CAAA;AAEzC,oBAAQ,GAAG;IAChB,gCAAgC;IAChC,sCAAsC;IACtC,iDAAiD;CAClD,CAAA;AAEM,iBAAK,GAAG;IACb,GAAG,0BAAW,CAAC,SAAS;IACxB,IAAI,EAAE,YAAK,CAAC,MAAM,CAAC;QACjB,WAAW,EAAE,kDAAkD;KAChE,CAAC;IACF,SAAS,EAAE,YAAK,CAAC,MAAM,CAAC;QACtB,WAAW,EAAE,6CAA6C;KAC3D,CAAC;IACF,IAAI,EAAE,YAAK,CAAC,OAAO,CAAC,EAAE,WAAW,EAAE,aAAa,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC;IAC/D,UAAU,EAAE,YAAK,CAAC,OAAO,CAAC,EAAE,WAAW,EAAE,4BAA4B,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;CACtF,CAAA;AAEM,gBAAI,GAAG;IACZ,QAAQ,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,2CAA2C,EAAE,CAAC;CACpF,CAAA;kBAvBkB,WAAW"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { BaseCommand } from '../../base-command';
|
|
2
|
+
export default class UserSubscriptions extends BaseCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static flags: {
|
|
6
|
+
sort: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
7
|
+
direction: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
8
|
+
page: import("@oclif/core/lib/interfaces").OptionFlag<number, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
9
|
+
'per-page': import("@oclif/core/lib/interfaces").OptionFlag<number, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
10
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
11
|
+
};
|
|
12
|
+
static args: {
|
|
13
|
+
username: import("@oclif/core/lib/interfaces").Arg<string | undefined, Record<string, unknown>>;
|
|
14
|
+
};
|
|
15
|
+
run(): Promise<void>;
|
|
16
|
+
}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const base_command_1 = require("../../base-command");
|
|
4
|
+
const user_1 = require("../../api/user");
|
|
5
|
+
const config_1 = require("../../config");
|
|
6
|
+
const ui_1 = require("../../ui");
|
|
7
|
+
const core_1 = require("@oclif/core");
|
|
8
|
+
class UserSubscriptions extends base_command_1.BaseCommand {
|
|
9
|
+
async run() {
|
|
10
|
+
const { flags, args } = await this.parse(UserSubscriptions);
|
|
11
|
+
const token = (0, config_1.getToken)();
|
|
12
|
+
if (!token) {
|
|
13
|
+
this.error('Not authenticated. Run: oh-gc auth login');
|
|
14
|
+
}
|
|
15
|
+
const params = {
|
|
16
|
+
sort: flags.sort,
|
|
17
|
+
direction: flags.direction,
|
|
18
|
+
page: flags.page,
|
|
19
|
+
per_page: flags['per-page'],
|
|
20
|
+
};
|
|
21
|
+
const repos = args.username
|
|
22
|
+
? await (0, user_1.getUserSubscriptionsByUsername)(token, args.username, params)
|
|
23
|
+
: await (0, user_1.getUserSubscriptions)(token, params);
|
|
24
|
+
if (flags.json) {
|
|
25
|
+
(0, ui_1.printJson)(repos);
|
|
26
|
+
}
|
|
27
|
+
else {
|
|
28
|
+
if (repos.length === 0) {
|
|
29
|
+
this.log('No watched repositories found.');
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
(0, ui_1.printTable)(repos.map((r) => ({
|
|
33
|
+
full_name: r.full_name,
|
|
34
|
+
namespace: r.namespace?.path || '',
|
|
35
|
+
})), ['full_name', 'namespace']);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
UserSubscriptions.description = 'List watched (subscribed) repositories';
|
|
40
|
+
UserSubscriptions.examples = [
|
|
41
|
+
'<%= config.bin %> user:subscriptions',
|
|
42
|
+
'<%= config.bin %> user:subscriptions alice',
|
|
43
|
+
'<%= config.bin %> user:subscriptions --sort last_push',
|
|
44
|
+
];
|
|
45
|
+
UserSubscriptions.flags = {
|
|
46
|
+
...base_command_1.BaseCommand.baseFlags,
|
|
47
|
+
sort: core_1.Flags.string({
|
|
48
|
+
description: 'Sort by: created or last_push (default: created)',
|
|
49
|
+
}),
|
|
50
|
+
direction: core_1.Flags.string({
|
|
51
|
+
description: 'Sort direction: asc or desc (default: desc)',
|
|
52
|
+
}),
|
|
53
|
+
page: core_1.Flags.integer({ description: 'Page number', default: 1 }),
|
|
54
|
+
'per-page': core_1.Flags.integer({ description: 'Results per page (max 100)', default: 20 }),
|
|
55
|
+
};
|
|
56
|
+
UserSubscriptions.args = {
|
|
57
|
+
username: core_1.Args.string({ description: 'Username (defaults to authenticated user)' }),
|
|
58
|
+
};
|
|
59
|
+
exports.default = UserSubscriptions;
|
|
60
|
+
//# sourceMappingURL=subscriptions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"subscriptions.js","sourceRoot":"","sources":["../../../src/commands/user/subscriptions.ts"],"names":[],"mappings":";;AAAA,qDAAgD;AAChD,yCAAqF;AACrF,yCAAuC;AACvC,iCAAgD;AAChD,sCAAyC;AAEzC,MAAqB,iBAAkB,SAAQ,0BAAW;IAyBxD,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAA;QAC3D,MAAM,KAAK,GAAG,IAAA,iBAAQ,GAAE,CAAA;QACxB,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,IAAI,CAAC,KAAK,CAAC,0CAA0C,CAAC,CAAA;QACxD,CAAC;QAED,MAAM,MAAM,GAAG;YACb,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,SAAS,EAAE,KAAK,CAAC,SAAS;YAC1B,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,QAAQ,EAAE,KAAK,CAAC,UAAU,CAAC;SAC5B,CAAA;QAED,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ;YACzB,CAAC,CAAC,MAAM,IAAA,qCAA8B,EAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,EAAE,MAAM,CAAC;YACpE,CAAC,CAAC,MAAM,IAAA,2BAAoB,EAAC,KAAK,EAAE,MAAM,CAAC,CAAA;QAE7C,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;YACf,IAAA,cAAS,EAAC,KAAK,CAAC,CAAA;QAClB,CAAC;aAAM,CAAC;YACN,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACvB,IAAI,CAAC,GAAG,CAAC,gCAAgC,CAAC,CAAA;gBAC1C,OAAM;YACR,CAAC;YACD,IAAA,eAAU,EACR,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;gBAChB,SAAS,EAAE,CAAC,CAAC,SAAS;gBACtB,SAAS,EAAE,CAAC,CAAC,SAAS,EAAE,IAAI,IAAI,EAAE;aACnC,CAAC,CAAC,EACH,CAAC,WAAW,EAAE,WAAW,CAAC,CAC3B,CAAA;QACH,CAAC;IACH,CAAC;;AAzDM,6BAAW,GAAG,wCAAwC,CAAA;AAEtD,0BAAQ,GAAG;IAChB,sCAAsC;IACtC,4CAA4C;IAC5C,uDAAuD;CACxD,CAAA;AAEM,uBAAK,GAAG;IACb,GAAG,0BAAW,CAAC,SAAS;IACxB,IAAI,EAAE,YAAK,CAAC,MAAM,CAAC;QACjB,WAAW,EAAE,kDAAkD;KAChE,CAAC;IACF,SAAS,EAAE,YAAK,CAAC,MAAM,CAAC;QACtB,WAAW,EAAE,6CAA6C;KAC3D,CAAC;IACF,IAAI,EAAE,YAAK,CAAC,OAAO,CAAC,EAAE,WAAW,EAAE,aAAa,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC;IAC/D,UAAU,EAAE,YAAK,CAAC,OAAO,CAAC,EAAE,WAAW,EAAE,4BAA4B,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;CACtF,CAAA;AAEM,sBAAI,GAAG;IACZ,QAAQ,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,2CAA2C,EAAE,CAAC;CACpF,CAAA;kBAvBkB,iBAAiB"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { BaseCommand } from '../../base-command';
|
|
2
|
+
export default class UserUpdate extends BaseCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static flags: {
|
|
6
|
+
name: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
7
|
+
company: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
8
|
+
bio: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
9
|
+
email: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
10
|
+
blog: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
11
|
+
location: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
12
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
13
|
+
};
|
|
14
|
+
run(): Promise<void>;
|
|
15
|
+
}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const base_command_1 = require("../../base-command");
|
|
4
|
+
const user_1 = require("../../api/user");
|
|
5
|
+
const config_1 = require("../../config");
|
|
6
|
+
const ui_1 = require("../../ui");
|
|
7
|
+
const core_1 = require("@oclif/core");
|
|
8
|
+
class UserUpdate extends base_command_1.BaseCommand {
|
|
9
|
+
async run() {
|
|
10
|
+
const { flags } = await this.parse(UserUpdate);
|
|
11
|
+
const token = (0, config_1.getToken)();
|
|
12
|
+
if (!token) {
|
|
13
|
+
this.error('Not authenticated. Run: oh-gc auth login');
|
|
14
|
+
}
|
|
15
|
+
const data = {};
|
|
16
|
+
if (flags.name)
|
|
17
|
+
data.nickname = flags.name;
|
|
18
|
+
if (flags.company)
|
|
19
|
+
data.company = flags.company;
|
|
20
|
+
if (flags.bio)
|
|
21
|
+
data.description = flags.bio;
|
|
22
|
+
if (flags.email)
|
|
23
|
+
data.email = flags.email;
|
|
24
|
+
if (flags.blog)
|
|
25
|
+
data.website = flags.blog;
|
|
26
|
+
if (flags.location)
|
|
27
|
+
data.location = flags.location;
|
|
28
|
+
if (Object.keys(data).length === 0) {
|
|
29
|
+
this.error('Provide at least one field to update (--name, --company, --bio, --email, --blog, --location)');
|
|
30
|
+
}
|
|
31
|
+
const user = await (0, user_1.updateCurrentUser)(token, data);
|
|
32
|
+
if (flags.json) {
|
|
33
|
+
(0, ui_1.printJson)(user);
|
|
34
|
+
}
|
|
35
|
+
else {
|
|
36
|
+
this.log(`Updated profile for ${user.login}`);
|
|
37
|
+
this.log(`Name: ${user.name || 'N/A'}`);
|
|
38
|
+
this.log(`Company: ${user.company || 'N/A'}`);
|
|
39
|
+
this.log(`Bio: ${user.bio || 'N/A'}`);
|
|
40
|
+
this.log(`Location: ${user.location || 'N/A'}`);
|
|
41
|
+
this.log(`Blog: ${user.blog || 'N/A'}`);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
UserUpdate.description = 'Update authenticated user profile';
|
|
46
|
+
UserUpdate.examples = [
|
|
47
|
+
'<%= config.bin %> user update --name "New Name"',
|
|
48
|
+
'<%= config.bin %> user update --company "New Corp" --location "Shanghai"',
|
|
49
|
+
];
|
|
50
|
+
UserUpdate.flags = {
|
|
51
|
+
...base_command_1.BaseCommand.baseFlags,
|
|
52
|
+
name: core_1.Flags.string({ description: 'Display name' }),
|
|
53
|
+
company: core_1.Flags.string({ description: 'Company' }),
|
|
54
|
+
bio: core_1.Flags.string({ description: 'Bio / description' }),
|
|
55
|
+
email: core_1.Flags.string({ description: 'Public email' }),
|
|
56
|
+
blog: core_1.Flags.string({ description: 'Blog / website URL' }),
|
|
57
|
+
location: core_1.Flags.string({ description: 'Location' }),
|
|
58
|
+
};
|
|
59
|
+
exports.default = UserUpdate;
|
|
60
|
+
//# sourceMappingURL=update.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"update.js","sourceRoot":"","sources":["../../../src/commands/user/update.ts"],"names":[],"mappings":"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"}
|