Fix curl import when using boolean flags

This commit is contained in:
Gregory Schier
2024-10-08 14:49:03 -07:00
parent 9df586cb59
commit 9291950554
2 changed files with 25 additions and 2 deletions

View File

@@ -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;
}
@@ -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

View File

@@ -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(