How to use the rhea.sasl_server_mechanisms function in rhea

To help you get started, we’ve selected a few rhea examples, based on popular ways it is used in public projects.

Secure your code as it's written. Use Snyk Code to scan source code in minutes - no build needed - and fix issues immediately.

github mthirion / microsaga / cards / src / main / amq / node_modules / rhea / examples / sasl / sasl_plain_server.js View on Github external
'p': { alias: 'port', default: 5672, describe: 'port to listen on'}
    }).help('help').argv;

/**
 * To authenticate using PLAIN and a simple username and password
 * combination, the application provides a callback function for
 * authenticating a connecting user given their specified username and
 * password. (The test used here - namely that the password is always
 * the username in reverse - is of course NOT recommended in practice!
 * :-)
 */
function authenticate(username, password) {
    console.log('Authenticating as ' + username);
    return username.split("").reverse().join("") === password;
}
container.sasl_server_mechanisms.enable_plain(authenticate);
var server = container.listen({'port':args.port});
container.on('connection_open', function (context) {
    context.connection.local.open.properties = {'foo':'abc'};
    console.log('Connected!');
});
github amqp / rhea / examples / sasl / sasl_plain_server.js View on Github external
/**
 * To authenticate using PLAIN and a simple username and password
 * combination, the application provides a callback function for
 * authenticating a connecting user given their specified username and
 * password.  The callback may provide either a boolean or a promise
 * yielding a boolean.
 *
 * (The test used here - namely that the password is always
 * the username in reverse - is of course NOT recommended in practice!
 * :-)
 */
function authenticate(username, password) {
        console.log('Authenticating as ' + username);
    return username.split('').reverse().join('') === password;
}
container.sasl_server_mechanisms.enable_plain(authenticate);
var server = container.listen({ port: args.port, host: args.host });
container.on('connection_open', function (context) {
    console.log('Connected!');
});
github amqp / rhea / examples / sasl / sasl_anonymous_server.js View on Github external
*
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
var container = require('rhea');
var args = require('../options.js').options({
    'h': { alias: 'host', default: 'localhost', describe: 'dns or ip name of server where you want to connect'},
    'p': { alias: 'port', default: 5672, describe: 'port to listen on'}
}).help('help').argv;

container.sasl_server_mechanisms.enable_anonymous();
var server = container.listen({ port: args.port, host: args.host });
container.on('connection_open', function (context) {
    console.log('Connected!');
});
github mthirion / microsaga / cards / src / main / amq / node_modules / rhea / examples / sasl / sasl_anonymous_server.js View on Github external
* You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
var container = require('rhea');
var args = require('../options.js').options({
      'p': { alias: 'port', default: 5672, describe: 'port to listen on'}
    }).help('help').argv;

container.sasl_server_mechanisms.enable_anonymous();
var server = container.listen({'port':args.port});
container.on('connection_open', function (context) {
    console.log('Connected!');
});
github EnMasseProject / enmasse / none-authservice / none-authservice.js View on Github external
* distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
var container = require('rhea');
var fs = require('fs');
var path = require('path');
var cert_dir = (process.env.CERT_DIR !== undefined) ? process.env.CERT_DIR : "/opt/none-authservice/cert";

function authenticate(username, password) {
    console.log('Authenticating as ' + username);
    return true;
}
container.sasl_server_mechanisms.enable_plain(authenticate);
container.sasl_server_mechanisms.enable_anonymous();
var server = container.listen({
    port: process.env.LISTENPORT,
    require_sasl: true,
    transport: 'tls',
    key: fs.readFileSync(path.resolve(cert_dir, 'tls.key')),
    cert: fs.readFileSync(path.resolve(cert_dir, 'tls.crt'))
});

console.log('Listening on port ' + process.env.LISTENPORT);
container.on('connection_open', function (context) {
    var authenticatedIdentity = { 'sub' : context.connection.sasl_transport.username || 'anonymous' };
    var groups = [ "manage" ];
    var properties = context.connection.local.open.properties || {};
    properties["authenticated-identity"] = authenticatedIdentity;
    properties["groups"] = groups;
    context.connection.local.open.properties = properties;
github EnMasseProject / enmasse / none-authservice / none-authservice.js View on Github external
* Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
var container = require('rhea');
var fs = require('fs');
var path = require('path');
var cert_dir = (process.env.CERT_DIR !== undefined) ? process.env.CERT_DIR : "/opt/none-authservice/cert";

function authenticate(username, password) {
    console.log('Authenticating as ' + username);
    return true;
}
container.sasl_server_mechanisms.enable_plain(authenticate);
container.sasl_server_mechanisms.enable_anonymous();
var server = container.listen({
    port: process.env.LISTENPORT,
    require_sasl: true,
    transport: 'tls',
    key: fs.readFileSync(path.resolve(cert_dir, 'tls.key')),
    cert: fs.readFileSync(path.resolve(cert_dir, 'tls.crt'))
});

console.log('Listening on port ' + process.env.LISTENPORT);
container.on('connection_open', function (context) {
    var authenticatedIdentity = { 'sub' : context.connection.sasl_transport.username || 'anonymous' };
    var groups = [ "manage" ];
    var properties = context.connection.local.open.properties || {};
    properties["authenticated-identity"] = authenticatedIdentity;
    properties["groups"] = groups;