Динамические Заголовки Ресурса

Я хотел бы, чтобы служба предоставляла ресурс, как показано в следующем коде:

   angular.module('myApp.userService', ['ngResource'])
  .factory('UserService', function ($resource)
  {
    var user = $resource('/api/user', {},
          {
            connect: { method: 'POST', params: {}, isArray:false }
          });
    return user;
  }

Затем при использованииconnect действие, я хотел бы динамически передавать заголовок HTTP, что означает, что он может меняться при каждом вызове. Вот пример, в контроллере, пожалуйста, смотрите комментарий в коде:

 $scope.user = UserService;

 $scope.connect = function ( user )
        {
          var hash = 'Basic ' + Base64Service.encode(user.login + ':' + user.password);

          // I would like this header to be computed 
          // and used by the user resource
          //  each time I call this function
          $scope.user.headers = [{Authorization: hash}];

          $scope.user.connect( {},
              function()
              {
                  // successful login
                  $location.path('/connected');
              }
              ,function()
              {
                  console.log('There was an error, please try again');
              });
       }

Вы знаете способ сделать это, напрямую или с помощью трюка?

Последние мысли

Принятый ответ не полностью отвечает на вопрос, так как заголовки не являются полностью динамическими, потому что фабрика возвращает фактически фабрику (!), Что не так в моем коде.

Поскольку $ resource является фабрикой, нет способа сделать ее динамичной.

Я наконец уничтожаю объект ресурса каждый раз, когда пользователь подключается. Таким образом, у меня есть ресурс с заголовком, который вычисляется при подключении пользователя.

Решение, предоставленное @Stewie, полезно для этого, поэтому я сохраняю его как принятый.

Вот как я сделал подключение, которое можно использовать несколько раз, поскольку ресурс уничтожается / воссоздается при (повторном) подключении:

 this.connect = function (user)
 {
    self.hash = 'Basic ' + Base64Service.encode(user.login + ':' + user.password);
console.log("CONNECT login:" + user.login + " - pwd:" + user.password + " - hash:" + self.hash);

if (self.userResource)
{
  delete self.userResource;
}

self.userResource = $resource('/api/user/login', {}, {
  connect: {
    method: 'POST',
    params: {},
    isArray: false,
    headers: { Authorization: self.hash }
  }
});

var deferred = $q.defer();
self.userResource.connect(user,
  function (data)
  {
    //console.log('--------- user logged in ----- ' + JSON.stringify(data));
    // successful login
    if (!!self.user)
    {
      angular.copy(data, self.user);
    }
    else
    {
      self.user = data;
    }

    self.setConnected();

    storage.set('user', self);

    deferred.resolve(self);
  },
  function (error)
  {
    self.user = {};
    self.isLogged = false;

    storage.set('user', self);

    deferred.reject(error);
  }
);

return deferred.promise;

};

Ответы на вопрос(2)

Ваш ответ на вопрос