with Prerender.io and Odoo?
Prerender.io is an API that enhances SEO by allowing servers to return fully rendered HTML pages to search engines and social media crawlers, ensuring that these services can index and display web content efficiently. Utilizing Prerender.io with Pipedream, developers can automate the caching and serving of rendered pages, monitor and manage the performance of their prerendered content, and integrate SEO enhancement processes into broader application workflows.
import { axios } from "@pipedream/platform"
export default defineComponent({
props: {
prerender: {
type: "app",
app: "prerender",
}
},
async run({steps, $}) {
return await axios($, {
url: `https://api.prerender.io/recache`,
method: `post`,
data: {
prerenderToken: this.prerender.$auth.token,
url: "http://www.example.com/url/to/recache"
},
})
},
})
import xmlrpc from 'xmlrpc';
export default defineComponent({
props: {
odoo: {
type: "app",
app: "odoo",
}
},
async run({ steps, $ }) {
const url = this.odoo.$auth.server_url;
const db = this.odoo.$auth.db;
const username = this.odoo.$auth.username;
const password = this.odoo.$auth.password;
// Create clients for common and object endpoints
const common = xmlrpc.createSecureClient(`${url}/xmlrpc/2/common`);
const models = xmlrpc.createSecureClient(`${url}/xmlrpc/2/object`);
// Using async/await with promises
async function getFields() {
try {
// Authenticate and get uid
const uid = await new Promise((resolve, reject) => {
common.methodCall('authenticate', [db, username, password, {}], (error, value) => {
if (error) reject(error);
resolve(value);
});
});
// Get fields
const results = await new Promise((resolve, reject) => {
models.methodCall('execute_kw', [
db,
uid,
password,
'res.partner',
'fields_get',
[],
{ 'attributes': ['string', 'help', 'type'] }
], (error, value) => {
if (error) reject(error);
resolve(value);
});
});
return results;
} catch (error) {
throw new Error(error);
}
}
return await getFields();
},
})