open-license-manager
2014-04-14 f77e1e4d2adf4422943c10a1906854c3027391d8
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
#include <paths.h>
#include <stdio.h>
#include <stdlib.h>
#include <cstring>
#include <string>
#include <system_error>
#include <unistd.h>
#include <sstream>
#include <sys/ioctl.h>
#include <sys/stat.h>
#include "../os.hpp"
#include "../../base/public-key.h"
#include <openssl/evp.h>
#include <openssl/bio.h>
#include <openssl/pem.h>
 
namespace license {
 
using namespace std;
 
vector<AdapterInfo> OsFunctions::getAdapterInfos() {
    return vector<AdapterInfo>();
}
vector<DiskInfo> OsFunctions::getDiskInfos() {
    struct stat filename_stat, mount_stat;
    static char discard[1024];
    char device[64], name[64], type[64];
    FILE *mounts = fopen(_PATH_MOUNTED, "r");
 
    while (fscanf(mounts, "%64s %64s %64s %1024[^\n]", device, name, type,
            discard) != EOF) {
        if (stat(device, &mount_stat) != 0)
            continue;
        if (filename_stat.st_dev == mount_stat.st_rdev)
            fprintf(stderr, "device: %s; name: %s; type: %s\n", device, name,
                    type);
    }
 
    return vector<DiskInfo>();
}
 
string OsFunctions::getModuleName() {
    char path[2048] = { 0 };
    string strPath;
    string result;
    pid_t pid = getpid();
    const string pidstr = to_string(((long) pid));
    strPath = string("/proc/") + pidstr + "/exe";
    const char * proc_path = strPath.c_str();
    int ch = readlink(proc_path, path, 2048);
    if (ch != -1) {
        path[ch] = '\0';
        result = string(path);
    } else {
        throw runtime_error(
                string("Can't find: ") + strPath + " proc filesystem mounted?");
    }
    return result;
}
 
string OsFunctions::getUserHomePath() {
    return "";
}
 
bool OsFunctions::verifySignature(const char* stringToVerify,
        const char* signature) {
    EVP_MD_CTX *mdctx = NULL;
 
    char *pubKey = PUBLIC_KEY
    ;
 
    BIO* bio = BIO_new_mem_buf((void*) (pubKey), strlen(pubKey));
    RSA *rsa = PEM_read_bio_RSAPublicKey(bio, NULL,NULL,NULL);
    BIO_free(bio);
    if (rsa == NULL) {
        throw new logic_error("Error reading public key");
    }
    EVP_PKEY *pkey = EVP_PKEY_new();
 
    EVP_PKEY_assign_RSA(pkey, rsa);
 
    /*BIO* bo = BIO_new(BIO_s_mem());
     BIO_write(bo, pubKey, strlen(pubKey));
     RSA *key = 0;
     PEM_read_bio_RSAPublicKey(bo, &key, 0, 0);
     BIO_free(bo);*/
 
    //RSA* rsa = EVP_PKEY_get1_RSA( key );
    //RSA * pubKey = d2i_RSA_PUBKEY(NULL, <der encoded byte stream pointer>, <num bytes>);
    /* Create the Message Digest Context */
    if (!(mdctx = EVP_MD_CTX_create())) {
        throw new logic_error("Error creating context");
    }
    if (1 != EVP_DigestVerifyInit(mdctx, NULL, EVP_sha256(), NULL, pkey)) {
        throw new logic_error("Error initializing digest");
    }
 
    if (1
            != EVP_DigestVerifyUpdate(mdctx, stringToVerify,
                    strlen(stringToVerify))) {
        throw new logic_error("Error initializing digest");
    }
    if (1
            == EVP_DigestVerifyFinal(mdctx, (unsigned char *) signature,
                    (unsigned long int) strlen(signature))) {
        return true;
    } else {
 
        return false;
    }
}
 
VIRTUALIZATION OsFunctions::getVirtualization() {
    //http://www.ibiblio.org/gferg/ldp/GCC-Inline-Assembly-HOWTO.html
    //
    bool rc = true;
    /*__asm__ (
            "push   %edx\n"
            "push   %ecx\n"
            "push   %ebx\n"
            "mov    %eax, 'VMXh'\n"
            "mov    %ebx, 0\n" // any value but not the MAGIC VALUE
            "mov    %ecx, 10\n"// get VMWare version
            "mov    %edx, 'VX'\n"// port number
            "in     %eax, dx\n"// read port on return EAX returns the VERSION
            "cmp    %ebx, 'VMXh'\n"// is it a reply from VMWare?
            "setz   [rc] \n"// set return value
            "pop    %ebx \n"
            "pop    %ecx \n"
            "pop    %edx \n"
    );*/
 
    return NONE;
}
 
}