view m-toolbox/classes/+utils/@credentials/credentials.m @ 41:6def6533cb16 database-connection-manager

Report authentication errors to user
author Daniele Nicolodi <nicolodi@science.unitn.it>
date Mon, 05 Dec 2011 18:04:34 +0100
parents 18e956c96a1b
children
line wrap: on
line source

classdef credentials

  properties

    hostname = [];
    database = [];
    username = [];
    password = [];
    expiry = 0;

  end % properties

  methods

    function obj = credentials(hostname, database, username, password)
    % CREDENTIALS Constructor for credentials objects.
    %
    % Those are simple container objects to hold credentials required for
    % establishing a connection to a database server, in addition to an
    % expiry time.
    %
    % CREDENTIALS(hostname, database, username, password) The constructor can
    % be called with any number of arguments. The default value for the object
    % properties is the empty vector.

      switch nargin
        case 1
          obj.hostname = hostname;
        case 2
          obj.hostname = hostname;
          obj.database = database;
        case 3
          obj.hostname = hostname;
          obj.database = database;
          obj.username = username;
        case 4
          obj.hostname = hostname;
          obj.database = database;
          obj.username = username;
          obj.password = password;
      end
    end

    function str = char(obj, mode)
    % CHAR Convert a credentials object to string representation.
    %
    % It takes an optional second argument that defines the representation to
    % use. The default is to replace the password, if present, with the YES
    % string, other possible modes are SHORT where password is omitted, or FULL
    % where the password is shown at it is.

      if nargin < 2
        mode = '';
      end
      switch mode
        case 'short'
          % do not show password
          frm = 'mysql://%s/%s username=%s';
          str = sprintf(frm, obj.hostname, obj.database, obj.username);
        case 'full'
          % show password
          frm = 'mysql://%s/%s username=%s password=%s';
          str = sprintf(frm, obj.hostname, obj.database, obj.username, obj.password);
        otherwise
          % by default only show if a password is known
          passwd = [];
          if ischar(obj.password)
            passwd = 'YES';
          end
          frm = 'mysql://%s/%s username=%s password=%s';
          str = sprintf(frm, obj.hostname, obj.database, obj.username, passwd);
      end
    end

    function disp(objs)
    % DISP Overloaded display method for credentials objects.
    %
    % Uses the default string representation of the char() method where the
    % password, if present, is replaced with the string YES.

      for obj = objs
        disp(['    ' char(obj) char(10)]);
      end
    end

    function len = length(obj)
    % LENGTH Returns the number of not null fields in the object.

      len = 0;
      if ~isempty(obj.hostname)
        len = len + 1;
      end
      if ~isempty(obj.database)
        len = len + 1;
      end
      if ~isempty(obj.username)
        len = len + 1;
      end
      if ~isempty(obj.password)
        len = len + 1;
      end
    end

    function rv = complete(obj)
    % COMPLETE Checks if the credentials are complete.
    %
    % Credentials object are complete when they contains all the required
    % information to connect to a database. Namely the HOSTNAME, DATABASE
    % and USERNAME properties should not be empty, the PASSWORD property is
    % allowed to be an empty string '' but not [].

      info = {'hostname', 'database', 'username'};
      for kk = 1:numel(info)
        if isempty(obj.(info{kk}))
          rv = false;
          return;
        end
      end
      if ~ischar(obj.password)
        rv = false;
        return;
      end
      rv = true;
    end

    function rv = expired(obj)
    % EXPIRED Checks if the credentials are expired.
    %
    % Credential objects expire when their expiry time is smaller than the
    % current time in seconds since the epoch, as obtained by the time()
    % function. Credentials with zero or negative expiry time never expire.

      rv = false;
      if obj.expiry > 0 && double(time()) > obj.expiry
        rv = true;
      end
    end

    function rv = match(obj, hostname, database, username)
    % MATCH Check if the credentials object matches the given information.
    %
    % MATCH(obj, hostname) Returns true when HOSTANAME parameter match
    % the object properties.
    %
    % MATCH(obj, hostname, database) Returns true when HOSTANAME and
    % DATABASE parameters match the object properties.
    %
    % MATCH(obj, hostname, database, username) Returns true when
    % HOSTANAME, DATABASE, and USERNAME parameters match the object
    % properties.

      % default arguments
      switch nargin
        case 4
        case 3
          username = [];
        case 2
          username = [];
          database = [];
        otherwise
          error('### wrong number of parameters');
      end

      % default return value
      rv = true;

      if ~strcmp(obj.hostname, hostname)
        rv = false;
        return;
      end
      if ischar(database) && ~strcmp(obj.database, database)
        rv = false;
        return;
      end
      if ischar(username) && ~strcmp(obj.username, username)
        rv = false;
        return;
      end
    end

  end % methods

end