| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231 | <!DOCTYPE html><html lang="en"><head>    <meta charset="utf-8">    <title>JSDoc: Source: src/common.js</title>    <script src="scripts/prettify/prettify.js"> </script>    <script src="scripts/prettify/lang-css.js"> </script>    <!--[if lt IE 9]>      <script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>    <![endif]-->    <link type="text/css" rel="stylesheet" href="styles/prettify-tomorrow.css">    <link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css"></head><body><div id="main">    <h1 class="page-title">Source: src/common.js</h1>            <section>        <article>            <pre class="prettyprint source linenums"><code>/* * * Copyright 2015, Google Inc. * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are * met: * *     * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. *     * Redistributions in binary form must reproduce the above * copyright notice, this list of conditions and the following disclaimer * in the documentation and/or other materials provided with the * distribution. *     * Neither the name of Google Inc. nor the names of its * contributors may be used to endorse or promote products derived from * this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * *//** * This module contains functions that are common to client and server * code. None of them should be used directly by gRPC users. * @module */'use strict';var _ = require('lodash');/** * Get a function that deserializes a specific type of protobuf. * @param {function()} cls The constructor of the message type to deserialize * @param {bool=} binaryAsBase64 Deserialize bytes fields as base64 strings *     instead of Buffers. Defaults to false * @param {bool=} longsAsStrings Deserialize long values as strings instead of *     objects. Defaults to true * @return {function(Buffer):cls} The deserialization function */exports.deserializeCls = function deserializeCls(cls, binaryAsBase64,                                                 longsAsStrings) {  if (binaryAsBase64 === undefined || binaryAsBase64 === null) {    binaryAsBase64 = false;  }  if (longsAsStrings === undefined || longsAsStrings === null) {    longsAsStrings = true;  }  /**   * Deserialize a buffer to a message object   * @param {Buffer} arg_buf The buffer to deserialize   * @return {cls} The resulting object   */  return function deserialize(arg_buf) {    // Convert to a native object with binary fields as Buffers (first argument)    // and longs as strings (second argument)    return cls.decode(arg_buf).toRaw(binaryAsBase64, longsAsStrings);  };};var deserializeCls = exports.deserializeCls;/** * Get a function that serializes objects to a buffer by protobuf class. * @param {function()} Cls The constructor of the message type to serialize * @return {function(Cls):Buffer} The serialization function */exports.serializeCls = function serializeCls(Cls) {  /**   * Serialize an object to a Buffer   * @param {Object} arg The object to serialize   * @return {Buffer} The serialized object   */  return function serialize(arg) {    return new Buffer(new Cls(arg).encode().toBuffer());  };};var serializeCls = exports.serializeCls;/** * Get the fully qualified (dotted) name of a ProtoBuf.Reflect value. * @param {ProtoBuf.Reflect.Namespace} value The value to get the name of * @return {string} The fully qualified name of the value */exports.fullyQualifiedName = function fullyQualifiedName(value) {  if (value === null || value === undefined) {    return '';  }  var name = value.name;  var parent_name = fullyQualifiedName(value.parent);  if (parent_name !== '') {    name = parent_name + '.' + name;  }  return name;};var fullyQualifiedName = exports.fullyQualifiedName;/** * Wrap a function to pass null-like values through without calling it. If no * function is given, just uses the identity; * @param {?function} func The function to wrap * @return {function} The wrapped function */exports.wrapIgnoreNull = function wrapIgnoreNull(func) {  if (!func) {    return _.identity;  }  return function(arg) {    if (arg === null || arg === undefined) {      return null;    }    return func(arg);  };};/** * Return a map from method names to method attributes for the service. * @param {ProtoBuf.Reflect.Service} service The service to get attributes for * @param {Object=} options Options to apply to these attributes * @return {Object} The attributes map */exports.getProtobufServiceAttrs = function getProtobufServiceAttrs(service,                                                                   options) {  var prefix = '/' + fullyQualifiedName(service) + '/';  var binaryAsBase64, longsAsStrings;  if (options) {    binaryAsBase64 = options.binaryAsBase64;    longsAsStrings = options.longsAsStrings;  }  return _.object(_.map(service.children, function(method) {    return [_.camelCase(method.name), {      path: prefix + method.name,      requestStream: method.requestStream,      responseStream: method.responseStream,      requestType: method.resolvedRequestType,      responseType: method.resolvedResponseType,      requestSerialize: serializeCls(method.resolvedRequestType.build()),      requestDeserialize: deserializeCls(method.resolvedRequestType.build(),                                     binaryAsBase64, longsAsStrings),      responseSerialize: serializeCls(method.resolvedResponseType.build()),      responseDeserialize: deserializeCls(method.resolvedResponseType.build(),                                     binaryAsBase64, longsAsStrings)    }];  }));};/** * The logger object for the gRPC module. Defaults to console. */exports.logger = console;/** * The current logging verbosity. 0 corresponds to logging everything */exports.logVerbosity = 0;/** * Log a message if the severity is at least as high as the current verbosity * @param {Number} severity A value of the grpc.logVerbosity map * @param {String} message The message to log */exports.log = function log(severity, message) {  if (severity >= exports.logVerbosity) {    exports.logger.error(message);  }};</code></pre>        </article>    </section></div><nav>    <h2><a href="index.html">Home</a></h2><h3>Modules</h3><ul><li><a href="module-src_client.html">src/client</a></li><li><a href="module-src_common.html">src/common</a></li><li><a href="module-src_credentials.html">src/credentials</a></li><li><a href="module-src_metadata.html">src/metadata</a></li><li><a href="module-src_server.html">src/server</a></li></ul><h3>Classes</h3><ul><li><a href="module-src_client.makeClientConstructor-Client.html">Client</a></li><li><a href="module-src_client-ClientDuplexStream.html">ClientDuplexStream</a></li><li><a href="module-src_client-ClientReadableStream.html">ClientReadableStream</a></li><li><a href="module-src_client-ClientWritableStream.html">ClientWritableStream</a></li><li><a href="module-src_metadata-Metadata.html">Metadata</a></li><li><a href="module-src_server-Server.html">Server</a></li><li><a href="module-src_server-ServerDuplexStream.html">ServerDuplexStream</a></li><li><a href="module-src_server-ServerReadableStream.html">ServerReadableStream</a></li><li><a href="module-src_server-ServerWritableStream.html">ServerWritableStream</a></li></ul><h3>Global</h3><ul><li><a href="global.html#callError">callError</a></li><li><a href="global.html#credentials">credentials</a></li><li><a href="global.html#getClientChannel">getClientChannel</a></li><li><a href="global.html#load">load</a></li><li><a href="global.html#loadObject">loadObject</a></li><li><a href="global.html#logVerbosity">logVerbosity</a></li><li><a href="global.html#makeGenericClientConstructor">makeGenericClientConstructor</a></li><li><a href="global.html#Metadata">Metadata</a></li><li><a href="global.html#propagate">propagate</a></li><li><a href="global.html#Server">Server</a></li><li><a href="global.html#ServerCredentials">ServerCredentials</a></li><li><a href="global.html#setLogger">setLogger</a></li><li><a href="global.html#setLogVerbosity">setLogVerbosity</a></li><li><a href="global.html#status">status</a></li><li><a href="global.html#waitForClientReady">waitForClientReady</a></li><li><a href="global.html#writeFlags">writeFlags</a></li></ul></nav><br class="clear"><footer>    Documentation generated by <a href="https://github.com/jsdoc3/jsdoc">JSDoc 3.4.0</a> on Thu Aug 18 2016 12:19:14 GMT-0700 (PDT)</footer><script> prettyPrint(); </script><script src="scripts/linenumber.js"> </script></body></html>
 |