HEX
Server: nginx/1.18.0
System: Linux test-ipsremont 5.4.0-214-generic #234-Ubuntu SMP Fri Mar 14 23:50:27 UTC 2025 x86_64
User: ips (1000)
PHP: 8.0.30
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/europequiz/node_modules/oauth-1.0a/test/oauth_body_hash.js
var expect = require('chai').expect;
var OAuth = require('../oauth-1.0a');
var crypto = require('crypto');

describe("OAuth Body Hash", function() {
  var oauth, request;

  beforeEach(function() {
    var algo = 'sha1';
    var enc = 'base64';

    oauth = new OAuth({
      consumer: {
        key: '1434affd-4d69-4a1a-bace-cc5c6fe493bc',
        secret: '932a216f-fb94-43b6-a2d2-e9c6b345cbea'
      },
      signature_method: 'HMAC-SHA1',
      hash_function: function (base_string, key) {
        return crypto.createHmac(algo, key).update(base_string).digest(enc);
      },
      body_hash_function: function (data) {
        return crypto.createHash(algo).update(data).digest(enc);
      }
    });

    //overide for testing only !!!
    oauth.getTimeStamp = function () {
      return 1484599369;
    };

    //overide for testing only !!!
    oauth.getNonce = function (length) {
      return 't62lMDp9DLwKZJJbZTpmSAhRINGBEOcF';
    };

    request = {
      url: 'http://canvas.docker/api/lti/accounts/1/tool_proxy',
      method: 'POST',
      data: {
        "@context": [
          "http://purl.imsglobal.org/ctx/lti/v2/ToolProxy"
        ],
        "@type": "ToolProxy",
        "lti_version": "LTI-2p1",
        "tool_proxy_guid": "0cf04d67-8a0d-4d41-af61-6e8c6fc3e68c",
        "tool_consumer_profile": "http://canvas.docker/api/lti/accounts/1/tool_consumer_profile/339b6700-e4cb-47c5-a54f-3ee0064921a9",
        "tool_profile": {
          "lti_version": "LTI-2p1",
          "product_instance": {
            "guid": "fd75124a-140e-470f-944c-114d2d93db40",
            "product_info": {
              "product_name": {
                "default_value": "TestTool",
                "key": "tool.name"
              },
              "product_version": "0.1.0",
              "product_family": {
                "code": "testtool",
                "vendor": {
                  "code": "Example.com",
                  "vendor_name": {
                    "default_value": "Example",
                    "key": "tool.vendor.name"
                  }
                }
              }
            }
          },
          "base_url_choice": [
            {
              "default_base_url": "http://example.docker/",
              "selector": {
                "applies_to": [
                  "MessageHandler"
                ]
              }
            }
          ],
          "resource_handler": [
            {
              "resource_type": {
                "code": "testtool"
              },
              "resource_name": {
                "default_value": "TestTool",
                "key": "testtool.resource.name"
              },
              "message": [
                {
                  "message_type": "basic-lti-launch-request",
                  "path": "lti_launch",
                  "enabled_capability": [
                    "Canvas.placements.courseNavigation"
                  ]
                }
              ]
            }
          ]
        },
        "enabled_capability": [
          "OAuth.splitSecret"
        ],
        "security_contract": {
          "tp_half_shared_secret": "1c7849d3c9f037a9891575c8508d3aaab6a9e1312b5d0353625f83d68f0d545344f81ff9e1849b6400982a0d3f6bf953c6095265e3b6d700a73f5be94ce5654c"
        }
      },
      includeBodyHash: true
    };
  });

  describe('#getBodyHash', function() {
    it('should handle data encoded as an object', function() {
      expect(oauth.getBodyHash(request, '')).to.equal('xpJzRG6xylVIRRtiigLPKX7iRmM=')
    });

    it('should handle data encoded as a string', function() {
      request.data = 'Hello World!';
      expect(oauth.getBodyHash(request, '')).to.equal('Lve95gjOVATpfV8EL5X4nxwjKHE=')
    });
  });

  describe('#authorize', function() {
    it('should properly include an oauth_body_hash param', function() {
      expect(oauth.authorize(request)).to.eql({
        oauth_consumer_key: '1434affd-4d69-4a1a-bace-cc5c6fe493bc',
        oauth_nonce: 't62lMDp9DLwKZJJbZTpmSAhRINGBEOcF',
        oauth_signature_method: 'HMAC-SHA1',
        oauth_timestamp: 1484599369,
        oauth_version: '1.0',
        oauth_body_hash: 'xpJzRG6xylVIRRtiigLPKX7iRmM=',
        oauth_signature: '1Q0U8yhK1bWYguRxlUDs9KHywOE='
      });
    });
  });

  describe('#toHeader', function() {
    it('should properly include an oauth_body_hash header', function() {
      expect(oauth.toHeader(oauth.authorize(request))).to.have.property('Authorization', 'OAuth oauth_body_hash="xpJzRG6xylVIRRtiigLPKX7iRmM%3D", oauth_consumer_key="1434affd-4d69-4a1a-bace-cc5c6fe493bc", oauth_nonce="t62lMDp9DLwKZJJbZTpmSAhRINGBEOcF", oauth_signature="1Q0U8yhK1bWYguRxlUDs9KHywOE%3D", oauth_signature_method="HMAC-SHA1", oauth_timestamp="1484599369", oauth_version="1.0"');
    });
  });
});