Research
Security News
Malicious npm Packages Inject SSH Backdoors via Typosquatted Libraries
Socket’s threat research team has detected six malicious npm packages typosquatting popular libraries to insert SSH backdoors.
Import the data at a high speed to the table from a text file, using the MySQL LOAD DATA INFILE
statement.
This gem is dependent on mysql2.
By using mysql2, as well as plugin of ActiveRecord, it is possible to use in pure Ruby script.
Add to your Gemfile:
gem 'load_data_infile2'
And bundle.
Database configuration:
db_config = {
host: 'localhost'
database: 'ldi_test'
username: 'root'
}
Create client:
ldi_client = LoadDataInfile2::Client.new(db_config)
Import from CSV file:
ldi_client.import('/path/to/data.csv')
Default options are CSV format:
module LoadDataInfile2
class << self
def default_import_options
@default_import_options ||= {
fields_terminated_by: ',', # CSV
fields_optionally_enclosed_by: '"', # standard format of CSV
fields_escaped_by: '"', # standard format of CSV
lines_terminated_by: "\\n",
ignore_lines: 0
}
end
end
end
If you are using TSV format:
opts = {
fileds_terminated_by: "\\t",
fields_optionally_enclosed_by: "",
fields_escaped_by: "\\"
}
ldi_client = LoadDataInfile2::Client.new(db_config, opts)
ldi_client.import('/path/to/data.tsv')
If you use LOCAL
option:
opts = { local_infile: true }
ldi_client = LoadDataInfile2::Client.new(db_config, opts)
ldi_client.import('/path/to/data.csv')
# => Execute "LOAD DATA LOCAL INFILE '/path/to/data.csv' INTO TABLE `ldi_test`.`data`;"
Support all options of LOAD DATA INFILE statement on MySQL 5.7 .
see: http://dev.mysql.com/doc/refman/5.7/en/load-data.html
For examples:
opts = { local_infile: true }
sql_opts = { table: 'special_users', ignore_lines: 1 }
ldi_client = LoadDataInfile2::Client.new(db_config, opts)
ldi_client.import('/path/to/users.csv', sql_opts)
MySQL | LoadDataInfile2 |
---|---|
LOW_PRIORITY | low_priority_or_concurrent: :low_priority |
CONCURRENT | low_priority_or_concurrent: :concurrent |
LOCAL | local_infile: true |
REPLACE | replace_or_ignore: :replace |
IGNORE | replace_or_ignore: :ignore |
tbl_name | table: 'special_table_name' |
PARTITION | partition: 'p0' / ['p0', 'p1', ...] |
CHARCTER SET | charset: 'utf8' |
FIELDS TERMINATED BY | fields_terminated_by: ',' |
FIELDS ENCLOSED BY | fields_enclosed_by: '"' |
FIELDS OPTIONALLY ENCLOSED BY | fields_optionally_enclosed_by: '"' |
FIELDS ESCAPED BY | fields_escaped_by: '"' |
LINES STARTING BY | lines_starting_by: '***' |
LINES TERMINATED BY | lines_terminated_by: '\n' |
IGNORE LINES | ignore_lines: 1 |
col_name_or_user_var | columns: ['col1', 'col2', '@var3', ...] |
SET col_name = expr | set: { col1: "'specific value'", col2: '@var', col3: 'NOW()' } |
Subclass of ActiveRecord is added .load_data_infile
.
For example, in the case of User model, you can call the class method named load_data_infile
from the User model.
User.load_data_infile('/path/to/data.csv')
If you want to pass options to the initialization of LoadDataInfile2::ActiveRecord
, you can use the accessor of class variable named .default_load_data_infile_options
.
User.default_load_data_infile_options = { ignore_lines: 1 }
User.load_data_infile('/path/to/data.csv')
Bug reports and pull requests are welcome on GitHub at https://github.com/nalabjp/load_data_infile2.
MIT License
The gem is available as open source under the terms of the MIT License.
FAQs
Unknown package
We found that load_data_infile2 demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
Security News
Socket’s threat research team has detected six malicious npm packages typosquatting popular libraries to insert SSH backdoors.
Security News
MITRE's 2024 CWE Top 25 highlights critical software vulnerabilities like XSS, SQL Injection, and CSRF, reflecting shifts due to a refined ranking methodology.
Security News
In this segment of the Risky Business podcast, Feross Aboukhadijeh and Patrick Gray discuss the challenges of tracking malware discovered in open source softare.