diff --git a/CHANGES.txt b/CHANGES.txt new file mode 100644 index 0000000..35a34f3 --- /dev/null +++ b/CHANGES.txt @@ -0,0 +1,4 @@ +0.0 +--- + +- Initial version diff --git a/MANIFEST.in b/MANIFEST.in new file mode 100644 index 0000000..ae9ea72 --- /dev/null +++ b/MANIFEST.in @@ -0,0 +1,2 @@ +include *.txt *.ini *.cfg *.rst +recursive-include lbbulk *.ico *.png *.css *.gif *.jpg *.pt *.txt *.mak *.mako *.js *.html *.xml diff --git a/README.txt b/README.txt new file mode 100644 index 0000000..0cd1430 --- /dev/null +++ b/README.txt @@ -0,0 +1,14 @@ +LBBulk README +================== + +Getting Started +--------------- + +- cd + +- $VENV/bin/python setup.py develop + +- $VENV/bin/initialize_LBBulk_db development.ini + +- $VENV/bin/pserve development.ini + diff --git a/TODO.txt b/TODO.txt new file mode 100644 index 0000000..43d2a31 --- /dev/null +++ b/TODO.txt @@ -0,0 +1 @@ +- coisas \ No newline at end of file diff --git a/development.ini b/development.ini new file mode 100644 index 0000000..e6276fb --- /dev/null +++ b/development.ini @@ -0,0 +1,71 @@ +### +# app configuration +# http://docs.pylonsproject.org/projects/pyramid/en/latest/narr/environment.html +### + +[app:main] +use = egg:LBBulk + +pyramid.reload_templates = true +pyramid.debug_authorization = false +pyramid.debug_notfound = false +pyramid.debug_routematch = false +pyramid.default_locale_name = en +pyramid.includes = + pyramid_debugtoolbar + pyramid_tm + +sqlalchemy.url = postgresql://postgres:postgres@10.1.0.152/projeto1 + +# By default, the toolbar only appears for clients from IP addresses +# '127.0.0.1' and '::1'. +# debugtoolbar.hosts = 0.0.0.0/0 + +### +# wsgi server configuration +### + +[server:main] +use = egg:waitress#main +host = 0.0.0.0 +port = 6543 + +### +# logging configuration +# http://docs.pylonsproject.org/projects/pyramid/en/latest/narr/logging.html +### + +[loggers] +keys = root, lbbulk, sqlalchemy + +[handlers] +keys = console + +[formatters] +keys = generic + +[logger_root] +level = INFO +handlers = console + +[logger_lbbulk] +level = DEBUG +handlers = +qualname = lbbulk + +[logger_sqlalchemy] +level = INFO +handlers = +qualname = sqlalchemy.engine +# "level = INFO" logs SQL queries. +# "level = DEBUG" logs SQL queries and results. +# "level = WARN" logs neither. (Recommended for production systems.) + +[handler_console] +class = StreamHandler +args = (sys.stderr,) +level = NOTSET +formatter = generic + +[formatter_generic] +format = %(asctime)s %(levelname)-5.5s [%(name)s][%(threadName)s] %(message)s diff --git a/lbbulk/__init__.py b/lbbulk/__init__.py new file mode 100644 index 0000000..dab7f7d --- /dev/null +++ b/lbbulk/__init__.py @@ -0,0 +1,21 @@ +from pyramid.config import Configurator +from sqlalchemy import engine_from_config +from lbbulk.config.routing import make_routes + +from lbbulk.models import ( + DBSession, + Base, + ) + + +def main(global_config, **settings): + """ This function returns a Pyramid WSGI application. + """ + config = Configurator(settings=settings) + config.scan('lbbulk') + engine = engine_from_config(settings, 'sqlalchemy.') + DBSession.configure(bind=engine) + Base.metadata.bind = engine + config.include('pyramid_chameleon') + make_routes(config) + return config.make_wsgi_app() \ No newline at end of file diff --git a/lbbulk/config/__init__.py b/lbbulk/config/__init__.py new file mode 100644 index 0000000..d310fdd --- /dev/null +++ b/lbbulk/config/__init__.py @@ -0,0 +1 @@ +# package \ No newline at end of file diff --git a/lbbulk/config/routing.py b/lbbulk/config/routing.py new file mode 100644 index 0000000..d610687 --- /dev/null +++ b/lbbulk/config/routing.py @@ -0,0 +1,6 @@ +def make_routes(config): + """ + Create routes + """ + config.add_static_view('static', 'static', cache_max_age=3600) + config.add_route('home', '/') \ No newline at end of file diff --git a/lbbulk/models/Registro.py b/lbbulk/models/Registro.py new file mode 100644 index 0000000..62a3969 --- /dev/null +++ b/lbbulk/models/Registro.py @@ -0,0 +1,32 @@ +from sqlalchemy import Table, Column, Integer, \ + String, MetaData, join, ForeignKey +from sqlalchemy.ext.declarative import declarative_base +from sqlalchemy.orm import column_property + +metadata = MetaData() + +# define two Table objects +bulk_sources = Table('lb_bulk_sources', metadata, + Column('id_source', Integer, primary_key=True), + Column('nome_source', String), + ) + +bulk_upload = Table('lb_bulk_upload', metadata, + Column('id_reg', Integer, primary_key=True), + Column('chave_externa', String) + Column('id_source', Integer, ForeignKey('lb_bulk_sources.id_source')), + ) + +# define a join between them. This +# takes place across the user.id and address.user_id +# columns. +user_address_join = join(user_table, address_table) + +Base = declarative_base() + +# map to it +class AddressUser(Base): + __table__ = user_address_join + + id = column_property(user_table.c.id, address_table.c.user_id) + address_id = address_table.c.id \ No newline at end of file diff --git a/lbbulk/models/__init__.py b/lbbulk/models/__init__.py new file mode 100644 index 0000000..5bb534f --- /dev/null +++ b/lbbulk/models/__init__.py @@ -0,0 +1 @@ +# package diff --git a/lbbulk/scripts/__init__.py b/lbbulk/scripts/__init__.py new file mode 100644 index 0000000..5bb534f --- /dev/null +++ b/lbbulk/scripts/__init__.py @@ -0,0 +1 @@ +# package diff --git a/lbbulk/scripts/initializedb.py b/lbbulk/scripts/initializedb.py new file mode 100644 index 0000000..7dfdece --- /dev/null +++ b/lbbulk/scripts/initializedb.py @@ -0,0 +1,40 @@ +import os +import sys +import transaction + +from sqlalchemy import engine_from_config + +from pyramid.paster import ( + get_appsettings, + setup_logging, + ) + +from pyramid.scripts.common import parse_vars + +from ..models import ( + DBSession, + MyModel, + Base, + ) + + +def usage(argv): + cmd = os.path.basename(argv[0]) + print('usage: %s [var=value]\n' + '(example: "%s development.ini")' % (cmd, cmd)) + sys.exit(1) + + +def main(argv=sys.argv): + if len(argv) < 2: + usage(argv) + config_uri = argv[1] + options = parse_vars(argv[2:]) + setup_logging(config_uri) + settings = get_appsettings(config_uri, options=options) + engine = engine_from_config(settings, 'sqlalchemy.') + DBSession.configure(bind=engine) + Base.metadata.create_all(engine) + with transaction.manager: + model = MyModel(name='one', value=1) + DBSession.add(model) diff --git a/lbbulk/static/favicon.ico b/lbbulk/static/favicon.ico new file mode 100644 index 0000000..71f837c Binary files /dev/null and b/lbbulk/static/favicon.ico differ diff --git a/lbbulk/static/footerbg.png b/lbbulk/static/footerbg.png new file mode 100644 index 0000000..1fbc873 Binary files /dev/null and b/lbbulk/static/footerbg.png differ diff --git a/lbbulk/static/headerbg.png b/lbbulk/static/headerbg.png new file mode 100644 index 0000000..0596f20 Binary files /dev/null and b/lbbulk/static/headerbg.png differ diff --git a/lbbulk/static/ie6.css b/lbbulk/static/ie6.css new file mode 100644 index 0000000..b7c8493 --- /dev/null +++ b/lbbulk/static/ie6.css @@ -0,0 +1,8 @@ +* html img, +* html .png{position:relative;behavior:expression((this.runtimeStyle.behavior="none")&&(this.pngSet?this.pngSet=true:(this.nodeName == "IMG" && this.src.toLowerCase().indexOf('.png')>-1?(this.runtimeStyle.backgroundImage = "none", +this.runtimeStyle.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='" + this.src + "',sizingMethod='image')", +this.src = "static/transparent.gif"):(this.origBg = this.origBg? this.origBg :this.currentStyle.backgroundImage.toString().replace('url("','').replace('")',''), +this.runtimeStyle.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='" + this.origBg + "',sizingMethod='crop')", +this.runtimeStyle.backgroundImage = "none")),this.pngSet=true) +);} +#wrap{display:table;height:100%} diff --git a/lbbulk/static/middlebg.png b/lbbulk/static/middlebg.png new file mode 100644 index 0000000..2369cfb Binary files /dev/null and b/lbbulk/static/middlebg.png differ diff --git a/lbbulk/static/pylons.css b/lbbulk/static/pylons.css new file mode 100644 index 0000000..4b1c017 --- /dev/null +++ b/lbbulk/static/pylons.css @@ -0,0 +1,372 @@ +html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td +{ + margin: 0; + padding: 0; + border: 0; + outline: 0; + font-size: 100%; /* 16px */ + vertical-align: baseline; + background: transparent; +} + +body +{ + line-height: 1; +} + +ol, ul +{ + list-style: none; +} + +blockquote, q +{ + quotes: none; +} + +blockquote:before, blockquote:after, q:before, q:after +{ + content: ''; + content: none; +} + +:focus +{ + outline: 0; +} + +ins +{ + text-decoration: none; +} + +del +{ + text-decoration: line-through; +} + +table +{ + border-collapse: collapse; + border-spacing: 0; +} + +sub +{ + vertical-align: sub; + font-size: smaller; + line-height: normal; +} + +sup +{ + vertical-align: super; + font-size: smaller; + line-height: normal; +} + +ul, menu, dir +{ + display: block; + list-style-type: disc; + margin: 1em 0; + padding-left: 40px; +} + +ol +{ + display: block; + list-style-type: decimal-leading-zero; + margin: 1em 0; + padding-left: 40px; +} + +li +{ + display: list-item; +} + +ul ul, ul ol, ul dir, ul menu, ul dl, ol ul, ol ol, ol dir, ol menu, ol dl, dir ul, dir ol, dir dir, dir menu, dir dl, menu ul, menu ol, menu dir, menu menu, menu dl, dl ul, dl ol, dl dir, dl menu, dl dl +{ + margin-top: 0; + margin-bottom: 0; +} + +ol ul, ul ul, menu ul, dir ul, ol menu, ul menu, menu menu, dir menu, ol dir, ul dir, menu dir, dir dir +{ + list-style-type: circle; +} + +ol ol ul, ol ul ul, ol menu ul, ol dir ul, ol ol menu, ol ul menu, ol menu menu, ol dir menu, ol ol dir, ol ul dir, ol menu dir, ol dir dir, ul ol ul, ul ul ul, ul menu ul, ul dir ul, ul ol menu, ul ul menu, ul menu menu, ul dir menu, ul ol dir, ul ul dir, ul menu dir, ul dir dir, menu ol ul, menu ul ul, menu menu ul, menu dir ul, menu ol menu, menu ul menu, menu menu menu, menu dir menu, menu ol dir, menu ul dir, menu menu dir, menu dir dir, dir ol ul, dir ul ul, dir menu ul, dir dir ul, dir ol menu, dir ul menu, dir menu menu, dir dir menu, dir ol dir, dir ul dir, dir menu dir, dir dir dir +{ + list-style-type: square; +} + +.hidden +{ + display: none; +} + +p +{ + line-height: 1.5em; +} + +h1 +{ + font-size: 1.75em; + line-height: 1.7em; + font-family: helvetica, verdana; +} + +h2 +{ + font-size: 1.5em; + line-height: 1.7em; + font-family: helvetica, verdana; +} + +h3 +{ + font-size: 1.25em; + line-height: 1.7em; + font-family: helvetica, verdana; +} + +h4 +{ + font-size: 1em; + line-height: 1.7em; + font-family: helvetica, verdana; +} + +html, body +{ + width: 100%; + height: 100%; +} + +body +{ + margin: 0; + padding: 0; + background-color: #fff; + position: relative; + font: 16px/24px NobileRegular, "Lucida Grande", Lucida, Verdana, sans-serif; +} + +a +{ + color: #1b61d6; + text-decoration: none; +} + +a:hover +{ + color: #e88f00; + text-decoration: underline; +} + +body h1, body h2, body h3, body h4, body h5, body h6 +{ + font-family: NeutonRegular, "Lucida Grande", Lucida, Verdana, sans-serif; + font-weight: 400; + color: #373839; + font-style: normal; +} + +#wrap +{ + min-height: 100%; +} + +#header, #footer +{ + width: 100%; + color: #fff; + height: 40px; + position: absolute; + text-align: center; + line-height: 40px; + overflow: hidden; + font-size: 12px; + vertical-align: middle; +} + +#header +{ + background: #000; + top: 0; + font-size: 14px; +} + +#footer +{ + bottom: 0; + background: #000 url(footerbg.png) repeat-x 0 top; + position: relative; + margin-top: -40px; + clear: both; +} + +.header, .footer +{ + width: 750px; + margin-right: auto; + margin-left: auto; +} + +.wrapper +{ + width: 100%; +} + +#top, #top-small, #bottom +{ + width: 100%; +} + +#top +{ + color: #000; + height: 230px; + background: #fff url(headerbg.png) repeat-x 0 top; + position: relative; +} + +#top-small +{ + color: #000; + height: 60px; + background: #fff url(headerbg.png) repeat-x 0 top; + position: relative; +} + +#bottom +{ + color: #222; + background-color: #fff; +} + +.top, .top-small, .middle, .bottom +{ + width: 750px; + margin-right: auto; + margin-left: auto; +} + +.top +{ + padding-top: 40px; +} + +.top-small +{ + padding-top: 10px; +} + +#middle +{ + width: 100%; + height: 100px; + background: url(middlebg.png) repeat-x; + border-top: 2px solid #fff; + border-bottom: 2px solid #b2b2b2; +} + +.app-welcome +{ + margin-top: 25px; +} + +.app-name +{ + color: #000; + font-weight: 700; +} + +.bottom +{ + padding-top: 50px; +} + +#left +{ + width: 350px; + float: left; + padding-right: 25px; +} + +#right +{ + width: 350px; + float: right; + padding-left: 25px; +} + +.align-left +{ + text-align: left; +} + +.align-right +{ + text-align: right; +} + +.align-center +{ + text-align: center; +} + +ul.links +{ + margin: 0; + padding: 0; +} + +ul.links li +{ + list-style-type: none; + font-size: 14px; +} + +form +{ + border-style: none; +} + +fieldset +{ + border-style: none; +} + +input +{ + color: #222; + border: 1px solid #ccc; + font-family: sans-serif; + font-size: 12px; + line-height: 16px; +} + +input[type=text], input[type=password] +{ + width: 205px; +} + +input[type=submit] +{ + background-color: #ddd; + font-weight: 700; +} + +/*Opera Fix*/ +body:before +{ + content: ""; + height: 100%; + float: left; + width: 0; + margin-top: -32767px; +} diff --git a/lbbulk/static/pyramid-small.png b/lbbulk/static/pyramid-small.png new file mode 100644 index 0000000..a5bc0ad Binary files /dev/null and b/lbbulk/static/pyramid-small.png differ diff --git a/lbbulk/static/pyramid.png b/lbbulk/static/pyramid.png new file mode 100644 index 0000000..347e055 Binary files /dev/null and b/lbbulk/static/pyramid.png differ diff --git a/lbbulk/static/transparent.gif b/lbbulk/static/transparent.gif new file mode 100644 index 0000000..0341802 Binary files /dev/null and b/lbbulk/static/transparent.gif differ diff --git a/lbbulk/templates/mytemplate.pt b/lbbulk/templates/mytemplate.pt new file mode 100644 index 0000000..b4da3e9 --- /dev/null +++ b/lbbulk/templates/mytemplate.pt @@ -0,0 +1,73 @@ + + + + The Pyramid Web Framework + + + + + + + + + + +
+
+
+
pyramid
+
+
+
+
+

