be709e4f90
security fix OBS-URL: https://build.opensuse.org/request/show/73431 OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/unixODBC?expand=0&rev=12
27 lines
980 B
Diff
27 lines
980 B
Diff
--- trunk/DriverManager/SQLDriverConnect.c 2011/01/12 15:50:07 23
|
|
+++ trunk/DriverManager/SQLDriverConnect.c 2011/03/09 15:38:55 27
|
|
@@ -664,7 +664,7 @@
|
|
{
|
|
DMHDBC connection = (DMHDBC)hdbc;
|
|
struct con_struct con_struct;
|
|
- char *driver, *dsn = NULL, *filedsn, *tsavefile, savefile[ 128 ];
|
|
+ char *driver, *dsn = NULL, *filedsn, *tsavefile, savefile[ INI_MAX_PROPERTY_VALUE + 1 ];
|
|
char lib_name[ INI_MAX_PROPERTY_VALUE + 1 ];
|
|
char driver_name[ INI_MAX_PROPERTY_VALUE + 1 ];
|
|
SQLRETURN ret_from_connect;
|
|
@@ -969,7 +969,13 @@
|
|
tsavefile = __get_attribute_value( &con_struct, "SAVEFILE" );
|
|
if ( tsavefile )
|
|
{
|
|
- strcpy( savefile, tsavefile );
|
|
+ if ( strlen( tsavefile ) > INI_MAX_PROPERTY_VALUE ) {
|
|
+ memcpy( savefile, tsavefile, INI_MAX_PROPERTY_VALUE );
|
|
+ savefile[ INI_MAX_PROPERTY_VALUE ] = '\0';
|
|
+ }
|
|
+ else {
|
|
+ strcpy( savefile, tsavefile );
|
|
+ }
|
|
}
|
|
else
|
|
{
|