import * as wmill from "windmill-client";
import createClient, { type Middleware } from "openapi-fetch";
interface Data {
[p: number]: any
}
type Nextcloud = {
baseUrl: string,
password: string,
username: string
};
export async function main(
ncResource: Nextcloud,
userId: string | null = null,
tableId: number,
data: Data,
useAppApiAuth: boolean = false,
) {
const client = createClient<paths>({ baseUrl: ncResource.baseUrl });
const authMiddleware: Middleware = {
async onRequest({ request, options }) {
// fetch token, if it doesn’t exist
// add Authorization header to every request
request.headers.set("Authorization", `Basic ${btoa((userId || ncResource.username) + ':' + ncResource.password)}`);
if (useAppApiAuth) {
request.headers.set("AA-VERSION", "2.3.0",);
request.headers.set("EX-APP-ID", "flow",);
request.headers.set("EX-APP-VERSION", "1.0.1",);
request.headers.set("AUTHORIZATION-APP-API", btoa(
`${userId || ncResource.username}:${ncResource.password}`,
));
}
return request;
},
};
client.use(authMiddleware);
const resp = await client.POST("/index.php/apps/tables/api/1/tables/{tableId}/rows", {
params: {
header: {
"OCS-APIRequest": true,
},
query: {
format: "json",
},
path: {
tableId: tableId,
},
},
body: {
data: data
},
});
return resp.data;
}
Submitted by nextcloud 4 days ago
import * as wmill from "windmill-client";
import createClient, { type Middleware } from "openapi-fetch";
interface Data {
[p: number]: any
}
type Nextcloud = {
baseUrl: string,
password: string,
username: string
};
export async function main(
ncResource: Nextcloud,
userId: string | null = null,
tableId: number,
data: Data,
useAppApiAuth: boolean = false,
) {
const client = createClient<paths>({ baseUrl: ncResource.baseUrl });
const authMiddleware: Middleware = {
async onRequest({ request, options }) {
// fetch token, if it doesn’t exist
// add Authorization header to every request
request.headers.set("Authorization", `Basic ${btoa((userId || ncResource.username) + ':' + ncResource.password)}`);
if (useAppApiAuth) {
request.headers.set("AA-VERSION", "2.3.0",);
request.headers.set("EX-APP-ID", "flow",);
request.headers.set("EX-APP-VERSION", "1.0.1",);
request.headers.set("AUTHORIZATION-APP-API", btoa(
`${userId || ncResource.username}:${ncResource.password}`,
));
}
return request;
},
};
client.use(authMiddleware);
const resp = await client.POST("/index.php/apps/tables/api/1/tables/{tableId}/rows", {
params: {
header: {
"OCS-APIRequest": true,
},
query: {
format: "json",
},
path: {
tableId: tableId,
},
},
body: {
data: data
},
});
return resp.data;
}
Submitted by nextcloud 5 days ago
import * as wmill from "windmill-client";
import createClient, { type Middleware } from "openapi-fetch";
interface Data {
[p: number]: any
}
export async function main(
ncResource: Nextcloud,
userId: string | null = null,
tableId: number,
data: Data,
useAppApiAuth: boolean = false,
) {
const client = createClient<paths>({ baseUrl: ncResource.baseUrl });
const authMiddleware: Middleware = {
async onRequest({ request, options }) {
// fetch token, if it doesn’t exist
// add Authorization header to every request
request.headers.set("Authorization", `Basic ${btoa((userId || ncResource.username) + ':' + ncResource.password)}`);
if (useAppApiAuth) {
request.headers.set("AA-VERSION", "2.3.0",);
request.headers.set("EX-APP-ID", "flow",);
request.headers.set("EX-APP-VERSION", "1.0.1",);
request.headers.set("AUTHORIZATION-APP-API", btoa(
`${userId || ncResource.username}:${ncResource.password}`,
));
}
return request;
},
};
client.use(authMiddleware);
const resp = await client.POST("/index.php/apps/tables/api/1/tables/{tableId}/rows", {
params: {
header: {
"OCS-APIRequest": true,
},
query: {
format: "json",
},
path: {
tableId: tableId,
},
},
body: {
data: data
},
});
return resp.data;
}
Submitted by nextcloud 6 days ago
import * as wmill from "windmill-client";
import createClient, { type Middleware } from "openapi-fetch";
interface Data {
[p: number]: any
}
export async function main(
nextcloudResource: string,
userId: string | null = null,
tableId: number,
data: Data,
useAppApiAuth: boolean = false,
) {
const ncResource = await wmill.getResource(
nextcloudResource,
);
const client = createClient<paths>({ baseUrl: ncResource.baseUrl });
const authMiddleware: Middleware = {
async onRequest({ request, options }) {
// fetch token, if it doesn’t exist
// add Authorization header to every request
request.headers.set("Authorization", `Basic ${btoa((userId || ncResource.username) + ':' + ncResource.password)}`);
if (useAppApiAuth) {
request.headers.set("AA-VERSION", "2.3.0",);
request.headers.set("EX-APP-ID", "flow",);
request.headers.set("EX-APP-VERSION", "1.0.1",);
request.headers.set("AUTHORIZATION-APP-API", btoa(
`${userId || ncResource.username}:${ncResource.password}`,
));
}
return request;
},
};
client.use(authMiddleware);
const resp = await client.POST("/index.php/apps/tables/api/1/tables/{tableId}/rows", {
params: {
header: {
"OCS-APIRequest": true,
},
query: {
format: "json",
},
path: {
tableId: tableId,
},
},
body: {
data: data
},
});
return resp.data;
}
Submitted by nextcloud 10 days ago