Annotation of embedaddon/strongswan/src/manager/storage.c, revision 1.1

1.1     ! misho       1: /*
        !             2:  * Copyright (C) 2007 Martin Willi
        !             3:  * HSR Hochschule fuer Technik Rapperswil
        !             4:  *
        !             5:  * This program is free software; you can redistribute it and/or modify it
        !             6:  * under the terms of the GNU General Public License as published by the
        !             7:  * Free Software Foundation; either version 2 of the License, or (at your
        !             8:  * option) any later version.  See <http://www.fsf.org/copyleft/gpl.txt>.
        !             9:  *
        !            10:  * This program is distributed in the hope that it will be useful, but
        !            11:  * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
        !            12:  * or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
        !            13:  * for more details.
        !            14:  */
        !            15: 
        !            16: #include "storage.h"
        !            17: 
        !            18: #include <library.h>
        !            19: #include <crypto/hashers/hasher.h>
        !            20: 
        !            21: 
        !            22: typedef struct private_storage_t private_storage_t;
        !            23: 
        !            24: /**
        !            25:  * private data of storage
        !            26:  */
        !            27: struct private_storage_t {
        !            28: 
        !            29:        /**
        !            30:         * public functions
        !            31:         */
        !            32:        storage_t public;
        !            33: 
        !            34:        /**
        !            35:         * database connection
        !            36:         */
        !            37:        database_t *db;
        !            38: };
        !            39: 
        !            40: METHOD(storage_t, login, int,
        !            41:        private_storage_t *this, char *username, char *password)
        !            42: {
        !            43:        hasher_t *hasher;
        !            44:        chunk_t hash, data, hex_str;
        !            45:        size_t username_len, password_len;
        !            46:        int uid = 0;
        !            47:        enumerator_t *enumerator;
        !            48: 
        !            49:        /* hash = SHA1( username | password ) */
        !            50:        hasher = lib->crypto->create_hasher(lib->crypto, HASH_SHA1);
        !            51:        if (hasher == NULL)
        !            52:        {
        !            53:                return 0;
        !            54:        }
        !            55:        hash = chunk_alloca(hasher->get_hash_size(hasher));
        !            56:        username_len = strlen(username);
        !            57:        password_len = strlen(password);
        !            58:        data = chunk_alloca(username_len + password_len);
        !            59:        memcpy(data.ptr, username, username_len);
        !            60:        memcpy(data.ptr + username_len, password, password_len);
        !            61:        if (!hasher->get_hash(hasher, data, hash.ptr))
        !            62:        {
        !            63:                hasher->destroy(hasher);
        !            64:                return 0;
        !            65:        }
        !            66:        hasher->destroy(hasher);
        !            67:        hex_str = chunk_to_hex(hash, NULL, FALSE);
        !            68: 
        !            69:        enumerator = this->db->query(this->db,
        !            70:                        "SELECT oid FROM users WHERE username = ? AND password = ?;",
        !            71:                        DB_TEXT, username, DB_TEXT, hex_str.ptr,
        !            72:                        DB_INT);
        !            73:        if (enumerator)
        !            74:        {
        !            75:                enumerator->enumerate(enumerator, &uid);
        !            76:                enumerator->destroy(enumerator);
        !            77:        }
        !            78:        free(hex_str.ptr);
        !            79:        return uid;
        !            80: }
        !            81: 
        !            82: METHOD(storage_t, create_gateway_enumerator, enumerator_t*,
        !            83:        private_storage_t *this, int user)
        !            84: {
        !            85:        enumerator_t *enumerator;
        !            86: 
        !            87:        enumerator = this->db->query(this->db,
        !            88:                        "SELECT gateways.oid AS gid, name, port, address FROM "
        !            89:                        "gateways, user_gateway AS ug ON gid = ug.gateway WHERE ug.user = ?;",
        !            90:                        DB_INT, user,
        !            91:                        DB_INT, DB_TEXT, DB_INT, DB_TEXT);
        !            92:        if (!enumerator)
        !            93:        {
        !            94:                enumerator = enumerator_create_empty();
        !            95:        }
        !            96:        return enumerator;
        !            97: }
        !            98: 
        !            99: METHOD(storage_t, destroy, void,
        !           100:        private_storage_t *this)
        !           101: {
        !           102:        this->db->destroy(this->db);
        !           103:        free(this);
        !           104: }
        !           105: 
        !           106: /*
        !           107:  * see header file
        !           108:  */
        !           109: storage_t *storage_create(char *uri)
        !           110: {
        !           111:        private_storage_t *this;
        !           112: 
        !           113:        INIT(this,
        !           114:                .public = {
        !           115:                        .login = _login,
        !           116:                        .create_gateway_enumerator = _create_gateway_enumerator,
        !           117:                        .destroy = _destroy,
        !           118:                },
        !           119:                .db = lib->db->create(lib->db, uri),
        !           120:        );
        !           121:        if (this->db == NULL)
        !           122:        {
        !           123:                free(this);
        !           124:                return NULL;
        !           125:        }
        !           126:        return &this->public;
        !           127: }
        !           128: 

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>