+ Welcome to ${project}, an application generated by
+ the Pyramid Web Framework. +

+
+
+
+
+
+

Search documentation

+
+ + +
+
+ +
+
+
+ + diff --git a/lbbulk/views.py b/lbbulk/views.py new file mode 100644 index 0000000..a14ca39 --- /dev/null +++ b/lbbulk/views.py @@ -0,0 +1,9 @@ +from pyramid.response import Response +from pyramid.view import view_config + +from sqlalchemy.exc import DBAPIError + + +@view_config(route_name='home', renderer='templates/mytemplate.pt') +def my_view(request): + return {'project': 'LBBulk'} \ No newline at end of file diff --git a/production.ini b/production.ini new file mode 100644 index 0000000..20b33ed --- /dev/null +++ b/production.ini @@ -0,0 +1,62 @@ +### +# app configuration +# http://docs.pylonsproject.org/projects/pyramid/en/latest/narr/environment.html +### + +[app:main] +use = egg:LBBulk + +pyramid.reload_templates = false +pyramid.debug_authorization = false +pyramid.debug_notfound = false +pyramid.debug_routematch = false +pyramid.default_locale_name = en +pyramid.includes = + pyramid_tm + +sqlalchemy.url = postgresql://postgres:postgres@10.1.0.152/projeto1 + +[server:main] +use = egg:waitress#main +host = 0.0.0.0 +port = 6543 + +### +# logging configuration +# http://docs.pylonsproject.org/projects/pyramid/en/latest/narr/logging.html +### + +[loggers] +keys = root, lbbulk, sqlalchemy + +[handlers] +keys = console + +[formatters] +keys = generic + +[logger_root] +level = WARN +handlers = console + +[logger_lbbulk] +level = WARN +handlers = +qualname = lbbulk + +[logger_sqlalchemy] +level = WARN +handlers = +qualname = sqlalchemy.engine +# "level = INFO" logs SQL queries. +# "level = DEBUG" logs SQL queries and results. +# "level = WARN" logs neither. (Recommended for production systems.) + +[handler_console] +class = StreamHandler +args = (sys.stderr,) +level = NOTSET +formatter = generic + +[formatter_generic] +format = %(asctime)s %(levelname)-5.5s [%(name)s][%(threadName)s] %(message)s diff --git a/setup.cfg b/setup.cfg new file mode 100644 index 0000000..af6b0cd --- /dev/null +++ b/setup.cfg @@ -0,0 +1,27 @@ +[nosetests] +match=^test +nocapture=1 +cover-package=lbbulk +with-coverage=1 +cover-erase=1 + +[compile_catalog] +directory = lbbulk/locale +domain = LBBulk +statistics = true + +[extract_messages] +add_comments = TRANSLATORS: +output_file = lbbulk/locale/LBBulk.pot +width = 80 + +[init_catalog] +domain = LBBulk +input_file = lbbulk/locale/LBBulk.pot +output_dir = lbbulk/locale + +[update_catalog] +domain = LBBulk +input_file = lbbulk/locale/LBBulk.pot +output_dir = lbbulk/locale +previous = true diff --git a/setup.py b/setup.py new file mode 100644 index 0000000..a1c64b7 --- /dev/null +++ b/setup.py @@ -0,0 +1,50 @@ +import os + +from setuptools import setup, find_packages + +here = os.path.abspath(os.path.dirname(__file__)) +with open(os.path.join(here, 'README.txt')) as f: + README = f.read() +with open(os.path.join(here, 'CHANGES.txt')) as f: + CHANGES = f.read() + +requires = [ + 'pyramid', + 'pyramid_chameleon', + 'pyramid_debugtoolbar', + 'pyramid_tm', + 'SQLAlchemy', + 'transaction', + 'zope.sqlalchemy', + 'waitress', + 'pyramid_restler', + ] + +setup(name='LBBulk', + version='0.1', + description='Translator for external keys to fit properly on the lightbase standard', + long_description=README + '\n\n' + CHANGES, + classifiers=[ + "Development Status :: 2 - Pre-Alpha" + "Framework :: Pyramid", + "License :: OSI Approved :: GNU General Public License v2 (GPLv2)", + "Natural Language :: English" + "Programming Language :: Python :: 3", + "Topic :: Database :: Database Engines/Servers" + ], + author='Lightbase', + author_email='pedro.ricardo@lightbase.com', + url='', + keywords='lightbase database translator bulk pyramid', + packages=find_packages(), + include_package_data=True, + zip_safe=False, + # test_suite='lbbulk', + install_requires=requires, + entry_points="""\ + [paste.app_factory] + main = lbbulk:main + [console_scripts] + initialize_LBBulk_db = lbbulk.scripts.initializedb:main + """, + ) \ No newline at end of file -- libgit2 0.21.2