Security News
Introducing the Socket Python SDK
The initial version of the Socket Python SDK is now on PyPI, enabling developers to more easily interact with the Socket REST API in Python projects.
@murasoftware/mura
Advanced tools
Mura.js is javscript utility to interact with the Mura CMS JSON/REST API
Mura CMS is an open source content management system for CFML, created by Blue River Interactive Group. Mura has been designed to be used by marketing departments, web designers and developers.
<script src="https://domain.com/core/modules/v1/core_assets/js/mura.min.js"></script>
Babel is a next generation JavaScript compiler. One of the features is the ability to use ES6/ES2015 modules now, even though browsers do not yet support this feature natively.
import Mura from "mura.js";
There are several ways to use Browserify and Webpack. For more information on using these tools, please refer to the corresponding project's documention. In the script, including jQuery will usually look like this...
var Mura = require("mura.js");
AMD is a module format built for the browser. For more information, we recommend require.js' documentation.
define(["mura.js"], function(Mura) {
});
Mura.init(
{
siteid:'YOUR_SITEID',
rootpath:'https://domain.com'
}
);
Mura(function(Mura){
Mura.addEventHandler(
{
asyncObjectRendered:function(event){
alert(this.innerHTML);
}
}
);
Mura('#my-id').addDisplayObject('objectname',{..});
Mura.login('userame','password')
.then(function(data){
alert(data.success);
});
Mura.logout())
.then(function(data){
alert('you have logged out!');
});
Mura.renderFilename('')
.then(function(item){
alert(item.get('title'));
});
Mura.getEntity('content').loadBy('contentid','${contentid}')
.then(function(item){
alert(item.get('title'));
});
Mura.getEntity('content').loadBy('contentid','${contentid}')
.then(function(item){
item.get('kids').then(function(kids){
alert(kids.get('items').length);
});
});
Mura.getEntity('content').loadBy('contentid','${contentid}')
.then(function(item){
item.get('parent').then(function(parent){
alert(parent.get('title'));
});
});
Mura.getEntity('content').
.set('parentid''${contentid}')
.set('approved',1)
.set('title','test 5')
.save()
.then(function(item){
alert(item.get('title'));
});
Mura.getEntity('content').
.set(
{
parentid:'${contentid}',
approved:1,
title:'test 5'
}
.save()
.then(
function(item){
alert(item.get('title'));
});
Mura.getFeed('content')
.where()
.prop('title').isEQ('About')
.andProp('type').isEQ('Page')
.getQuery()
.then(function(collection){
alert(collection.item(0).get('title'));
});
});
If you want client cookie support you must use a custom RequestContext that contains the current executions request and response objects.
const express = require('express');
const app = express();
const env = {
siteid:'default',
rootpath:'http://localhost:8080'
};
app.get('/', function (req, res) {
let Mura=require('mura.js');
Mura.init(Mura.extend(
{
request:req,
response:res
},
env
)
);
Mura.renderFilename('about').then(
function(content){
res.send("<br/>rendered content:<pre>" + JSON.stringify(content.getAll()) + "</pre>")
},
function(error){
console.log(error);
}
);
});
app.get('/content', function (req, res) {
let Mura=require('mura.js');
Mura.init(Mura.extend(
{
request:req,
response:res
},
env
)
);
Mura.getFeed('content')
.getQuery()
.then(function(items){
res.send("<br/>content feed:<pre>" + JSON.stringify(items.getAll()) + "</pre>");
});
})
app.listen(3000, function () {
console.log('Example app listening on port 3000!')
})
const express = require('express')
const app = express()
const env = {
siteid:'default',
rootpath:'http://localhost:8080',
mode:'REST'
};
app.get('/', function (req, res) {
let Mura=require('../index');
Mura.init({
siteid:'default',
rootpath:'http://localhost:8080'
mode:'REST'
});
//Per Execution Request Headers
Mura.setRequestHeader('Authorization','Bearer: ...');
Mura .renderFilename('about').then(
function(content){
res.send("<br/>rendered content:<pre>" + JSON.stringify(content.getAll()) + "</pre>")
},
function(error){
console.log(error);
}
);
});
FAQs
Utility for interacting with the Mura JSON/REST API
We found that @murasoftware/mura demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
The initial version of the Socket Python SDK is now on PyPI, enabling developers to more easily interact with the Socket REST API in Python projects.
Security News
Floating dependency ranges in npm can introduce instability and security risks into your project by allowing unverified or incompatible versions to be installed automatically, leading to unpredictable behavior and potential conflicts.
Security News
A new Rust RFC proposes "Trusted Publishing" for Crates.io, introducing short-lived access tokens via OIDC to improve security and reduce risks associated with long-lived API tokens.