Skip to content

Commit

Permalink
Fix curl import when using boolean flags
Browse files Browse the repository at this point in the history
  • Loading branch information
gschier committed Oct 8, 2024
1 parent 124a01f commit d4d331b
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 2 deletions.
6 changes: 4 additions & 2 deletions plugins/importer-curl/src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -27,12 +27,13 @@ const SUPPORTED_ARGS = [
['request', 'X'], // Request method
DATA_FLAGS,
].flatMap((v) => v);
const BOOL_FLAGS = ['G', 'get', 'digest'];

type Pair = string | boolean;

type PairsByName = Record<string, Pair[]>;

export function pluginHookImport(ctx: Context, rawData: string) {
export function pluginHookImport(_ctx: Context, rawData: string) {
if (!rawData.match(/^\s*curl /)) {
return null;
}
Expand Down Expand Up @@ -140,11 +141,12 @@ function importCommand(parseEntries: ParseEntry[], workspaceId: string) {

let value;
const nextEntry = parseEntries[i + 1];
const hasValue = !BOOL_FLAGS.includes(name);
if (isSingleDash && name.length > 1) {
// Handle squished arguments like -XPOST
value = name.slice(1);
name = name.slice(0, 1);
} else if (typeof nextEntry === 'string' && !nextEntry.startsWith('-')) {
} else if (typeof nextEntry === 'string' && hasValue && !nextEntry.startsWith('-')) {
// Next arg is not a flag, so assign it as the value
value = nextEntry;
i++; // Skip next one
Expand Down
21 changes: 21 additions & 0 deletions plugins/importer-curl/tests/index.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -196,6 +196,27 @@ describe('importer-curl', () => {
});
});

test('Imports post data into URL', () => {
expect(
pluginHookImport(ctx, 'curl -G https://api.stripe.com/v1/payment_links -d limit=3'),
).toEqual({
resources: {
workspaces: [baseWorkspace()],
httpRequests: [
baseRequest({
method: 'GET',
url: 'https://api.stripe.com/v1/payment_links',
urlParameters: [{
enabled: true,
name: 'limit',
value: '3',
}]
}),
],
},
});
});

test('Imports multi-line JSON', () => {
expect(
pluginHookImport(
Expand Down

0 comments on commit d4d331b

Please sign in to comment.