AuthInfo authInfo = request.getAuthInfo();
Vector serviceVector = request.getBusinessServiceVector();
UUIDGen uuidgen = UUIDGenFactory.getUUIDGen();
// aquire a jUDDI datastore instance
DataStore dataStore = DataStoreFactory.getDataStore();
try
{
dataStore.beginTrans();
// validate authentication parameters
Publisher publisher = getPublisher(authInfo,dataStore);
String publisherID = publisher.getPublisherID();
// Validate request parameters & execute
for (int i=0; i<serviceVector.size(); i++)
{
// Move the BusinessService data into a form we can work with easily
BusinessService service = (BusinessService)serviceVector.elementAt(i);
String businessKey = service.getBusinessKey();
String serviceKey = service.getServiceKey();
// If a BusinessKey wasn't included or it is an invalid BusinessKey then
// throw an InvalidKeyPassedException
if ((businessKey == null) || (businessKey.length() == 0) || (!dataStore.isValidBusinessKey(businessKey)))
throw new InvalidKeyPassedException("save_service: "+
"businessKey="+businessKey);
// Confirm that 'publisherID' controls the BusinessEntity that this
// BusinessService belongs to. If not then throw a UserMismatchException.
if (!dataStore.isBusinessPublisher(businessKey,publisherID))
throw new UserMismatchException("save_service: "+
"userID="+publisherID+", "+
"businessKey="+serviceKey);
// If a ServiceKey was specified then make sure it's a valid one.
if (((serviceKey != null) && (serviceKey.length() > 0)) && (!dataStore.isValidServiceKey(serviceKey)))
throw new InvalidKeyPassedException("save_service: "+
"serviceKey="+serviceKey);
// Normally, a valid tModelKey MUST be specified for the keyedReference
// to be valid. However, in the case of a keyedReference that is used in
// a categoryBag, the tModelKey may be omitted or specified as a
// zero-length string to indicate that the taxonomy being used is
// uddi-org:general_keywords. When it is omitted in this manner, the UDDI
// registry will insert the proper key during the save_xx operation.
// - UDDI Programmers API v2.04 Section 4.3.5.1 Specifying keyedReferences
//
CategoryBag categoryBag = service.getCategoryBag();
if (categoryBag != null)
{
Vector keyedRefVector = categoryBag.getKeyedReferenceVector();
if (keyedRefVector != null)
{
int vectorSize = keyedRefVector.size();
if (vectorSize > 0)
{
for (int j=0; j<vectorSize; j++)
{
KeyedReference keyedRef = (KeyedReference)keyedRefVector.elementAt(j);
String key = keyedRef.getTModelKey();
// A null or zero-length tModelKey is treated as
// though the tModelKey for uddiorg:general_keywords
// had been specified.
//
if ((key == null) || (key.trim().length() == 0))
keyedRef.setTModelKey(TModel.GENERAL_KEYWORDS_TMODEL_KEY);
}
}
}
}
}
for (int i=0; i<serviceVector.size(); i++)
{
// move the BusinessService data into a form we can work with easily
BusinessService service = (BusinessService)serviceVector.elementAt(i);
String serviceKey = service.getServiceKey();
// If the new BusinessService has a ServiceKey then it must already
// exists so delete the old one. It a ServiceKey isn't specified then
// this is a new BusinessService so create a new ServiceKey for it.
if ((serviceKey != null) && (serviceKey.length() > 0))
dataStore.deleteService(serviceKey);
else
service.setServiceKey(uuidgen.uuidgen());
// everything checks out so let's save it.
dataStore.saveService(service);
}
dataStore.commit();
// create a new ServiceDetail and stuff the
// original but 'updated' serviceVector in.
ServiceDetail detail = new ServiceDetail();
detail.setGeneric(generic);
detail.setOperator(Config.getOperator());
detail.setTruncated(false);
detail.setBusinessServiceVector(serviceVector);
return detail;
}
catch(InvalidKeyPassedException ikpex)
{
try { dataStore.rollback(); } catch(Exception e) { }
log.info(ikpex);
throw (RegistryException)ikpex;
}
catch(UserMismatchException umex)
{
try { dataStore.rollback(); } catch(Exception e) { }
log.info(umex);
throw (RegistryException)umex;
}
catch(RegistryException regex)
{
try { dataStore.rollback(); } catch(Exception e) { }
log.error(regex);
throw (RegistryException)regex;
}
catch(Exception ex)
{
try { dataStore.rollback(); } catch(Exception e) { }
log.error(ex);
throw new RegistryException(ex);
}
finally
{
if (dataStore != null)
dataStore.release();
}
}