Skip to content

A command-line tool to manage attachments in SAP Cloud for Customer (C4C)

License

Notifications You must be signed in to change notification settings

AndreasFerdinand/CloudCopy

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

71 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

CloudCopy - A command-line tool to manage attachments in SAP Cloud for Customer

Codacy Badge License: MIT Latest Release Platform Support

Tired of manually uploading a bunch of files to your service request in C4C? Or do you just need to download all files, attached to a Contact? Try CloudCopy, it’s your swiss army knife for managing attachments in SAP Cloud 4 Customer. Watch the screencast, to see, how CloudCopy can help you to improve your service process.

Alt text

Some more Examples

Upload the file details.pdf to Contact 1000000:

CloudCopy upload details.pdf h.maulwurf@my000000.crm.ondemand.com:Contact:#1000000

List all attached files of Contact 1000000:

CloudCopy list h.maulwurf@my000000.crm.ondemand.com:Contact:#1000000

The following examples require a configuration file, containing the target host and the credentials to authenticate the user.

Upload all files of the current directory to ServiceRequest 2:

CloudCopy upload * ServiceRequest:#2

List all attached files of a ServiceRequest using the UUID of the Request:

CloudCopy list ServiceRequest:a563df71571140899b17ed8d08d8ff4b

Only list jpg files of ServiceRequest 2:

CloudCopy list -P "*.jpg" ServiceRequest:#4

Download all pdf files of Contact 2000000:

CloudCopy download -P "*.pdf" Contact:#2000000

Download all files of ServiceRequest 333 using 6 parallel jobs:

CloudCopy download -T 6 ServiceRequest:#333

To set a product image you have to provide the TypeCode 10011 using option -C:

CloudCopy upload -C 10011 product.png Product:#10000483

Installing

Linux

To install CloudCopy use, the following commands. To run it, use ./CloudCopy.

$ mkdir CloudCopy && cd CloudCopy
$ curl -LsS https://github.com/AndreasFerdinand/CloudCopy/releases/download/v0.4/CloudCopy-0.4-linux-x64.tar.gz | tar xzv

Windows

Just download and extract the file CloudCopy-0.4-win-x64.zip from the the release-page and use the executable CloudCopy.exe.

Build from Source

Linux

If you run Linux, you can use the Makefile to build the binaries. Since the source is based on .NET Core you have to install the .NET Core SDK. Additionally you need to create the Version-file in the root directory which has to include the version number of your build. To build the binaries for windows and linux use the following two commands. To build platform specific binaries you can use the target 'windows' or 'linux' for the make command.

echo "v.1.2.3.4" > Version
make

Windows

To build the binaries on windows, the .NET Core SDK is needed too. First you have to create the VersionName-file in the root directory which has to contain the version number. Afterwards navigate to the src directory and use the following command to build the binaries for windows:

dotnet build

Supported Entities

Currently the following entities are supported:

  • Appointment
  • CodTimeReport
  • CompetitorProduct
  • Contact
  • Contract
  • CorporateAccount
  • CustomerOrder
  • CustomerOrderItem
  • IndividualCustomer
  • InstallationPoint
  • JobDefinition
  • Lead
  • LeanInvoice
  • MemoActivity
  • Opportunity
  • OpportunityItem
  • Payment
  • PhoneCall
  • Product
  • Promotion
  • RegisteredProduct
  • SalesQuote
  • SalesQuoteItem
  • ServiceAgent
  • ServiceRequest
  • SocialMediaActivity
  • Tasks

Configuration File

To prevent entering the credentials and the host each time, the data can be provided through a user specific configuration file.

Path to the File

Debian / Ubuntu:

~/.local/share/CloudCopy/default.xml

Windows:

C:\Users\<user>\AppData\Local\CloudCopy\default.xml

Format

It is not recommended to use the file, since the credentials are stored unencrypted in it. At least be sure, to prevent other users to access the file by setting appropriate file permissions.

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<CloudCopy>
	<Hostname>my000000.crm.ondemand.com</Hostname>
	<Username>username</Username>
	<Password>password</Password>
</CloudCopy>

Set recommended file permissions (linux)

chmod 600 ~/.local/share/CloudCopy/default.xml

C4C User Configuration

CloudCopy uses the OData service provided by C4C. To access it, an application user or a technical (aka integration) user is needed.

Creating a technical user

  1. Create a Communication Systems (Administrator \ General Settings \ Integration \ Communication Systems)
  2. Define a Communication Arrangements (Administrator \ General Settings \ Integration \ Communication Arrangements)
    • use communication scenario OData Services for Business Objects
    • use Basic Authentication as authentication method
    • specify a password (username is preset by C4C)
    • assign the required OData services

About

A command-line tool to manage attachments in SAP Cloud for Customer (C4C)

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published