Remove unused EDA client code
This commit is contained in:
parent
e554845407
commit
bea2e02253
@ -24,7 +24,6 @@ from atst.domain.authz import Authorization
|
|||||||
from atst.domain.csp import make_csp_provider
|
from atst.domain.csp import make_csp_provider
|
||||||
from atst.domain.portfolios import Portfolios
|
from atst.domain.portfolios import Portfolios
|
||||||
from atst.models.permissions import Permissions
|
from atst.models.permissions import Permissions
|
||||||
from atst.eda_client import MockEDAClient
|
|
||||||
from atst.utils import mailer
|
from atst.utils import mailer
|
||||||
from atst.utils.form_cache import FormCache
|
from atst.utils.form_cache import FormCache
|
||||||
from atst.utils.json import CustomJSONEncoder
|
from atst.utils.json import CustomJSONEncoder
|
||||||
@ -61,7 +60,6 @@ def make_app(config):
|
|||||||
|
|
||||||
make_flask_callbacks(app)
|
make_flask_callbacks(app)
|
||||||
register_filters(app)
|
register_filters(app)
|
||||||
make_eda_client(app)
|
|
||||||
make_csp_provider(app)
|
make_csp_provider(app)
|
||||||
make_crl_validator(app)
|
make_crl_validator(app)
|
||||||
make_mailer(app)
|
make_mailer(app)
|
||||||
@ -235,10 +233,6 @@ def make_crl_validator(app):
|
|||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
def make_eda_client(app):
|
|
||||||
app.eda_client = MockEDAClient()
|
|
||||||
|
|
||||||
|
|
||||||
def make_mailer(app):
|
def make_mailer(app):
|
||||||
if app.config["DEBUG"]:
|
if app.config["DEBUG"]:
|
||||||
mailer_connection = mailer.RedisConnection(app.redis)
|
mailer_connection = mailer.RedisConnection(app.redis)
|
||||||
|
@ -1,197 +0,0 @@
|
|||||||
from csv import DictReader
|
|
||||||
import defusedxml.ElementTree as ET
|
|
||||||
|
|
||||||
import requests
|
|
||||||
from requests.auth import HTTPBasicAuth
|
|
||||||
|
|
||||||
|
|
||||||
def parse_eda_xml(xml_string):
|
|
||||||
contract_et = ET.fromstring(xml_string)
|
|
||||||
handler = EDAXMLHandler(contract_et)
|
|
||||||
handler.parse()
|
|
||||||
return {
|
|
||||||
"clin_0001": handler.clins.get("0001"),
|
|
||||||
"clin_0003": handler.clins.get("0003"),
|
|
||||||
"clin_1001": handler.clins.get("1001"),
|
|
||||||
"clin_1003": handler.clins.get("1003"),
|
|
||||||
"clin_2001": handler.clins.get("2001"),
|
|
||||||
"clin_2003": handler.clins.get("2003"),
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
class EDAXMLHandler:
|
|
||||||
def __init__(self, element_tree):
|
|
||||||
self.element_tree = element_tree
|
|
||||||
self.clins = {}
|
|
||||||
|
|
||||||
@property
|
|
||||||
def _line_items(self):
|
|
||||||
return self.element_tree.findall(".//LineItem[LineItemType='CLIN']/../../..")
|
|
||||||
|
|
||||||
def parse(self):
|
|
||||||
for line_item in self._line_items:
|
|
||||||
number_el = line_item.find(".//LineItemBase")
|
|
||||||
amount_details = line_item.find(
|
|
||||||
".//ItemOtherAmounts[AmountDescription='Not to Exceed Amount (Funding)']/Amount"
|
|
||||||
)
|
|
||||||
if number_el is not None and amount_details is not None:
|
|
||||||
try:
|
|
||||||
self.clins[number_el.text] = float(amount_details.text)
|
|
||||||
except ValueError:
|
|
||||||
continue
|
|
||||||
|
|
||||||
|
|
||||||
class EDAClientBase(object):
|
|
||||||
def list_contracts(
|
|
||||||
self,
|
|
||||||
contract_number=None,
|
|
||||||
delivery_order=None,
|
|
||||||
cage_code=None,
|
|
||||||
duns_number=None,
|
|
||||||
):
|
|
||||||
"""
|
|
||||||
Get a list of all contracts matching the given filters.
|
|
||||||
"""
|
|
||||||
raise NotImplementedError()
|
|
||||||
|
|
||||||
def get_contract(self, contract_number, status):
|
|
||||||
"""
|
|
||||||
Get details for a contract.
|
|
||||||
"""
|
|
||||||
raise NotImplementedError()
|
|
||||||
|
|
||||||
|
|
||||||
class MockEDAClient(EDAClientBase):
|
|
||||||
def __init__(self, *args, **kwargs):
|
|
||||||
pass
|
|
||||||
|
|
||||||
def list_contracts(
|
|
||||||
self,
|
|
||||||
contract_number=None,
|
|
||||||
delivery_order=None,
|
|
||||||
cage_code=None,
|
|
||||||
duns_number=None,
|
|
||||||
):
|
|
||||||
return [
|
|
||||||
{
|
|
||||||
"aco_mod": "01",
|
|
||||||
"admin_dodaac": None,
|
|
||||||
"cage_code": "1U305",
|
|
||||||
"contract_no": "DCA10096D0052",
|
|
||||||
"delivery_order": "0084",
|
|
||||||
"duns_number": None,
|
|
||||||
"issue_date": "20000228",
|
|
||||||
"issue_dodaac": None,
|
|
||||||
"location": "https://docsrv1.nit.disa.mil:443/eda/enforcer/C0414345.PDF?ver=1.4&loc=Y29udHJhY3RzL29nZGVuL3ZlbmRvci8xOTk4LzA5LzE0L0MwNDE0MzQ1LlBERg==&sourceurl=aHR0cHM6Ly9lZGE0Lm5pdC5kaXNhLm1pbC9wbHMvdXNlci9uZXdfYXBwLkdldF9Eb2M_cFRhYmxlX0lEPTImcFJlY29yZF9LZXk9OEE2ODExNjM2RUY5NkU2M0UwMzQwMDYwQjBCMjgyNkM=&uid=6CFC2B2322E86FD5E054002264936E3C&qid=19344159&signed=G&qdate=20180529194407GMT&token=6xQICrrrfIMciEJSpXmfsAYrToM=",
|
|
||||||
"pay_dodaac": None,
|
|
||||||
"pco_mod": "02",
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"aco_mod": "01",
|
|
||||||
"admin_dodaac": None,
|
|
||||||
"cage_code": "1U305",
|
|
||||||
"contract_no": "DCA10096D0052",
|
|
||||||
"delivery_order": "0084",
|
|
||||||
"duns_number": None,
|
|
||||||
"issue_date": "20000228",
|
|
||||||
"issue_dodaac": None,
|
|
||||||
"location": "https://docsrv1.nit.disa.mil:443/eda/enforcer/C0414345.PDF?ver=1.4&loc=Y29udHJhY3RzL29nZGVuL3ZlbmRvci8xOTk4LzA5LzE0L0MwNDE0MzQ1LlBERg==&sourceurl=aHR0cHM6Ly9lZGE0Lm5pdC5kaXNhLm1pbC9wbHMvdXNlci9uZXdfYXBwLkdldF9Eb2M_cFRhYmxlX0lEPTImcFJlY29yZF9LZXk9OEE2ODExNjM2RUY5NkU2M0UwMzQwMDYwQjBCMjgyNkM=&uid=6CFC2B2322E86FD5E054002264936E3C&qid=19344159&signed=G&qdate=20180529194407GMT&token=6xQICrrrfIMciEJSpXmfsAYrToM=",
|
|
||||||
"pay_dodaac": None,
|
|
||||||
"pco_mod": "02",
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"aco_mod": "01",
|
|
||||||
"admin_dodaac": None,
|
|
||||||
"cage_code": "1U305",
|
|
||||||
"contract_no": "DCA10096D0052",
|
|
||||||
"delivery_order": "0084",
|
|
||||||
"duns_number": None,
|
|
||||||
"issue_date": "20000228",
|
|
||||||
"issue_dodaac": None,
|
|
||||||
"location": "https://docsrv1.nit.disa.mil:443/eda/enforcer/C0414345.PDF?ver=1.4&loc=Y29udHJhY3RzL29nZGVuL3ZlbmRvci8xOTk4LzA5LzE0L0MwNDE0MzQ1LlBERg==&sourceurl=aHR0cHM6Ly9lZGE0Lm5pdC5kaXNhLm1pbC9wbHMvdXNlci9uZXdfYXBwLkdldF9Eb2M_cFRhYmxlX0lEPTImcFJlY29yZF9LZXk9OEE2ODExNjM2RUY5NkU2M0UwMzQwMDYwQjBCMjgyNkM=&uid=6CFC2B2322E86FD5E054002264936E3C&qid=19344159&signed=G&qdate=20180529194407GMT&token=6xQICrrrfIMciEJSpXmfsAYrToM=",
|
|
||||||
"pay_dodaac": None,
|
|
||||||
"pco_mod": "02",
|
|
||||||
},
|
|
||||||
]
|
|
||||||
|
|
||||||
MOCK_CONTRACT_NUMBER = "DCA10096D0052"
|
|
||||||
|
|
||||||
def get_contract(self, contract_number, status):
|
|
||||||
if contract_number == self.MOCK_CONTRACT_NUMBER and status == "y":
|
|
||||||
return {
|
|
||||||
"number": "DCA10096D0052",
|
|
||||||
"clin_0001": 500,
|
|
||||||
"clin_0003": 600,
|
|
||||||
"clin_1001": 700,
|
|
||||||
"clin_1003": 800,
|
|
||||||
"clin_2001": 900,
|
|
||||||
"clin_2003": 1000,
|
|
||||||
}
|
|
||||||
else:
|
|
||||||
return None
|
|
||||||
|
|
||||||
|
|
||||||
class EDAClient(EDAClientBase):
|
|
||||||
def __init__(self, base_url, user_name, user_role, auth_name, auth_pass):
|
|
||||||
self.base_url = base_url
|
|
||||||
self.user_name = user_name
|
|
||||||
self.user_role = user_role
|
|
||||||
self.auth = HTTPBasicAuth(auth_name, auth_pass)
|
|
||||||
|
|
||||||
def _make_url(self, method, **kwargs):
|
|
||||||
query_args = dict(kwargs)
|
|
||||||
query_string = "&".join(
|
|
||||||
["{}={}".format(key, value) for key, value in query_args.items()]
|
|
||||||
)
|
|
||||||
return "{base_url}/{method}?{query_string}".format(
|
|
||||||
base_url=self.base_url, method=method, query_string=query_string
|
|
||||||
)
|
|
||||||
|
|
||||||
def _get(self, method, **kwargs):
|
|
||||||
url = self._make_url(method, **kwargs)
|
|
||||||
return requests.get(url, auth=self.auth, verify="ssl/server-certs/eda.pem")
|
|
||||||
|
|
||||||
def list_contracts(
|
|
||||||
self,
|
|
||||||
contract_number=None,
|
|
||||||
delivery_order=None,
|
|
||||||
cage_code=None,
|
|
||||||
duns_number=None,
|
|
||||||
):
|
|
||||||
response = self._get(
|
|
||||||
"wawf_interface.returnContractList",
|
|
||||||
pContract=contract_number,
|
|
||||||
pDelivery_Order=delivery_order,
|
|
||||||
pCage_Code=cage_code,
|
|
||||||
pDuns_Number=duns_number,
|
|
||||||
pUserName=self.user_name,
|
|
||||||
pUser_Role=self.user_role,
|
|
||||||
)
|
|
||||||
lines = response.text.replace("<br />", "").split("\n")
|
|
||||||
return list(DictReader(lines))
|
|
||||||
|
|
||||||
def get_contract(self, contract_number, status):
|
|
||||||
response = self._get(
|
|
||||||
"pds_contract_interface.get_xml_doc",
|
|
||||||
pContract=contract_number,
|
|
||||||
pStatus=status,
|
|
||||||
)
|
|
||||||
if response.text.startswith("No data found"):
|
|
||||||
return None
|
|
||||||
|
|
||||||
eda_data = {"number": contract_number}
|
|
||||||
eda_data.update(parse_eda_xml(response.text))
|
|
||||||
return eda_data
|
|
||||||
|
|
||||||
def get_clins(self, record_key, clins, cage_code="", duns_number=""):
|
|
||||||
response = self._get(
|
|
||||||
"wawf_interface.returnclinXML",
|
|
||||||
pCage_Code=cage_code,
|
|
||||||
pDuns_Number=duns_number,
|
|
||||||
pUserName=self.user_name,
|
|
||||||
pUser_Role=self.user_role,
|
|
||||||
pRecord_key=record_key,
|
|
||||||
pClins=clins,
|
|
||||||
)
|
|
||||||
# TODO: Parse XML, similar to `get_contract`
|
|
||||||
return response
|
|
@ -1,38 +0,0 @@
|
|||||||
# Add root project dir to the python path
|
|
||||||
import os
|
|
||||||
import sys
|
|
||||||
|
|
||||||
parent_dir = os.path.abspath(os.path.join(os.path.dirname(__file__), ".."))
|
|
||||||
sys.path.append(parent_dir)
|
|
||||||
|
|
||||||
from atst.app import make_config, make_app
|
|
||||||
from atst.eda_client import EDAClient
|
|
||||||
|
|
||||||
|
|
||||||
config = make_config({"DISABLE_CRL_CHECK": True})
|
|
||||||
|
|
||||||
client = EDAClient(
|
|
||||||
base_url=config.get("EDA_HOST"),
|
|
||||||
user_name=config.get("EDA_USER_NAME"),
|
|
||||||
user_role=config.get("EDA_USER_ROLE"),
|
|
||||||
auth_name=config.get("EDA_AUTH_NAME"),
|
|
||||||
auth_pass=config.get("EDA_AUTH_PASS"),
|
|
||||||
)
|
|
||||||
|
|
||||||
contract_number = "DCA10096D0052"
|
|
||||||
|
|
||||||
listed = client.list_contracts(
|
|
||||||
contract_number=contract_number,
|
|
||||||
delivery_order="",
|
|
||||||
cage_code="1U305",
|
|
||||||
duns_number="",
|
|
||||||
)
|
|
||||||
contract = client.get_contract(contract_number=contract_number, status="Y")
|
|
||||||
|
|
||||||
requested_clins = ",".join(["'0001'", "'0003'", "'1001'", "'1003'", "'2001'", "'2003'"])
|
|
||||||
clins = client.get_clins(
|
|
||||||
record_key=contract_number,
|
|
||||||
duns_number="",
|
|
||||||
cage_code="1U305",
|
|
||||||
with_clins=requested_clins,
|
|
||||||
)
|
|
@ -1,57 +0,0 @@
|
|||||||
from atst.eda_client import MockEDAClient, parse_eda_xml
|
|
||||||
|
|
||||||
|
|
||||||
mock_client = MockEDAClient()
|
|
||||||
|
|
||||||
|
|
||||||
def test_list_contracts():
|
|
||||||
results = mock_client.list_contracts()
|
|
||||||
assert len(results) == 3
|
|
||||||
|
|
||||||
|
|
||||||
def test_get_contract():
|
|
||||||
result = mock_client.get_contract("DCA10096D0052", "y")
|
|
||||||
assert result["number"] == "DCA10096D0052"
|
|
||||||
|
|
||||||
|
|
||||||
def test_contract_not_found():
|
|
||||||
result = mock_client.get_contract("abc", "y")
|
|
||||||
assert result is None
|
|
||||||
|
|
||||||
|
|
||||||
def test_eda_xml_parser():
|
|
||||||
with open("tests/fixtures/eda_contract.xml") as contract:
|
|
||||||
eda_data = parse_eda_xml(contract.read())
|
|
||||||
assert eda_data["clin_0001"] == 200_000.00
|
|
||||||
assert not eda_data["clin_0003"]
|
|
||||||
|
|
||||||
|
|
||||||
_EDA_XML_NO_NUMBER = """
|
|
||||||
<ProcurementDocument>
|
|
||||||
<AwardInstrument>
|
|
||||||
<ContractLineItems>
|
|
||||||
<LineItems>
|
|
||||||
<LineItemIdentifier>
|
|
||||||
<DFARS>
|
|
||||||
<LineItem>
|
|
||||||
<LineItemType>CLIN</LineItemType>
|
|
||||||
<LineItemBase>0001</LineItemBase>
|
|
||||||
</LineItem>
|
|
||||||
</DFARS>
|
|
||||||
</LineItemIdentifier>
|
|
||||||
<LineItemAmounts>
|
|
||||||
<ItemOtherAmounts>
|
|
||||||
<AmountDescription>Not to Exceed Amount (Funding)</AmountDescription>
|
|
||||||
<Amount>not a number</Amount>
|
|
||||||
</ItemOtherAmounts>
|
|
||||||
</LineItemAmounts>
|
|
||||||
</LineItems>
|
|
||||||
</ContractLineItems>
|
|
||||||
</AwardInstrument>
|
|
||||||
</ProcurementDocument>
|
|
||||||
"""
|
|
||||||
|
|
||||||
|
|
||||||
def test_eda_xml_parser_with_bad_xml():
|
|
||||||
eda_data = parse_eda_xml(_EDA_XML_NO_NUMBER)
|
|
||||||
assert eda_data["clin_0001"] is None
|
|
Loading…
x
Reference in New Issue
Block a user