2017-03-30 16:56:49 +02:00
|
|
|
/* Copyright 2017 R. Thomas
|
|
|
|
* Copyright 2017 Quarkslab
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
#include "LIEF/logging.hpp"
|
2017-07-25 17:06:30 +02:00
|
|
|
#include "LIEF/version.h"
|
2017-03-30 16:56:49 +02:00
|
|
|
#include "pyLIEF.hpp"
|
2018-09-12 14:44:18 +02:00
|
|
|
#include "pyAbstract.hpp"
|
2017-03-30 16:56:49 +02:00
|
|
|
|
2018-06-08 10:48:29 +02:00
|
|
|
#if defined(LIEF_ELF_SUPPORT)
|
|
|
|
#include "ELF/pyELF.hpp"
|
|
|
|
#endif
|
|
|
|
|
2018-06-08 14:58:00 +02:00
|
|
|
#if defined(LIEF_PE_SUPPORT)
|
|
|
|
#include "PE/pyPE.hpp"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(LIEF_MACHO_SUPPORT)
|
|
|
|
#include "MachO/pyMachO.hpp"
|
|
|
|
#endif
|
|
|
|
|
2018-05-04 12:46:28 +02:00
|
|
|
#if defined(LIEF_OAT_SUPPORT)
|
|
|
|
#include "OAT/pyOAT.hpp"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(LIEF_VDEX_SUPPORT)
|
|
|
|
#include "VDEX/pyVDEX.hpp"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(LIEF_DEX_SUPPORT)
|
|
|
|
#include "DEX/pyDEX.hpp"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(LIEF_ART_SUPPORT)
|
|
|
|
#include "ART/pyART.hpp"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
#include "platforms/android/pyAndroid.hpp"
|
|
|
|
|
|
|
|
|
2019-03-31 10:15:08 +02:00
|
|
|
PYBIND11_MODULE(lief, LIEF_module) {
|
|
|
|
|
|
|
|
LIEF_module.attr("__version__") = py::str(LIEF_VERSION);
|
|
|
|
LIEF_module.attr("__tag__") = py::str(LIEF_TAG);
|
|
|
|
LIEF_module.attr("__is_tagged__") = py::bool_(LIEF_TAGGED);
|
2020-08-24 18:44:03 +01:00
|
|
|
LIEF_module.doc() = "Python API for LIEF";
|
2017-03-30 16:56:49 +02:00
|
|
|
|
2018-03-13 16:49:02 +01:00
|
|
|
init_LIEF_Object_class(LIEF_module);
|
|
|
|
|
2017-03-30 16:56:49 +02:00
|
|
|
init_LIEF_iterators(LIEF_module);
|
|
|
|
|
2017-07-31 15:16:02 +02:00
|
|
|
init_LIEF_Logger(LIEF_module);
|
|
|
|
|
2017-03-30 16:56:49 +02:00
|
|
|
// Init custom LIEF exceptions
|
|
|
|
init_LIEF_exceptions(LIEF_module);
|
|
|
|
|
|
|
|
// Init the LIEF module
|
2018-09-12 14:44:18 +02:00
|
|
|
LIEF::init_python_module(LIEF_module);
|
2017-03-30 16:56:49 +02:00
|
|
|
|
2018-05-04 12:46:28 +02:00
|
|
|
init_hash_functions(LIEF_module);
|
|
|
|
|
Improve the ELF part of LIEF
Major changes (features):
* Enable adding multiple sections/segments - Executable (PIE or not), Library
* Enable adding multiple dynamic entries (DT_NEEDED, DT_INIT etc)
* Enable adding multiple relocations
* Enable adding multiple dynamic symbols
* Enable segment replacement
Major changes (API):
* Getters Binary::get_*name*() has been renamed to "name()"
* Binary::add(const DynamicEntry& entry) - To add an entry in the dynamic table
* Section& Binary::add(const Section& section, bool loaded = true) - To add a section(s)
* Segment& Binary::add(const Segment& segment, uint64_t base = 0) - To add segments
* Segment& replace(const Segment& new_segment, const Segment& original_segment, uint64_t base = 0)
* Binary's last_offset_section(), last_offset_segment(), next_virtual_address()
to have information about offset
* Binary's add_library(), get_library(), has_library() to handle
DT_NEEDED entries
Other changes:
* Binary::insert_content() - Use add(const Section&) or add(const Segment&) instead
* ELF's DataHandler has been cleaned
* Through LIEF::Section one can look for integers, strings, data
within the section (see LIEF::Section::search,
LIEF::Section::search_all)
* Through LIEF::Binary one can get *xref* of a number (or address)
see LIEF::Binary::xref function
* To access to the Abstract binary in Python, one can now use
the 'abstract' attribute. (e.g. binary.abstract.header.is_32)
Resolve: #83
Resolve: #66
Resolve: #48
2017-09-02 08:54:54 +02:00
|
|
|
|
2017-03-30 16:56:49 +02:00
|
|
|
// Init the ELF module
|
2017-11-18 16:37:40 +01:00
|
|
|
#if defined(LIEF_ELF_SUPPORT)
|
2018-06-08 10:48:29 +02:00
|
|
|
LIEF::ELF::init_python_module(LIEF_module);
|
2017-03-30 16:56:49 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
// Init the PE module
|
2017-11-18 16:37:40 +01:00
|
|
|
#if defined(LIEF_PE_SUPPORT)
|
2018-06-08 14:58:00 +02:00
|
|
|
LIEF::PE::init_python_module(LIEF_module);
|
2017-03-30 16:56:49 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
// Init the MachO module
|
2017-11-18 16:37:40 +01:00
|
|
|
#if defined(LIEF_MACHO_SUPPORT)
|
2018-06-08 14:58:00 +02:00
|
|
|
LIEF::MachO::init_python_module(LIEF_module);
|
2017-03-30 16:56:49 +02:00
|
|
|
#endif
|
|
|
|
|
2018-05-04 12:46:28 +02:00
|
|
|
// Init the OAT module
|
|
|
|
#if defined(LIEF_OAT_SUPPORT)
|
|
|
|
LIEF::OAT::init_python_module(LIEF_module);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// Init the VDEX module
|
|
|
|
#if defined(LIEF_VDEX_SUPPORT)
|
|
|
|
LIEF::VDEX::init_python_module(LIEF_module);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// Init the DEX module
|
|
|
|
#if defined(LIEF_DEX_SUPPORT)
|
|
|
|
LIEF::DEX::init_python_module(LIEF_module);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// Init the ART module
|
|
|
|
#if defined(LIEF_ART_SUPPORT)
|
|
|
|
LIEF::ART::init_python_module(LIEF_module);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
LIEF::Android::init_python_module(LIEF_module);
|
|
|
|
|
2017-03-30 16:56:49 +02:00
|
|
|
// Init util functions
|
|
|
|
init_utils_functions(LIEF_module);
|
|
|
|
|
2017-08-20 07:08:50 +02:00
|
|
|
|
|
|
|
#if defined(LIEF_JSON_SUPPORT)
|
2017-03-30 16:56:49 +02:00
|
|
|
init_json_functions(LIEF_module);
|
2017-08-20 07:08:50 +02:00
|
|
|
#endif
|
2017-03-30 16:56:49 +02:00
|
|
|
|
|
|
|
}
|